iPXE
asn1.h
Go to the documentation of this file.
1 #ifndef _IPXE_ASN1_H
2 #define _IPXE_ASN1_H
3 
4 /** @file
5  *
6  * ASN.1 encoding
7  *
8  */
9 
10 FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
11 
12 #include <stddef.h>
13 #include <stdint.h>
14 #include <stdarg.h>
15 #include <assert.h>
16 #include <time.h>
17 #include <ipxe/tables.h>
18 
19 /** An ASN.1 object cursor */
20 struct asn1_cursor {
21  /** Start of data */
22  const void *data;
23  /** Length of data */
24  size_t len;
25 };
26 
27 /** An ASN.1 object builder */
28 struct asn1_builder {
29  /** Data
30  *
31  * This is always dynamically allocated. If @c data is NULL
32  * while @len is non-zero, this indicates that a memory
33  * allocation error has occurred during the building process.
34  */
35  void *data;
36  /** Length of data */
37  size_t len;
38 };
39 
40 /** Maximum (viable) length of ASN.1 length
41  *
42  * While in theory unlimited, this length is sufficient to contain a
43  * size_t.
44  */
45 #define ASN1_MAX_LEN_LEN ( 1 + sizeof ( size_t ) )
46 
47 /** An ASN.1 header */
49  /** Type */
51  /** Length (encoded) */
53 } __attribute__ (( packed ));
54 
55 /** ASN.1 end */
56 #define ASN1_END 0x00
57 
58 /** ASN.1 boolean */
59 #define ASN1_BOOLEAN 0x01
60 
61 /** ASN.1 integer */
62 #define ASN1_INTEGER 0x02
63 
64 /** ASN.1 bit string */
65 #define ASN1_BIT_STRING 0x03
66 
67 /** ASN.1 octet string */
68 #define ASN1_OCTET_STRING 0x04
69 
70 /** ASN.1 null */
71 #define ASN1_NULL 0x05
72 
73 /** ASN.1 object identifier */
74 #define ASN1_OID 0x06
75 
76 /** ASN.1 enumeration */
77 #define ASN1_ENUMERATED 0x0a
78 
79 /** ASN.1 UTF-8 string */
80 #define ASN1_UTF8_STRING 0x0c
81 
82 /** ASN.1 UTC time */
83 #define ASN1_UTC_TIME 0x17
84 
85 /** ASN.1 generalized time */
86 #define ASN1_GENERALIZED_TIME 0x18
87 
88 /** ASN.1 sequence */
89 #define ASN1_SEQUENCE 0x30
90 
91 /** ASN.1 set */
92 #define ASN1_SET 0x31
93 
94 /** ASN.1 implicit tag */
95 #define ASN1_IMPLICIT_TAG( number) ( 0x80 | (number) )
96 
97 /** ASN.1 explicit tag */
98 #define ASN1_EXPLICIT_TAG( number) ( 0xa0 | (number) )
99 
100 /** ASN.1 "any tag" magic value */
101 #define ASN1_ANY -1U
102 
103 /** Construct a short ASN.1 value */
104 #define ASN1_SHORT( tag, ... ) \
105  (tag), VA_ARG_COUNT ( __VA_ARGS__ ), __VA_ARGS__
106 
107 /** Initial OID byte */
108 #define ASN1_OID_INITIAL( first, second ) ( ( (first) * 40 ) + (second) )
109 
110 /** Single-byte OID value
111  *
112  * Valid for values up to 127
113  */
114 #define ASN1_OID_SINGLE( value ) ( (value) & 0x7f )
115 
116 /** Double-byte OID value
117  *
118  * Valid for values up to 16383
119  */
120 #define ASN1_OID_DOUBLE( value ) \
121  ( 0x80 | ( ( (value) >> 7 ) & 0x7f ) ), ASN1_OID_SINGLE ( (value) )
122 
123 /** Double-byte OID value
124  *
125  * Valid for values up to 2097151
126  */
127 #define ASN1_OID_TRIPLE( value ) \
128  ( 0x80 | ( ( (value) >> 14 ) & 0x7f ) ), ASN1_OID_DOUBLE ( (value) )
129 
130 /** ASN.1 OID for prime256v1 (1.2.840.10045.3.1.7) */
131 #define ASN1_OID_PRIME256V1 \
132  ASN1_OID_INITIAL ( 1, 1 ), ASN1_OID_DOUBLE ( 840 ), \
133  ASN1_OID_DOUBLE ( 10045 ), ASN1_OID_SINGLE ( 3 ), \
134  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 7 )
135 
136 /** ASN.1 OID for rsaEncryption (1.2.840.113549.1.1.1) */
137 #define ASN1_OID_RSAENCRYPTION \
138  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
139  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
140  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 1 )
141 
142 /** ASN.1 OID for md5WithRSAEncryption (1.2.840.113549.1.1.4) */
143 #define ASN1_OID_MD5WITHRSAENCRYPTION \
144  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
145  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
146  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 4 )
147 
148 /** ASN.1 OID for sha1WithRSAEncryption (1.2.840.113549.1.1.5) */
149 #define ASN1_OID_SHA1WITHRSAENCRYPTION \
150  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
151  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
152  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 )
153 
154 /** ASN.1 OID for sha256WithRSAEncryption (1.2.840.113549.1.1.11) */
155 #define ASN1_OID_SHA256WITHRSAENCRYPTION \
156  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
157  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
158  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 11 )
159 
160 /** ASN.1 OID for sha384WithRSAEncryption (1.2.840.113549.1.1.12) */
161 #define ASN1_OID_SHA384WITHRSAENCRYPTION \
162  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
163  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
164  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 12 )
165 
166 /** ASN.1 OID for sha512WithRSAEncryption (1.2.840.113549.1.1.13) */
167 #define ASN1_OID_SHA512WITHRSAENCRYPTION \
168  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
169  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
170  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 13 )
171 
172 /** ASN.1 OID for sha224WithRSAEncryption (1.2.840.113549.1.1.14) */
173 #define ASN1_OID_SHA224WITHRSAENCRYPTION \
174  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
175  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
176  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 14 )
177 
178 /** ASN.1 OID for id-md4 (1.2.840.113549.2.4) */
179 #define ASN1_OID_MD4 \
180  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
181  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 2 ), \
182  ASN1_OID_SINGLE ( 4 )
183 
184 /** ASN.1 OID for id-md5 (1.2.840.113549.2.5) */
185 #define ASN1_OID_MD5 \
186  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
187  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 2 ), \
188  ASN1_OID_SINGLE ( 5 )
189 
190 /** ASN.1 OID for id-sha1 (1.3.14.3.2.26) */
191 #define ASN1_OID_SHA1 \
192  ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 14 ), \
193  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 2 ), \
194  ASN1_OID_SINGLE ( 26 )
195 
196 /** ASN.1 OID for id-x25519 (1.3.101.110) */
197 #define ASN1_OID_X25519 \
198  ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 101 ), \
199  ASN1_OID_SINGLE ( 110 )
200 
201 /** ASN.1 OID for secp384r1 (1.3.132.0.34) */
202 #define ASN1_OID_SECP384R1 \
203  ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_DOUBLE ( 132 ), \
204  ASN1_OID_SINGLE ( 0 ), ASN1_OID_SINGLE ( 34 )
205 
206 /** ASN.1 OID for id-aes128-cbc (2.16.840.1.101.3.4.1.2) */
207 #define ASN1_OID_AES128_CBC \
208  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
209  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
210  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
211  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 2 )
212 
213 /** ASN.1 OID for id-aes128-gcm (2.16.840.1.101.3.4.1.6) */
214 #define ASN1_OID_AES128_GCM \
215  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
216  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
217  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
218  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 6 )
219 
220 /** ASN.1 OID for id-aes192-cbc (2.16.840.1.101.3.4.1.22) */
221 #define ASN1_OID_AES192_CBC \
222  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
223  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
224  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
225  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 22 )
226 
227 /** ASN.1 OID for id-aes192-gcm (2.16.840.1.101.3.4.1.26) */
228 #define ASN1_OID_AES192_GCM \
229  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
230  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
231  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
232  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 26 )
233 
234 /** ASN.1 OID for id-aes256-cbc (2.16.840.1.101.3.4.1.42) */
235 #define ASN1_OID_AES256_CBC \
236  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
237  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
238  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
239  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 42 )
240 
241 /** ASN.1 OID for id-aes256-gcm (2.16.840.1.101.3.4.1.46) */
242 #define ASN1_OID_AES256_GCM \
243  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
244  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
245  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
246  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 46 )
247 
248 /** ASN.1 OID for id-sha256 (2.16.840.1.101.3.4.2.1) */
249 #define ASN1_OID_SHA256 \
250  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
251  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
252  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
253  ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 1 )
254 
255 /** ASN.1 OID for id-sha384 (2.16.840.1.101.3.4.2.2) */
256 #define ASN1_OID_SHA384 \
257  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
258  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
259  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
260  ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 2 )
261 
262 /** ASN.1 OID for id-sha512 (2.16.840.1.101.3.4.2.3) */
263 #define ASN1_OID_SHA512 \
264  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
265  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
266  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
267  ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 3 )
268 
269 /** ASN.1 OID for id-sha224 (2.16.840.1.101.3.4.2.4) */
270 #define ASN1_OID_SHA224 \
271  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
272  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
273  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
274  ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 4 )
275 
276 /** ASN.1 OID for id-sha512-224 (2.16.840.1.101.3.4.2.5) */
277 #define ASN1_OID_SHA512_224 \
278  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
279  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
280  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
281  ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 5 )
282 
283 /** ASN.1 OID for id-sha512-256 (2.16.840.1.101.3.4.2.6) */
284 #define ASN1_OID_SHA512_256 \
285  ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
286  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
287  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
288  ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 6 )
289 
290 /** ASN.1 OID for commonName (2.5.4.3) */
291 #define ASN1_OID_COMMON_NAME \
292  ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 4 ), \
293  ASN1_OID_SINGLE ( 3 )
294 
295 /** ASN.1 OID for id-ce-keyUsage (2.5.29.15) */
296 #define ASN1_OID_KEYUSAGE \
297  ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \
298  ASN1_OID_SINGLE ( 15 )
299 
300 /** ASN.1 OID for id-ce-basicConstraints (2.5.29.19) */
301 #define ASN1_OID_BASICCONSTRAINTS \
302  ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \
303  ASN1_OID_SINGLE ( 19 )
304 
305 /** ASN.1 OID for id-ce-extKeyUsage (2.5.29.37) */
306 #define ASN1_OID_EXTKEYUSAGE \
307  ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \
308  ASN1_OID_SINGLE ( 37 )
309 
310 /** ASN.1 OID for id-kp-codeSigning (1.3.6.1.5.5.7.3.3) */
311 #define ASN1_OID_CODESIGNING \
312  ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
313  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
314  ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
315  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 3 )
316 
317 /** ASN.1 OID for id-signedData (1.2.840.113549.1.7.2) */
318 #define ASN1_OID_SIGNEDDATA \
319  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
320  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
321  ASN1_OID_SINGLE ( 7 ), ASN1_OID_SINGLE ( 2 )
322 
323 /** ASN.1 OID for id-envelopedData (1.2.840.113549.1.7.3) */
324 #define ASN1_OID_ENVELOPEDDATA \
325  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
326  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
327  ASN1_OID_SINGLE ( 7 ), ASN1_OID_SINGLE ( 3 )
328 
329 /** ASN.1 OID for id-authEnvelopedData (1.2.840.113549.1.9.16.1.23) */
330 #define ASN1_OID_AUTHENVELOPEDDATA \
331  ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
332  ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
333  ASN1_OID_SINGLE ( 9 ), ASN1_OID_SINGLE ( 16 ), \
334  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 23 )
335 
336 /** ASN.1 OID for id-pe-authorityInfoAccess (1.3.6.1.5.5.7.1.1) */
337 #define ASN1_OID_AUTHORITYINFOACCESS \
338  ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
339  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
340  ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
341  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 1 )
342 
343 /** ASN.1 OID for id-ad-ocsp (1.3.6.1.5.5.7.48.1) */
344 #define ASN1_OID_OCSP \
345  ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
346  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
347  ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
348  ASN1_OID_SINGLE ( 48 ), ASN1_OID_SINGLE ( 1 )
349 
350 /** ASN.1 OID for id-pkix-ocsp-basic ( 1.3.6.1.5.5.7.48.1.1) */
351 #define ASN1_OID_OCSP_BASIC \
352  ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
353  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
354  ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
355  ASN1_OID_SINGLE ( 48 ), ASN1_OID_SINGLE ( 1 ), \
356  ASN1_OID_SINGLE ( 1 )
357 
358 /** ASN.1 OID for id-kp-OCSPSigning (1.3.6.1.5.5.7.3.9) */
359 #define ASN1_OID_OCSPSIGNING \
360  ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
361  ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
362  ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
363  ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 9 )
364 
365 /** ASN.1 OID for id-ce-subjectAltName (2.5.29.17) */
366 #define ASN1_OID_SUBJECTALTNAME \
367  ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \
368  ASN1_OID_SINGLE ( 17 )
369 
370 /** Define an ASN.1 cursor for a static value */
371 #define ASN1_CURSOR( value ) { \
372  .data = value, \
373  .len = sizeof ( value ), \
374  }
375 
376 /** An ASN.1 OID-identified algorithm */
378  /** Name */
379  const char *name;
380  /** Object identifier */
381  struct asn1_cursor oid;
382  /** Public-key algorithm (if applicable) */
384  /** Digest algorithm (if applicable) */
386  /** Cipher algorithm (if applicable) */
388  /** Elliptic curve (if applicable) */
390  /**
391  * Parse algorithm parameters (optional)
392  *
393  * @v algorithm Algorithm
394  * @v param Parameters to parse (and potentially modify)
395  * @ret rc Return status code
396  */
397  int ( * parse ) ( struct asn1_algorithm *algorithm,
398  struct asn1_cursor *params );
399 };
400 
401 /** ASN.1 OID-identified algorithms */
402 #define ASN1_ALGORITHMS __table ( struct asn1_algorithm, "asn1_algorithms" )
403 
404 /** Declare an ASN.1 OID-identified algorithm */
405 #define __asn1_algorithm __table_entry ( ASN1_ALGORITHMS, 01 )
406 
407 /* ASN.1 OID-identified algorithms */
408 extern struct asn1_algorithm rsa_encryption_algorithm __asn1_algorithm;
409 extern struct asn1_algorithm md5_with_rsa_encryption_algorithm __asn1_algorithm;
410 extern struct asn1_algorithm
411 sha1_with_rsa_encryption_algorithm __asn1_algorithm;
412 extern struct asn1_algorithm
413 sha256_with_rsa_encryption_algorithm __asn1_algorithm;
414 extern struct asn1_algorithm
415 sha384_with_rsa_encryption_algorithm __asn1_algorithm;
416 extern struct asn1_algorithm
417 sha512_with_rsa_encryption_algorithm __asn1_algorithm;
418 extern struct asn1_algorithm
419 sha224_with_rsa_encryption_algorithm __asn1_algorithm;
420 extern struct asn1_algorithm oid_md4_algorithm __asn1_algorithm;
421 extern struct asn1_algorithm oid_md5_algorithm __asn1_algorithm;
422 extern struct asn1_algorithm oid_sha1_algorithm __asn1_algorithm;
423 extern struct asn1_algorithm oid_sha256_algorithm __asn1_algorithm;
424 extern struct asn1_algorithm oid_sha384_algorithm __asn1_algorithm;
425 extern struct asn1_algorithm oid_sha512_algorithm __asn1_algorithm;
426 extern struct asn1_algorithm oid_sha224_algorithm __asn1_algorithm;
427 extern struct asn1_algorithm oid_sha512_224_algorithm __asn1_algorithm;
428 extern struct asn1_algorithm oid_sha512_256_algorithm __asn1_algorithm;
429 
430 /** An ASN.1 bit string */
432  /** Data */
433  const void *data;
434  /** Length */
435  size_t len;
436  /** Unused bits at end of data */
437  unsigned int unused;
438 } __attribute__ (( packed ));
439 
440 /**
441  * Invalidate ASN.1 object cursor
442  *
443  * @v cursor ASN.1 object cursor
444  */
445 static inline __attribute__ (( always_inline )) void
447  cursor->len = 0;
448 }
449 
450 /**
451  * Extract ASN.1 type
452  *
453  * @v cursor ASN.1 object cursor
454  * @ret type Type, or ASN1_END if cursor is invalid
455  */
456 static inline __attribute__ (( always_inline )) unsigned int
457 asn1_type ( const struct asn1_cursor *cursor ) {
458  const uint8_t *type = cursor->data;
459 
460  return ( ( cursor->len >= sizeof ( *type ) ) ? *type : ASN1_END );
461 }
462 
463 /**
464  * Get cursor for built object
465  *
466  * @v builder ASN.1 object builder
467  * @ret cursor ASN.1 object cursor
468  */
469 static inline __attribute__ (( always_inline )) struct asn1_cursor *
470 asn1_built ( struct asn1_builder *builder ) {
471  union {
472  struct asn1_builder builder;
473  struct asn1_cursor cursor;
474  } *u = container_of ( builder, typeof ( *u ), builder );
475 
476  /* Sanity check */
477  build_assert ( ( ( const void * ) &u->builder.data ) ==
478  &u->cursor.data );
479  build_assert ( &u->builder.len == &u->cursor.len );
480 
481  return &u->cursor;
482 }
483 
484 extern int asn1_enter_partial ( struct asn1_cursor *cursor, unsigned int type,
485  size_t *extra );
486 extern int asn1_enter ( struct asn1_cursor *cursor, unsigned int type );
487 extern int asn1_skip_if_exists ( struct asn1_cursor *cursor,
488  unsigned int type );
489 extern int asn1_skip ( struct asn1_cursor *cursor, unsigned int type );
490 extern int asn1_shrink ( struct asn1_cursor *cursor, unsigned int type );
491 extern int asn1_enter_any ( struct asn1_cursor *cursor );
492 extern int asn1_skip_any ( struct asn1_cursor *cursor );
493 extern int asn1_shrink_any ( struct asn1_cursor *cursor );
494 extern int asn1_boolean ( const struct asn1_cursor *cursor );
495 extern int asn1_integer ( const struct asn1_cursor *cursor, int *value );
496 extern int asn1_bit_string ( const struct asn1_cursor *cursor,
497  struct asn1_bit_string *bits );
498 extern int asn1_integral_bit_string ( const struct asn1_cursor *cursor,
499  struct asn1_bit_string *bits );
500 extern int asn1_compare ( const struct asn1_cursor *cursor1,
501  const struct asn1_cursor *cursor2 );
502 extern int asn1_algorithm ( const struct asn1_cursor *cursor,
503  struct asn1_algorithm **algorithm,
504  struct asn1_cursor *params );
505 extern int asn1_pubkey_algorithm ( const struct asn1_cursor *cursor,
506  struct asn1_algorithm **algorithm );
507 extern int asn1_digest_algorithm ( const struct asn1_cursor *cursor,
508  struct asn1_algorithm **algorithm );
509 extern int asn1_cipher_algorithm ( const struct asn1_cursor *cursor,
510  struct asn1_algorithm **algorithm,
511  struct asn1_cursor *params );
512 extern int asn1_signature_algorithm ( const struct asn1_cursor *cursor,
513  struct asn1_algorithm **algorithm );
514 extern int asn1_check_algorithm ( const struct asn1_cursor *cursor,
515  struct asn1_algorithm *expected );
516 extern int asn1_parse_cbc ( struct asn1_algorithm *algorithm,
517  struct asn1_cursor *params );
518 extern int asn1_parse_gcm ( struct asn1_algorithm *algorithm,
519  struct asn1_cursor *params );
520 extern int asn1_generalized_time ( const struct asn1_cursor *cursor,
521  time_t *time );
522 extern int asn1_grow ( struct asn1_builder *builder, size_t extra );
523 extern int asn1_prepend_raw ( struct asn1_builder *builder, const void *data,
524  size_t len );
525 extern int asn1_prepend ( struct asn1_builder *builder, unsigned int type,
526  const void *data, size_t len );
527 extern int asn1_wrap ( struct asn1_builder *builder, unsigned int type );
528 
529 #endif /* _IPXE_ASN1_H */
int asn1_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm, struct asn1_cursor *params)
Parse ASN.1 OID-identified algorithm.
Definition: asn1.c:516
#define __attribute__(x)
Definition: compiler.h:10
const void * data
Data.
Definition: asn1.h:433
An ASN.1 OID-identified algorithm.
Definition: asn1.h:377
void * data
Data.
Definition: asn1.h:35
struct cipher_algorithm * cipher
Cipher algorithm (if applicable)
Definition: asn1.h:387
uint8_t extra
Signature extra byte.
Definition: smbios.h:17
int asn1_digest_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm)
Parse ASN.1 OID-identified digest algorithm.
Definition: asn1.c:592
int asn1_generalized_time(const struct asn1_cursor *cursor, time_t *time)
Parse ASN.1 GeneralizedTime.
Definition: asn1.c:751
#define ASN1_END
ASN.1 end.
Definition: asn1.h:56
int asn1_boolean(const struct asn1_cursor *cursor)
Parse value of ASN.1 boolean.
Definition: asn1.c:333
int asn1_cipher_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm, struct asn1_cursor *params)
Parse ASN.1 OID-identified cipher algorithm.
Definition: asn1.c:619
uint32_t type
Operating system type.
Definition: ena.h:12
const void * data
Start of data.
Definition: asn1.h:22
int asn1_skip(struct asn1_cursor *cursor, unsigned int type)
Skip ASN.1 object.
Definition: asn1.c:254
#define __asn1_algorithm
Declare an ASN.1 OID-identified algorithm.
Definition: asn1.h:405
int asn1_prepend_raw(struct asn1_builder *builder, const void *data, size_t len)
Prepend raw data to ASN.1 builder.
Definition: asn1.c:923
int asn1_enter(struct asn1_cursor *cursor, unsigned int type)
Enter ASN.1 object.
Definition: asn1.c:205
uint8_t length[ASN1_MAX_LEN_LEN]
Length (encoded)
Definition: asn1.h:52
static unsigned int asn1_type(const struct asn1_cursor *cursor)
Extract ASN.1 type.
Definition: asn1.h:457
int asn1_integral_bit_string(const struct asn1_cursor *cursor, struct asn1_bit_string *bits)
Parse ASN.1 bit string that must be an integral number of bytes.
Definition: asn1.c:451
uint8_t type
Type.
Definition: asn1.h:50
int asn1_shrink(struct asn1_cursor *cursor, unsigned int type)
Shrink ASN.1 cursor to fit object.
Definition: asn1.c:277
size_t len
Length of data.
Definition: asn1.h:24
int asn1_skip_if_exists(struct asn1_cursor *cursor, unsigned int type)
Skip ASN.1 object if present.
Definition: asn1.c:225
struct pubkey_algorithm * pubkey
Public-key algorithm (if applicable)
Definition: asn1.h:383
int asn1_shrink_any(struct asn1_cursor *cursor)
Shrink ASN.1 object of any type.
Definition: asn1.c:323
int asn1_prepend(struct asn1_builder *builder, unsigned int type, const void *data, size_t len)
Prepend data to ASN.1 builder.
Definition: asn1.c:946
Assertions.
#define container_of(ptr, type, field)
Get containing structure.
Definition: stddef.h:35
int asn1_pubkey_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm)
Parse ASN.1 OID-identified public-key algorithm.
Definition: asn1.c:566
pseudo_bit_t value[0x00020]
Definition: arbel.h:13
#define build_assert(condition)
Assert a condition at build time (after dead code elimination)
Definition: assert.h:76
int asn1_parse_gcm(struct asn1_algorithm *algorithm, struct asn1_cursor *params)
#define ASN1_MAX_LEN_LEN
Maximum (viable) length of ASN.1 length.
Definition: asn1.h:45
int asn1_compare(const struct asn1_cursor *cursor1, const struct asn1_cursor *cursor2)
Compare two ASN.1 objects.
Definition: asn1.c:480
unsigned int unused
Unused bits at end of data.
Definition: asn1.h:437
int asn1_wrap(struct asn1_builder *builder, unsigned int type)
Wrap ASN.1 builder.
Definition: asn1.c:973
int asn1_signature_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm)
Parse ASN.1 OID-identified signature algorithm.
Definition: asn1.c:646
static void asn1_invalidate_cursor(struct asn1_cursor *cursor)
Invalidate ASN.1 object cursor.
Definition: asn1.h:446
size_t len
Length.
Definition: asn1.h:435
FILE_LICENCE(GPL2_OR_LATER_OR_UBDL)
struct elliptic_curve * curve
Elliptic curve (if applicable)
Definition: asn1.h:389
An ASN.1 object builder.
Definition: asn1.h:28
int asn1_enter_partial(struct asn1_cursor *cursor, unsigned int type, size_t *extra)
Enter ASN.1 partial object.
Definition: asn1.c:171
int asn1_bit_string(const struct asn1_cursor *cursor, struct asn1_bit_string *bits)
Parse ASN.1 bit string.
Definition: asn1.c:396
unsigned char uint8_t
Definition: stdint.h:10
struct asn1_cursor oid
Object identifier.
Definition: asn1.h:381
int asn1_integer(const struct asn1_cursor *cursor, int *value)
Parse value of ASN.1 integer.
Definition: asn1.c:357
int asn1_check_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm *expected)
Check ASN.1 OID-identified algorithm.
Definition: asn1.c:680
int asn1_skip_any(struct asn1_cursor *cursor)
Skip ASN.1 object of any type.
Definition: asn1.c:313
An ASN.1 header.
Definition: asn1.h:48
u16 algorithm
Authentication algorithm (Open System or Shared Key)
Definition: ieee80211.h:1030
const char * name
Name.
Definition: asn1.h:379
An elliptic curve.
Definition: crypto.h:184
static volatile void * bits
Definition: bitops.h:27
struct digest_algorithm * digest
Digest algorithm (if applicable)
Definition: asn1.h:385
int asn1_grow(struct asn1_builder *builder, size_t extra)
Grow ASN.1 builder.
Definition: asn1.c:890
A message digest algorithm.
Definition: crypto.h:18
union @17 u
uint8_t data[48]
Additional event data.
Definition: ena.h:22
A cipher algorithm.
Definition: crypto.h:50
Linker tables.
static struct asn1_cursor * asn1_built(struct asn1_builder *builder)
Get cursor for built object.
Definition: asn1.h:470
typeof(acpi_finder=acpi_find)
ACPI table finder.
Definition: acpi.c:45
int(* parse)(struct asn1_algorithm *algorithm, struct asn1_cursor *params)
Parse algorithm parameters (optional)
Definition: asn1.h:397
int asn1_parse_cbc(struct asn1_algorithm *algorithm, struct asn1_cursor *params)
Parse ASN.1 CBC cipher parameters.
Definition: asn1.c:706
int64_t time_t
Seconds since the Epoch.
Definition: time.h:18
Time source.
uint32_t len
Length.
Definition: ena.h:14
size_t len
Length of data.
Definition: asn1.h:37
An ASN.1 object cursor.
Definition: asn1.h:20
A public key algorithm.
Definition: crypto.h:121
An ASN.1 bit string.
Definition: asn1.h:431
int asn1_enter_any(struct asn1_cursor *cursor)
Enter ASN.1 object of any type.
Definition: asn1.c:303