45 #define ASN1_MAX_LEN_LEN ( 1 + sizeof ( size_t ) ) 59 #define ASN1_BOOLEAN 0x01 62 #define ASN1_INTEGER 0x02 65 #define ASN1_BIT_STRING 0x03 68 #define ASN1_OCTET_STRING 0x04 71 #define ASN1_NULL 0x05 77 #define ASN1_ENUMERATED 0x0a 80 #define ASN1_UTF8_STRING 0x0c 83 #define ASN1_UTC_TIME 0x17 86 #define ASN1_GENERALIZED_TIME 0x18 89 #define ASN1_SEQUENCE 0x30 95 #define ASN1_IMPLICIT_TAG( number) ( 0x80 | (number) ) 98 #define ASN1_EXPLICIT_TAG( number) ( 0xa0 | (number) ) 104 #define ASN1_SHORT( tag, ... ) \ 105 (tag), VA_ARG_COUNT ( __VA_ARGS__ ), __VA_ARGS__ 108 #define ASN1_OID_INITIAL( first, second ) ( ( (first) * 40 ) + (second) ) 114 #define ASN1_OID_SINGLE( value ) ( (value) & 0x7f ) 120 #define ASN1_OID_DOUBLE( value ) \ 121 ( 0x80 | ( ( (value) >> 7 ) & 0x7f ) ), ASN1_OID_SINGLE ( (value) ) 127 #define ASN1_OID_TRIPLE( value ) \ 128 ( 0x80 | ( ( (value) >> 14 ) & 0x7f ) ), ASN1_OID_DOUBLE ( (value) ) 131 #define ASN1_OID_ECPUBLICKEY \ 132 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 133 ASN1_OID_DOUBLE ( 10045 ), ASN1_OID_SINGLE ( 2 ), \ 134 ASN1_OID_SINGLE ( 1 ) 137 #define ASN1_OID_PRIME256V1 \ 138 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 139 ASN1_OID_DOUBLE ( 10045 ), ASN1_OID_SINGLE ( 3 ), \ 140 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 7 ) 143 #define ASN1_OID_ECDSA_WITH_SHA224 \ 144 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 145 ASN1_OID_DOUBLE ( 10045 ), ASN1_OID_SINGLE ( 4 ), \ 146 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 1 ) 149 #define ASN1_OID_ECDSA_WITH_SHA256 \ 150 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 151 ASN1_OID_DOUBLE ( 10045 ), ASN1_OID_SINGLE ( 4 ), \ 152 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 2 ) 155 #define ASN1_OID_ECDSA_WITH_SHA384 \ 156 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 157 ASN1_OID_DOUBLE ( 10045 ), ASN1_OID_SINGLE ( 4 ), \ 158 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 3 ) 161 #define ASN1_OID_ECDSA_WITH_SHA512 \ 162 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 163 ASN1_OID_DOUBLE ( 10045 ), ASN1_OID_SINGLE ( 4 ), \ 164 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ) 167 #define ASN1_OID_RSAENCRYPTION \ 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 ( 1 ) 173 #define ASN1_OID_MD5WITHRSAENCRYPTION \ 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 ( 4 ) 179 #define ASN1_OID_SHA1WITHRSAENCRYPTION \ 180 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 181 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \ 182 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ) 185 #define ASN1_OID_SHA256WITHRSAENCRYPTION \ 186 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 187 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \ 188 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 11 ) 191 #define ASN1_OID_SHA384WITHRSAENCRYPTION \ 192 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 193 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \ 194 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 12 ) 197 #define ASN1_OID_SHA512WITHRSAENCRYPTION \ 198 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 199 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \ 200 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 13 ) 203 #define ASN1_OID_SHA224WITHRSAENCRYPTION \ 204 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 205 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \ 206 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 14 ) 209 #define ASN1_OID_MD4 \ 210 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 211 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 2 ), \ 212 ASN1_OID_SINGLE ( 4 ) 215 #define ASN1_OID_MD5 \ 216 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 217 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 2 ), \ 218 ASN1_OID_SINGLE ( 5 ) 221 #define ASN1_OID_SHA1 \ 222 ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 14 ), \ 223 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 2 ), \ 224 ASN1_OID_SINGLE ( 26 ) 227 #define ASN1_OID_X25519 \ 228 ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 101 ), \ 229 ASN1_OID_SINGLE ( 110 ) 232 #define ASN1_OID_SECP384R1 \ 233 ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_DOUBLE ( 132 ), \ 234 ASN1_OID_SINGLE ( 0 ), ASN1_OID_SINGLE ( 34 ) 237 #define ASN1_OID_AES128_CBC \ 238 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 239 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 240 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 241 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 2 ) 244 #define ASN1_OID_AES128_GCM \ 245 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 246 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 247 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 248 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 6 ) 251 #define ASN1_OID_AES192_CBC \ 252 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 253 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 254 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 255 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 22 ) 258 #define ASN1_OID_AES192_GCM \ 259 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 260 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 261 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 262 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 26 ) 265 #define ASN1_OID_AES256_CBC \ 266 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 267 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 268 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 269 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 42 ) 272 #define ASN1_OID_AES256_GCM \ 273 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 274 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 275 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 276 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 46 ) 279 #define ASN1_OID_SHA256 \ 280 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 281 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 282 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 283 ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 1 ) 286 #define ASN1_OID_SHA384 \ 287 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 288 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 289 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 290 ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 2 ) 293 #define ASN1_OID_SHA512 \ 294 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 295 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 296 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 297 ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 3 ) 300 #define ASN1_OID_SHA224 \ 301 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 302 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 303 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 304 ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 4 ) 307 #define ASN1_OID_SHA512_224 \ 308 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 309 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 310 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 311 ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 5 ) 314 #define ASN1_OID_SHA512_256 \ 315 ASN1_OID_INITIAL ( 2, 16 ), ASN1_OID_DOUBLE ( 840 ), \ 316 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 101 ), \ 317 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 4 ), \ 318 ASN1_OID_SINGLE ( 2 ), ASN1_OID_SINGLE ( 6 ) 321 #define ASN1_OID_COMMON_NAME \ 322 ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 4 ), \ 323 ASN1_OID_SINGLE ( 3 ) 326 #define ASN1_OID_KEYUSAGE \ 327 ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \ 328 ASN1_OID_SINGLE ( 15 ) 331 #define ASN1_OID_BASICCONSTRAINTS \ 332 ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \ 333 ASN1_OID_SINGLE ( 19 ) 336 #define ASN1_OID_EXTKEYUSAGE \ 337 ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \ 338 ASN1_OID_SINGLE ( 37 ) 341 #define ASN1_OID_CODESIGNING \ 342 ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \ 343 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \ 344 ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \ 345 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 3 ) 348 #define ASN1_OID_SIGNEDDATA \ 349 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 350 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \ 351 ASN1_OID_SINGLE ( 7 ), ASN1_OID_SINGLE ( 2 ) 354 #define ASN1_OID_ENVELOPEDDATA \ 355 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 356 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \ 357 ASN1_OID_SINGLE ( 7 ), ASN1_OID_SINGLE ( 3 ) 360 #define ASN1_OID_AUTHENVELOPEDDATA \ 361 ASN1_OID_INITIAL ( 1, 2 ), ASN1_OID_DOUBLE ( 840 ), \ 362 ASN1_OID_TRIPLE ( 113549 ), ASN1_OID_SINGLE ( 1 ), \ 363 ASN1_OID_SINGLE ( 9 ), ASN1_OID_SINGLE ( 16 ), \ 364 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 23 ) 367 #define ASN1_OID_AUTHORITYINFOACCESS \ 368 ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \ 369 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \ 370 ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \ 371 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 1 ) 374 #define ASN1_OID_OCSP \ 375 ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \ 376 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \ 377 ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \ 378 ASN1_OID_SINGLE ( 48 ), ASN1_OID_SINGLE ( 1 ) 381 #define ASN1_OID_OCSP_BASIC \ 382 ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \ 383 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \ 384 ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \ 385 ASN1_OID_SINGLE ( 48 ), ASN1_OID_SINGLE ( 1 ), \ 386 ASN1_OID_SINGLE ( 1 ) 389 #define ASN1_OID_OCSPSIGNING \ 390 ASN1_OID_INITIAL ( 1, 3 ), ASN1_OID_SINGLE ( 6 ), \ 391 ASN1_OID_SINGLE ( 1 ), ASN1_OID_SINGLE ( 5 ), \ 392 ASN1_OID_SINGLE ( 5 ), ASN1_OID_SINGLE ( 7 ), \ 393 ASN1_OID_SINGLE ( 3 ), ASN1_OID_SINGLE ( 9 ) 396 #define ASN1_OID_SUBJECTALTNAME \ 397 ASN1_OID_INITIAL ( 2, 5 ), ASN1_OID_SINGLE ( 29 ), \ 398 ASN1_OID_SINGLE ( 17 ) 401 #define ASN1_CURSOR( value ) { \ 403 .len = sizeof ( value ), \ 432 #define ASN1_ALGORITHMS __table ( struct asn1_algorithm, "asn1_algorithms" ) 435 #define __asn1_algorithm __table_entry ( ASN1_ALGORITHMS, 01 ) 548 const void *
data,
size_t len );
int asn1_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm, struct asn1_cursor *params)
Parse ASN.1 OID-identified algorithm.
An ASN.1 OID-identified algorithm.
struct cipher_algorithm * cipher
Cipher algorithm (if applicable)
uint8_t extra
Signature extra byte.
int asn1_digest_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm)
Parse ASN.1 OID-identified digest algorithm.
int asn1_generalized_time(const struct asn1_cursor *cursor, time_t *time)
Parse ASN.1 GeneralizedTime.
#define ASN1_END
ASN.1 end.
int asn1_boolean(const struct asn1_cursor *cursor)
Parse value of ASN.1 boolean.
int asn1_cipher_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm, struct asn1_cursor *params)
Parse ASN.1 OID-identified cipher algorithm.
uint32_t type
Operating system type.
const void * data
Start of data.
int asn1_skip(struct asn1_cursor *cursor, unsigned int type)
Skip ASN.1 object.
int asn1_curve_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm *wrapper, struct asn1_algorithm **algorithm)
Parse ASN.1 OID-identified elliptic curve algorithm.
int asn1_prepend_raw(struct asn1_builder *builder, const void *data, size_t len)
Prepend raw data to ASN.1 builder.
int asn1_enter(struct asn1_cursor *cursor, unsigned int type)
Enter ASN.1 object.
static unsigned int asn1_type(const struct asn1_cursor *cursor)
Extract ASN.1 type.
int asn1_shrink(struct asn1_cursor *cursor, unsigned int type)
Shrink ASN.1 cursor to fit object.
size_t len
Length of data.
int asn1_skip_if_exists(struct asn1_cursor *cursor, unsigned int type)
Skip ASN.1 object if present.
struct pubkey_algorithm * pubkey
Public-key algorithm (if applicable)
int asn1_shrink_any(struct asn1_cursor *cursor)
Shrink ASN.1 object of any type.
int asn1_prepend(struct asn1_builder *builder, unsigned int type, const void *data, size_t len)
Prepend data to ASN.1 builder.
#define container_of(ptr, type, field)
Get containing structure.
int asn1_pubkey_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm)
Parse ASN.1 OID-identified public-key algorithm.
pseudo_bit_t value[0x00020]
#define build_assert(condition)
Assert a condition at build time (after dead code elimination)
int asn1_parse_gcm(struct asn1_algorithm *algorithm, struct asn1_cursor *params)
#define ASN1_MAX_LEN_LEN
Maximum (viable) length of ASN.1 length.
int asn1_compare(const struct asn1_cursor *cursor1, const struct asn1_cursor *cursor2)
Compare two ASN.1 objects.
int asn1_wrap(struct asn1_builder *builder, unsigned int type)
Wrap ASN.1 builder.
int asn1_signature_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm)
Parse ASN.1 OID-identified signature algorithm.
static void asn1_invalidate_cursor(struct asn1_cursor *cursor)
Invalidate ASN.1 object cursor.
FILE_LICENCE(GPL2_OR_LATER_OR_UBDL)
int asn1_enter_bits(struct asn1_cursor *cursor, unsigned int *unused)
Enter ASN.1 bit string.
struct elliptic_curve * curve
Elliptic curve (if applicable)
struct asn1_cursor oid
Object identifier.
int asn1_enter_unsigned(struct asn1_cursor *cursor)
Enter ASN.1 unsigned integer.
int asn1_integer(const struct asn1_cursor *cursor, int *value)
Parse value of ASN.1 integer.
#define __asn1_algorithm
Declare an ASN.1 OID-identified algorithm.
int asn1_check_algorithm(const struct asn1_cursor *cursor, struct asn1_algorithm *expected, struct asn1_cursor *params)
Check ASN.1 OID-identified algorithm.
int asn1_skip_any(struct asn1_cursor *cursor)
Skip ASN.1 object of any type.
u16 algorithm
Authentication algorithm (Open System or Shared Key)
struct digest_algorithm * digest
Digest algorithm (if applicable)
int asn1_grow(struct asn1_builder *builder, size_t extra)
Grow ASN.1 builder.
A message digest algorithm.
uint8_t data[48]
Additional event data.
static struct asn1_cursor * asn1_built(struct asn1_builder *builder)
Get cursor for built object.
typeof(acpi_finder=acpi_find)
ACPI table finder.
int(* parse)(struct asn1_algorithm *algorithm, struct asn1_cursor *params)
Parse algorithm parameters (optional)
int asn1_parse_cbc(struct asn1_algorithm *algorithm, struct asn1_cursor *params)
Parse ASN.1 CBC cipher parameters.
int64_t time_t
Seconds since the Epoch.
size_t len
Length of data.
int asn1_enter_any(struct asn1_cursor *cursor)
Enter ASN.1 object of any type.