diff options
author | jsing <> | 2015-02-09 16:04:46 +0000 |
---|---|---|
committer | jsing <> | 2015-02-09 16:04:46 +0000 |
commit | ef9e1f7eec0659c49a61db86c7a58ea19e13d6b1 (patch) | |
tree | 2a76c2380407aba5449ce959cc484da5f0ae67ea /src/lib/libcrypto/krb5/krb5_asn.c | |
parent | c67b08b466720c73bce5f5a0ee6d8ccf43683ae6 (diff) | |
download | openbsd-ef9e1f7eec0659c49a61db86c7a58ea19e13d6b1.tar.gz openbsd-ef9e1f7eec0659c49a61db86c7a58ea19e13d6b1.tar.bz2 openbsd-ef9e1f7eec0659c49a61db86c7a58ea19e13d6b1.zip |
Expand the IMPLEMENT_ASN1_FUNCTIONS macro so that the code is visible and
functions can be readily located.
Change has been scripted and there is no change to the generated assembly.
Discussed with beck@ miod@ tedu@
Diffstat (limited to 'src/lib/libcrypto/krb5/krb5_asn.c')
-rw-r--r-- | src/lib/libcrypto/krb5/krb5_asn.c | 288 |
1 files changed, 276 insertions, 12 deletions
diff --git a/src/lib/libcrypto/krb5/krb5_asn.c b/src/lib/libcrypto/krb5/krb5_asn.c index bcef47a7bd..1a95e62935 100644 --- a/src/lib/libcrypto/krb5/krb5_asn.c +++ b/src/lib/libcrypto/krb5/krb5_asn.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: krb5_asn.c,v 1.2 2014/06/12 15:49:29 deraadt Exp $ */ | 1 | /* $OpenBSD: krb5_asn.c,v 1.3 2015/02/09 16:04:46 jsing Exp $ */ |
2 | /* Written by Vern Staats <staatsvr@asc.hpc.mil> for the OpenSSL project, | 2 | /* Written by Vern Staats <staatsvr@asc.hpc.mil> for the OpenSSL project, |
3 | ** using ocsp/{*.h,*asn*.c} as a starting point | 3 | ** using ocsp/{*.h,*asn*.c} as a starting point |
4 | */ | 4 | */ |
@@ -66,7 +66,31 @@ ASN1_SEQUENCE(KRB5_ENCDATA) = { | |||
66 | ASN1_EXP(KRB5_ENCDATA, cipher, ASN1_OCTET_STRING,2) | 66 | ASN1_EXP(KRB5_ENCDATA, cipher, ASN1_OCTET_STRING,2) |
67 | } ASN1_SEQUENCE_END(KRB5_ENCDATA) | 67 | } ASN1_SEQUENCE_END(KRB5_ENCDATA) |
68 | 68 | ||
69 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_ENCDATA) | 69 | |
70 | KRB5_ENCDATA * | ||
71 | d2i_KRB5_ENCDATA(KRB5_ENCDATA **a, const unsigned char **in, long len) | ||
72 | { | ||
73 | return (KRB5_ENCDATA *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
74 | &KRB5_ENCDATA_it); | ||
75 | } | ||
76 | |||
77 | int | ||
78 | i2d_KRB5_ENCDATA(KRB5_ENCDATA *a, unsigned char **out) | ||
79 | { | ||
80 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_ENCDATA_it); | ||
81 | } | ||
82 | |||
83 | KRB5_ENCDATA * | ||
84 | KRB5_ENCDATA_new(void) | ||
85 | { | ||
86 | return (KRB5_ENCDATA *)ASN1_item_new(&KRB5_ENCDATA_it); | ||
87 | } | ||
88 | |||
89 | void | ||
90 | KRB5_ENCDATA_free(KRB5_ENCDATA *a) | ||
91 | { | ||
92 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_ENCDATA_it); | ||
93 | } | ||
70 | 94 | ||
71 | 95 | ||
72 | ASN1_SEQUENCE(KRB5_PRINCNAME) = { | 96 | ASN1_SEQUENCE(KRB5_PRINCNAME) = { |
@@ -74,7 +98,31 @@ ASN1_SEQUENCE(KRB5_PRINCNAME) = { | |||
74 | ASN1_EXP_SEQUENCE_OF(KRB5_PRINCNAME, namestring, ASN1_GENERALSTRING, 1) | 98 | ASN1_EXP_SEQUENCE_OF(KRB5_PRINCNAME, namestring, ASN1_GENERALSTRING, 1) |
75 | } ASN1_SEQUENCE_END(KRB5_PRINCNAME) | 99 | } ASN1_SEQUENCE_END(KRB5_PRINCNAME) |
76 | 100 | ||
77 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_PRINCNAME) | 101 | |
102 | KRB5_PRINCNAME * | ||
103 | d2i_KRB5_PRINCNAME(KRB5_PRINCNAME **a, const unsigned char **in, long len) | ||
104 | { | ||
105 | return (KRB5_PRINCNAME *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
106 | &KRB5_PRINCNAME_it); | ||
107 | } | ||
108 | |||
109 | int | ||
110 | i2d_KRB5_PRINCNAME(KRB5_PRINCNAME *a, unsigned char **out) | ||
111 | { | ||
112 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_PRINCNAME_it); | ||
113 | } | ||
114 | |||
115 | KRB5_PRINCNAME * | ||
116 | KRB5_PRINCNAME_new(void) | ||
117 | { | ||
118 | return (KRB5_PRINCNAME *)ASN1_item_new(&KRB5_PRINCNAME_it); | ||
119 | } | ||
120 | |||
121 | void | ||
122 | KRB5_PRINCNAME_free(KRB5_PRINCNAME *a) | ||
123 | { | ||
124 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_PRINCNAME_it); | ||
125 | } | ||
78 | 126 | ||
79 | 127 | ||
80 | /* [APPLICATION 1] = 0x61 */ | 128 | /* [APPLICATION 1] = 0x61 */ |
@@ -85,7 +133,31 @@ ASN1_SEQUENCE(KRB5_TKTBODY) = { | |||
85 | ASN1_EXP(KRB5_TKTBODY, encdata, KRB5_ENCDATA, 3) | 133 | ASN1_EXP(KRB5_TKTBODY, encdata, KRB5_ENCDATA, 3) |
86 | } ASN1_SEQUENCE_END(KRB5_TKTBODY) | 134 | } ASN1_SEQUENCE_END(KRB5_TKTBODY) |
87 | 135 | ||
88 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_TKTBODY) | 136 | |
137 | KRB5_TKTBODY * | ||
138 | d2i_KRB5_TKTBODY(KRB5_TKTBODY **a, const unsigned char **in, long len) | ||
139 | { | ||
140 | return (KRB5_TKTBODY *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
141 | &KRB5_TKTBODY_it); | ||
142 | } | ||
143 | |||
144 | int | ||
145 | i2d_KRB5_TKTBODY(KRB5_TKTBODY *a, unsigned char **out) | ||
146 | { | ||
147 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_TKTBODY_it); | ||
148 | } | ||
149 | |||
150 | KRB5_TKTBODY * | ||
151 | KRB5_TKTBODY_new(void) | ||
152 | { | ||
153 | return (KRB5_TKTBODY *)ASN1_item_new(&KRB5_TKTBODY_it); | ||
154 | } | ||
155 | |||
156 | void | ||
157 | KRB5_TKTBODY_free(KRB5_TKTBODY *a) | ||
158 | { | ||
159 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_TKTBODY_it); | ||
160 | } | ||
89 | 161 | ||
90 | 162 | ||
91 | ASN1_ITEM_TEMPLATE(KRB5_TICKET) = | 163 | ASN1_ITEM_TEMPLATE(KRB5_TICKET) = |
@@ -93,7 +165,31 @@ ASN1_ITEM_TEMPLATE(KRB5_TICKET) = | |||
93 | KRB5_TICKET, KRB5_TKTBODY) | 165 | KRB5_TICKET, KRB5_TKTBODY) |
94 | ASN1_ITEM_TEMPLATE_END(KRB5_TICKET) | 166 | ASN1_ITEM_TEMPLATE_END(KRB5_TICKET) |
95 | 167 | ||
96 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_TICKET) | 168 | |
169 | KRB5_TICKET * | ||
170 | d2i_KRB5_TICKET(KRB5_TICKET **a, const unsigned char **in, long len) | ||
171 | { | ||
172 | return (KRB5_TICKET *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
173 | &KRB5_TICKET_it); | ||
174 | } | ||
175 | |||
176 | int | ||
177 | i2d_KRB5_TICKET(KRB5_TICKET *a, unsigned char **out) | ||
178 | { | ||
179 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_TICKET_it); | ||
180 | } | ||
181 | |||
182 | KRB5_TICKET * | ||
183 | KRB5_TICKET_new(void) | ||
184 | { | ||
185 | return (KRB5_TICKET *)ASN1_item_new(&KRB5_TICKET_it); | ||
186 | } | ||
187 | |||
188 | void | ||
189 | KRB5_TICKET_free(KRB5_TICKET *a) | ||
190 | { | ||
191 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_TICKET_it); | ||
192 | } | ||
97 | 193 | ||
98 | 194 | ||
99 | /* [APPLICATION 14] = 0x6e */ | 195 | /* [APPLICATION 14] = 0x6e */ |
@@ -105,14 +201,62 @@ ASN1_SEQUENCE(KRB5_APREQBODY) = { | |||
105 | ASN1_EXP(KRB5_APREQBODY, authenticator, KRB5_ENCDATA, 4), | 201 | ASN1_EXP(KRB5_APREQBODY, authenticator, KRB5_ENCDATA, 4), |
106 | } ASN1_SEQUENCE_END(KRB5_APREQBODY) | 202 | } ASN1_SEQUENCE_END(KRB5_APREQBODY) |
107 | 203 | ||
108 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_APREQBODY) | 204 | |
205 | KRB5_APREQBODY * | ||
206 | d2i_KRB5_APREQBODY(KRB5_APREQBODY **a, const unsigned char **in, long len) | ||
207 | { | ||
208 | return (KRB5_APREQBODY *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
209 | &KRB5_APREQBODY_it); | ||
210 | } | ||
211 | |||
212 | int | ||
213 | i2d_KRB5_APREQBODY(KRB5_APREQBODY *a, unsigned char **out) | ||
214 | { | ||
215 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_APREQBODY_it); | ||
216 | } | ||
217 | |||
218 | KRB5_APREQBODY * | ||
219 | KRB5_APREQBODY_new(void) | ||
220 | { | ||
221 | return (KRB5_APREQBODY *)ASN1_item_new(&KRB5_APREQBODY_it); | ||
222 | } | ||
223 | |||
224 | void | ||
225 | KRB5_APREQBODY_free(KRB5_APREQBODY *a) | ||
226 | { | ||
227 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_APREQBODY_it); | ||
228 | } | ||
109 | 229 | ||
110 | ASN1_ITEM_TEMPLATE(KRB5_APREQ) = | 230 | ASN1_ITEM_TEMPLATE(KRB5_APREQ) = |
111 | ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_EXPTAG|ASN1_TFLG_APPLICATION, 14, | 231 | ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_EXPTAG|ASN1_TFLG_APPLICATION, 14, |
112 | KRB5_APREQ, KRB5_APREQBODY) | 232 | KRB5_APREQ, KRB5_APREQBODY) |
113 | ASN1_ITEM_TEMPLATE_END(KRB5_APREQ) | 233 | ASN1_ITEM_TEMPLATE_END(KRB5_APREQ) |
114 | 234 | ||
115 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_APREQ) | 235 | |
236 | KRB5_APREQ * | ||
237 | d2i_KRB5_APREQ(KRB5_APREQ **a, const unsigned char **in, long len) | ||
238 | { | ||
239 | return (KRB5_APREQ *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
240 | &KRB5_APREQ_it); | ||
241 | } | ||
242 | |||
243 | int | ||
244 | i2d_KRB5_APREQ(KRB5_APREQ *a, unsigned char **out) | ||
245 | { | ||
246 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_APREQ_it); | ||
247 | } | ||
248 | |||
249 | KRB5_APREQ * | ||
250 | KRB5_APREQ_new(void) | ||
251 | { | ||
252 | return (KRB5_APREQ *)ASN1_item_new(&KRB5_APREQ_it); | ||
253 | } | ||
254 | |||
255 | void | ||
256 | KRB5_APREQ_free(KRB5_APREQ *a) | ||
257 | { | ||
258 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_APREQ_it); | ||
259 | } | ||
116 | 260 | ||
117 | 261 | ||
118 | /* Authenticator stuff */ | 262 | /* Authenticator stuff */ |
@@ -122,7 +266,31 @@ ASN1_SEQUENCE(KRB5_CHECKSUM) = { | |||
122 | ASN1_EXP(KRB5_CHECKSUM, checksum, ASN1_OCTET_STRING,1) | 266 | ASN1_EXP(KRB5_CHECKSUM, checksum, ASN1_OCTET_STRING,1) |
123 | } ASN1_SEQUENCE_END(KRB5_CHECKSUM) | 267 | } ASN1_SEQUENCE_END(KRB5_CHECKSUM) |
124 | 268 | ||
125 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_CHECKSUM) | 269 | |
270 | KRB5_CHECKSUM * | ||
271 | d2i_KRB5_CHECKSUM(KRB5_CHECKSUM **a, const unsigned char **in, long len) | ||
272 | { | ||
273 | return (KRB5_CHECKSUM *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
274 | &KRB5_CHECKSUM_it); | ||
275 | } | ||
276 | |||
277 | int | ||
278 | i2d_KRB5_CHECKSUM(KRB5_CHECKSUM *a, unsigned char **out) | ||
279 | { | ||
280 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_CHECKSUM_it); | ||
281 | } | ||
282 | |||
283 | KRB5_CHECKSUM * | ||
284 | KRB5_CHECKSUM_new(void) | ||
285 | { | ||
286 | return (KRB5_CHECKSUM *)ASN1_item_new(&KRB5_CHECKSUM_it); | ||
287 | } | ||
288 | |||
289 | void | ||
290 | KRB5_CHECKSUM_free(KRB5_CHECKSUM *a) | ||
291 | { | ||
292 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_CHECKSUM_it); | ||
293 | } | ||
126 | 294 | ||
127 | 295 | ||
128 | ASN1_SEQUENCE(KRB5_ENCKEY) = { | 296 | ASN1_SEQUENCE(KRB5_ENCKEY) = { |
@@ -130,7 +298,31 @@ ASN1_SEQUENCE(KRB5_ENCKEY) = { | |||
130 | ASN1_EXP(KRB5_ENCKEY, keyvalue, ASN1_OCTET_STRING,1) | 298 | ASN1_EXP(KRB5_ENCKEY, keyvalue, ASN1_OCTET_STRING,1) |
131 | } ASN1_SEQUENCE_END(KRB5_ENCKEY) | 299 | } ASN1_SEQUENCE_END(KRB5_ENCKEY) |
132 | 300 | ||
133 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_ENCKEY) | 301 | |
302 | KRB5_ENCKEY * | ||
303 | d2i_KRB5_ENCKEY(KRB5_ENCKEY **a, const unsigned char **in, long len) | ||
304 | { | ||
305 | return (KRB5_ENCKEY *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
306 | &KRB5_ENCKEY_it); | ||
307 | } | ||
308 | |||
309 | int | ||
310 | i2d_KRB5_ENCKEY(KRB5_ENCKEY *a, unsigned char **out) | ||
311 | { | ||
312 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_ENCKEY_it); | ||
313 | } | ||
314 | |||
315 | KRB5_ENCKEY * | ||
316 | KRB5_ENCKEY_new(void) | ||
317 | { | ||
318 | return (KRB5_ENCKEY *)ASN1_item_new(&KRB5_ENCKEY_it); | ||
319 | } | ||
320 | |||
321 | void | ||
322 | KRB5_ENCKEY_free(KRB5_ENCKEY *a) | ||
323 | { | ||
324 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_ENCKEY_it); | ||
325 | } | ||
134 | 326 | ||
135 | 327 | ||
136 | /* SEQ OF SEQ; see ASN1_EXP_SEQUENCE_OF_OPT() below */ | 328 | /* SEQ OF SEQ; see ASN1_EXP_SEQUENCE_OF_OPT() below */ |
@@ -139,7 +331,31 @@ ASN1_SEQUENCE(KRB5_AUTHDATA) = { | |||
139 | ASN1_EXP(KRB5_AUTHDATA, addata, ASN1_OCTET_STRING,1) | 331 | ASN1_EXP(KRB5_AUTHDATA, addata, ASN1_OCTET_STRING,1) |
140 | } ASN1_SEQUENCE_END(KRB5_AUTHDATA) | 332 | } ASN1_SEQUENCE_END(KRB5_AUTHDATA) |
141 | 333 | ||
142 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_AUTHDATA) | 334 | |
335 | KRB5_AUTHDATA * | ||
336 | d2i_KRB5_AUTHDATA(KRB5_AUTHDATA **a, const unsigned char **in, long len) | ||
337 | { | ||
338 | return (KRB5_AUTHDATA *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
339 | &KRB5_AUTHDATA_it); | ||
340 | } | ||
341 | |||
342 | int | ||
343 | i2d_KRB5_AUTHDATA(KRB5_AUTHDATA *a, unsigned char **out) | ||
344 | { | ||
345 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_AUTHDATA_it); | ||
346 | } | ||
347 | |||
348 | KRB5_AUTHDATA * | ||
349 | KRB5_AUTHDATA_new(void) | ||
350 | { | ||
351 | return (KRB5_AUTHDATA *)ASN1_item_new(&KRB5_AUTHDATA_it); | ||
352 | } | ||
353 | |||
354 | void | ||
355 | KRB5_AUTHDATA_free(KRB5_AUTHDATA *a) | ||
356 | { | ||
357 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_AUTHDATA_it); | ||
358 | } | ||
143 | 359 | ||
144 | 360 | ||
145 | /* [APPLICATION 2] = 0x62 */ | 361 | /* [APPLICATION 2] = 0x62 */ |
@@ -156,12 +372,60 @@ ASN1_SEQUENCE(KRB5_AUTHENTBODY) = { | |||
156 | (KRB5_AUTHENTBODY, authorization, KRB5_AUTHDATA, 8), | 372 | (KRB5_AUTHENTBODY, authorization, KRB5_AUTHDATA, 8), |
157 | } ASN1_SEQUENCE_END(KRB5_AUTHENTBODY) | 373 | } ASN1_SEQUENCE_END(KRB5_AUTHENTBODY) |
158 | 374 | ||
159 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_AUTHENTBODY) | 375 | |
376 | KRB5_AUTHENTBODY * | ||
377 | d2i_KRB5_AUTHENTBODY(KRB5_AUTHENTBODY **a, const unsigned char **in, long len) | ||
378 | { | ||
379 | return (KRB5_AUTHENTBODY *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
380 | &KRB5_AUTHENTBODY_it); | ||
381 | } | ||
382 | |||
383 | int | ||
384 | i2d_KRB5_AUTHENTBODY(KRB5_AUTHENTBODY *a, unsigned char **out) | ||
385 | { | ||
386 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_AUTHENTBODY_it); | ||
387 | } | ||
388 | |||
389 | KRB5_AUTHENTBODY * | ||
390 | KRB5_AUTHENTBODY_new(void) | ||
391 | { | ||
392 | return (KRB5_AUTHENTBODY *)ASN1_item_new(&KRB5_AUTHENTBODY_it); | ||
393 | } | ||
394 | |||
395 | void | ||
396 | KRB5_AUTHENTBODY_free(KRB5_AUTHENTBODY *a) | ||
397 | { | ||
398 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_AUTHENTBODY_it); | ||
399 | } | ||
160 | 400 | ||
161 | ASN1_ITEM_TEMPLATE(KRB5_AUTHENT) = | 401 | ASN1_ITEM_TEMPLATE(KRB5_AUTHENT) = |
162 | ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_EXPTAG|ASN1_TFLG_APPLICATION, 2, | 402 | ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_EXPTAG|ASN1_TFLG_APPLICATION, 2, |
163 | KRB5_AUTHENT, KRB5_AUTHENTBODY) | 403 | KRB5_AUTHENT, KRB5_AUTHENTBODY) |
164 | ASN1_ITEM_TEMPLATE_END(KRB5_AUTHENT) | 404 | ASN1_ITEM_TEMPLATE_END(KRB5_AUTHENT) |
165 | 405 | ||
166 | IMPLEMENT_ASN1_FUNCTIONS(KRB5_AUTHENT) | 406 | |
407 | KRB5_AUTHENT * | ||
408 | d2i_KRB5_AUTHENT(KRB5_AUTHENT **a, const unsigned char **in, long len) | ||
409 | { | ||
410 | return (KRB5_AUTHENT *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
411 | &KRB5_AUTHENT_it); | ||
412 | } | ||
413 | |||
414 | int | ||
415 | i2d_KRB5_AUTHENT(KRB5_AUTHENT *a, unsigned char **out) | ||
416 | { | ||
417 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_AUTHENT_it); | ||
418 | } | ||
419 | |||
420 | KRB5_AUTHENT * | ||
421 | KRB5_AUTHENT_new(void) | ||
422 | { | ||
423 | return (KRB5_AUTHENT *)ASN1_item_new(&KRB5_AUTHENT_it); | ||
424 | } | ||
425 | |||
426 | void | ||
427 | KRB5_AUTHENT_free(KRB5_AUTHENT *a) | ||
428 | { | ||
429 | ASN1_item_free((ASN1_VALUE *)a, &KRB5_AUTHENT_it); | ||
430 | } | ||
167 | 431 | ||