You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

asn1.h 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374
  1. #ifndef _IPXE_ASN1_H
  2. #define _IPXE_ASN1_H
  3. /** @file
  4. *
  5. * ASN.1 encoding
  6. *
  7. */
  8. FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
  9. #include <stdint.h>
  10. #include <time.h>
  11. #include <ipxe/tables.h>
  12. /** An ASN.1 object cursor */
  13. struct asn1_cursor {
  14. /** Start of data */
  15. const void *data;
  16. /** Length of data */
  17. size_t len;
  18. };
  19. /** An ASN.1 object builder */
  20. struct asn1_builder {
  21. /** Data
  22. *
  23. * This is always dynamically allocated. If @c data is NULL
  24. * while @len is non-zero, this indicates that a memory
  25. * allocation error has occurred during the building process.
  26. */
  27. void *data;
  28. /** Length of data */
  29. size_t len;
  30. };
  31. /** Maximum (viable) length of ASN.1 length
  32. *
  33. * While in theory unlimited, this length is sufficient to contain a
  34. * size_t.
  35. */
  36. #define ASN1_MAX_LEN_LEN ( 1 + sizeof ( size_t ) )
  37. /** An ASN.1 header */
  38. struct asn1_builder_header {
  39. /** Type */
  40. uint8_t type;
  41. /** Length (encoded) */
  42. uint8_t length[ASN1_MAX_LEN_LEN];
  43. } __attribute__ (( packed ));
  44. /** ASN.1 end */
  45. #define ASN1_END 0x00
  46. /** ASN.1 boolean */
  47. #define ASN1_BOOLEAN 0x01
  48. /** ASN.1 integer */
  49. #define ASN1_INTEGER 0x02
  50. /** ASN.1 bit string */
  51. #define ASN1_BIT_STRING 0x03
  52. /** ASN.1 octet string */
  53. #define ASN1_OCTET_STRING 0x04
  54. /** ASN.1 null */
  55. #define ASN1_NULL 0x05
  56. /** ASN.1 object identifier */
  57. #define ASN1_OID 0x06
  58. /** ASN.1 enumeration */
  59. #define ASN1_ENUMERATED 0x0a
  60. /** ASN.1 UTC time */
  61. #define ASN1_UTC_TIME 0x17
  62. /** ASN.1 generalized time */
  63. #define ASN1_GENERALIZED_TIME 0x18
  64. /** ASN.1 sequence */
  65. #define ASN1_SEQUENCE 0x30
  66. /** ASN.1 set */
  67. #define ASN1_SET 0x31
  68. /** ASN.1 implicit tag */
  69. #define ASN1_IMPLICIT_TAG( number) ( 0x80 | (number) )
  70. /** ASN.1 explicit tag */
  71. #define ASN1_EXPLICIT_TAG( number) ( 0xa0 | (number) )
  72. /** ASN.1 "any tag" magic value */
  73. #define ASN1_ANY -1U
  74. /** Initial OID byte */
  75. #define ASN1_OID_INITIAL( first, second ) ( ( (first) * 40 ) + (second) )
  76. /** Single-byte OID value
  77. *
  78. * Valid for values up to 127
  79. */
  80. #define ASN1_OID_SINGLE( value ) ( (value) & 0x7f )
  81. /** Double-byte OID value
  82. *
  83. * Valid for values up to 16383
  84. */
  85. #define ASN1_OID_DOUBLE( value ) \
  86. ( 0x80 | ( ( (value) >> 7 ) & 0x7f ) ), ASN1_OID_SINGLE ( (value) )
  87. /** Double-byte OID value
  88. *
  89. * Valid for values up to 2097151
  90. */
  91. #define ASN1_OID_TRIPLE( value ) \
  92. ( 0x80 | ( ( (value) >> 14 ) & 0x7f ) ), ASN1_OID_DOUBLE ( (value) )
  93. /** ASN.1 OID for rsaEncryption (1.2.840.113549.1.1.1) */
  94. #define ASN1_OID_RSAENCRYPTION \
  95. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  96. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
  97. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 1 )
  98. /** ASN.1 OID for md5WithRSAEncryption (1.2.840.113549.1.1.4) */
  99. #define ASN1_OID_MD5WITHRSAENCRYPTION \
  100. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  101. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
  102. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 4 )
  103. /** ASN.1 OID for sha1WithRSAEncryption (1.2.840.113549.1.1.5) */
  104. #define ASN1_OID_SHA1WITHRSAENCRYPTION \
  105. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  106. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
  107. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 )
  108. /** ASN.1 OID for sha256WithRSAEncryption (1.2.840.113549.1.1.11) */
  109. #define ASN1_OID_SHA256WITHRSAENCRYPTION \
  110. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  111. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
  112. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 11 )
  113. /** ASN.1 OID for sha384WithRSAEncryption (1.2.840.113549.1.1.12) */
  114. #define ASN1_OID_SHA384WITHRSAENCRYPTION \
  115. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  116. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
  117. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 12 )
  118. /** ASN.1 OID for sha512WithRSAEncryption (1.2.840.113549.1.1.13) */
  119. #define ASN1_OID_SHA512WITHRSAENCRYPTION \
  120. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  121. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
  122. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 13 )
  123. /** ASN.1 OID for sha224WithRSAEncryption (1.2.840.113549.1.1.14) */
  124. #define ASN1_OID_SHA224WITHRSAENCRYPTION \
  125. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  126. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
  127. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 14 )
  128. /** ASN.1 OID for id-md5 (1.2.840.113549.2.5) */
  129. #define ASN1_OID_MD5 \
  130. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  131. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 2 ), \
  132. ASN1_OID_SINGLE ( 5 )
  133. /** ASN.1 OID for id-sha1 (1.3.14.3.2.26) */
  134. #define ASN1_OID_SHA1 \
  135. ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 14 ), \
  136. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 2 ), \
  137. ASN1_OID_SINGLE ( 26 )
  138. /** ASN.1 OID for id-sha256 (2.16.840.1.101.3.4.2.1) */
  139. #define ASN1_OID_SHA256 \
  140. ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
  141. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
  142. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
  143. ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 1 )
  144. /** ASN.1 OID for id-sha384 (2.16.840.1.101.3.4.2.2) */
  145. #define ASN1_OID_SHA384 \
  146. ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
  147. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
  148. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
  149. ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 2 )
  150. /** ASN.1 OID for id-sha512 (2.16.840.1.101.3.4.2.3) */
  151. #define ASN1_OID_SHA512 \
  152. ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
  153. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
  154. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
  155. ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 3 )
  156. /** ASN.1 OID for id-sha224 (2.16.840.1.101.3.4.2.4) */
  157. #define ASN1_OID_SHA224 \
  158. ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
  159. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
  160. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
  161. ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 4 )
  162. /** ASN.1 OID for id-sha512-224 (2.16.840.1.101.3.4.2.5) */
  163. #define ASN1_OID_SHA512_224 \
  164. ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
  165. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
  166. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
  167. ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 5 )
  168. /** ASN.1 OID for id-sha512-256 (2.16.840.1.101.3.4.2.6) */
  169. #define ASN1_OID_SHA512_256 \
  170. ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \
  171. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \
  172. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \
  173. ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 6 )
  174. /** ASN.1 OID for commonName (2.5.4.3) */
  175. #define ASN1_OID_COMMON_NAME \
  176. ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 4 ), \
  177. ASN1_OID_SINGLE ( 3 )
  178. /** ASN.1 OID for id-ce-keyUsage (2.5.29.15) */
  179. #define ASN1_OID_KEYUSAGE \
  180. ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \
  181. ASN1_OID_SINGLE ( 15 )
  182. /** ASN.1 OID for id-ce-basicConstraints (2.5.29.19) */
  183. #define ASN1_OID_BASICCONSTRAINTS \
  184. ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \
  185. ASN1_OID_SINGLE ( 19 )
  186. /** ASN.1 OID for id-ce-extKeyUsage (2.5.29.37) */
  187. #define ASN1_OID_EXTKEYUSAGE \
  188. ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \
  189. ASN1_OID_SINGLE ( 37 )
  190. /** ASN.1 OID for id-kp-codeSigning (1.3.6.1.5.5.7.3.3) */
  191. #define ASN1_OID_CODESIGNING \
  192. ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
  193. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
  194. ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
  195. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 3 )
  196. /** ASN.1 OID for pkcs-signedData (1.2.840.113549.1.7.2) */
  197. #define ASN1_OID_SIGNEDDATA \
  198. ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \
  199. ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \
  200. ASN1_OID_SINGLE ( 7 ), ASN1_OID_SINGLE ( 2 )
  201. /** ASN.1 OID for id-pe-authorityInfoAccess (1.3.6.1.5.5.7.1.1) */
  202. #define ASN1_OID_AUTHORITYINFOACCESS \
  203. ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
  204. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
  205. ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
  206. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 1 )
  207. /** ASN.1 OID for id-ad-ocsp (1.3.6.1.5.5.7.48.1) */
  208. #define ASN1_OID_OCSP \
  209. ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
  210. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
  211. ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
  212. ASN1_OID_SINGLE ( 48 ), ASN1_OID_SINGLE ( 1 )
  213. /** ASN.1 OID for id-pkix-ocsp-basic ( 1.3.6.1.5.5.7.48.1.1) */
  214. #define ASN1_OID_OCSP_BASIC \
  215. ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
  216. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
  217. ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
  218. ASN1_OID_SINGLE ( 48 ), ASN1_OID_SINGLE ( 1 ), \
  219. ASN1_OID_SINGLE ( 1 )
  220. /** ASN.1 OID for id-kp-OCSPSigning (1.3.6.1.5.5.7.3.9) */
  221. #define ASN1_OID_OCSPSIGNING \
  222. ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \
  223. ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \
  224. ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \
  225. ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 9 )
  226. /** ASN.1 OID for id-ce-subjectAltName (2.5.29.17) */
  227. #define ASN1_OID_SUBJECTALTNAME \
  228. ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \
  229. ASN1_OID_SINGLE ( 17 )
  230. /** Define an ASN.1 cursor containing an OID */
  231. #define ASN1_OID_CURSOR( oid_value ) { \
  232. .data = oid_value, \
  233. .len = sizeof ( oid_value ), \
  234. }
  235. /** An ASN.1 OID-identified algorithm */
  236. struct asn1_algorithm {
  237. /** Name */
  238. const char *name;
  239. /** Object identifier */
  240. struct asn1_cursor oid;
  241. /** Public-key algorithm (if applicable) */
  242. struct pubkey_algorithm *pubkey;
  243. /** Digest algorithm (if applicable) */
  244. struct digest_algorithm *digest;
  245. };
  246. /** ASN.1 OID-identified algorithms */
  247. #define ASN1_ALGORITHMS __table ( struct asn1_algorithm, "asn1_algorithms" )
  248. /** Declare an ASN.1 OID-identified algorithm */
  249. #define __asn1_algorithm __table_entry ( ASN1_ALGORITHMS, 01 )
  250. /** An ASN.1 bit string */
  251. struct asn1_bit_string {
  252. /** Data */
  253. const void *data;
  254. /** Length */
  255. size_t len;
  256. /** Unused bits at end of data */
  257. unsigned int unused;
  258. } __attribute__ (( packed ));
  259. /**
  260. * Invalidate ASN.1 object cursor
  261. *
  262. * @v cursor ASN.1 object cursor
  263. */
  264. static inline __attribute__ (( always_inline )) void
  265. asn1_invalidate_cursor ( struct asn1_cursor *cursor ) {
  266. cursor->len = 0;
  267. }
  268. /**
  269. * Extract ASN.1 type
  270. *
  271. * @v cursor ASN.1 object cursor
  272. * @ret type Type, or ASN1_END if cursor is invalid
  273. */
  274. static inline __attribute__ (( always_inline )) unsigned int
  275. asn1_type ( const struct asn1_cursor *cursor ) {
  276. const uint8_t *type = cursor->data;
  277. return ( ( cursor->len >= sizeof ( *type ) ) ? *type : ASN1_END );
  278. }
  279. extern int asn1_start ( struct asn1_cursor *cursor, unsigned int type,
  280. size_t extra );
  281. extern int asn1_enter ( struct asn1_cursor *cursor, unsigned int type );
  282. extern int asn1_skip_if_exists ( struct asn1_cursor *cursor,
  283. unsigned int type );
  284. extern int asn1_skip ( struct asn1_cursor *cursor, unsigned int type );
  285. extern int asn1_shrink ( struct asn1_cursor *cursor, unsigned int type );
  286. extern int asn1_enter_any ( struct asn1_cursor *cursor );
  287. extern int asn1_skip_any ( struct asn1_cursor *cursor );
  288. extern int asn1_shrink_any ( struct asn1_cursor *cursor );
  289. extern int asn1_boolean ( const struct asn1_cursor *cursor );
  290. extern int asn1_integer ( const struct asn1_cursor *cursor, int *value );
  291. extern int asn1_bit_string ( const struct asn1_cursor *cursor,
  292. struct asn1_bit_string *bits );
  293. extern int asn1_integral_bit_string ( const struct asn1_cursor *cursor,
  294. struct asn1_bit_string *bits );
  295. extern int asn1_compare ( const struct asn1_cursor *cursor1,
  296. const struct asn1_cursor *cursor2 );
  297. extern int asn1_algorithm ( const struct asn1_cursor *cursor,
  298. struct asn1_algorithm **algorithm );
  299. extern int asn1_pubkey_algorithm ( const struct asn1_cursor *cursor,
  300. struct asn1_algorithm **algorithm );
  301. extern int asn1_digest_algorithm ( const struct asn1_cursor *cursor,
  302. struct asn1_algorithm **algorithm );
  303. extern int asn1_signature_algorithm ( const struct asn1_cursor *cursor,
  304. struct asn1_algorithm **algorithm );
  305. extern int asn1_generalized_time ( const struct asn1_cursor *cursor,
  306. time_t *time );
  307. extern int asn1_prepend_raw ( struct asn1_builder *builder, const void *data,
  308. size_t len );
  309. extern int asn1_prepend ( struct asn1_builder *builder, unsigned int type,
  310. const void *data, size_t len );
  311. extern int asn1_wrap ( struct asn1_builder *builder, unsigned int type );
  312. #endif /* _IPXE_ASN1_H */