5 * Created on 11/16/2010
7 * Copyright (c) 2010,2011,2012,2015 Apple Inc. All rights reserved.
11 #ifndef _CORECRYPTO_CCASN1_H_
12 #define _CORECRYPTO_CCASN1_H_
14 #include <corecrypto/cc.h>
18 /* ASN.1 types for on the fly ASN.1 BER/DER encoding/decoding. Don't use
19 these with the ccder interface, use the CCDER_ types instead. */
22 CCASN1_BOOLEAN
= 0x01,
23 CCASN1_INTEGER
= 0x02,
24 CCASN1_BIT_STRING
= 0x03,
25 CCASN1_OCTET_STRING
= 0x04,
27 CCASN1_OBJECT_IDENTIFIER
= 0x06,
28 CCASN1_OBJECT_DESCRIPTOR
= 0x07,
29 /* External or instance-of 0x08 */
31 CCASN1_ENUMERATED
= 0x0a,
32 CCASN1_EMBEDDED_PDV
= 0x0b,
33 CCASN1_UTF8_STRING
= 0x0c,
37 CCASN1_SEQUENCE
= 0x10,
39 CCASN1_NUMERIC_STRING
= 0x12,
40 CCASN1_PRINTABLE_STRING
= 0x13,
41 CCASN1_T61_STRING
= 0x14,
42 CCASN1_VIDEOTEX_STRING
= 0x15,
43 CCASN1_IA5_STRING
= 0x16,
44 CCASN1_UTC_TIME
= 0x17,
45 CCASN1_GENERALIZED_TIME
= 0x18,
46 CCASN1_GRAPHIC_STRING
= 0x19,
47 CCASN1_VISIBLE_STRING
= 0x1a,
48 CCASN1_GENERAL_STRING
= 0x1b,
49 CCASN1_UNIVERSAL_STRING
= 0x1c,
51 CCASN1_BMP_STRING
= 0x1e,
52 CCASN1_HIGH_TAG_NUMBER
= 0x1f,
53 CCASN1_TELETEX_STRING
= CCASN1_T61_STRING
,
55 CCASN1_TAG_MASK
= 0xff,
56 CCASN1_TAGNUM_MASK
= 0x1f,
58 CCASN1_METHOD_MASK
= 0x20,
59 CCASN1_PRIMITIVE
= 0x00,
60 CCASN1_CONSTRUCTED
= 0x20,
62 CCASN1_CLASS_MASK
= 0xc0,
63 CCASN1_UNIVERSAL
= 0x00,
64 CCASN1_APPLICATION
= 0x40,
65 CCASN1_CONTEXT_SPECIFIC
= 0x80,
66 CCASN1_PRIVATE
= 0xc0,
68 CCASN1_CONSTRUCTED_SET
= CCASN1_SET
| CCASN1_CONSTRUCTED
,
69 CCASN1_CONSTRUCTED_SEQUENCE
= CCASN1_SEQUENCE
| CCASN1_CONSTRUCTED
,
72 #if CORECRYPTO_USE_TRANSPARENT_UNION
74 const unsigned char * oid
;
75 } __attribute__((transparent_union
)) ccoid_t
;
76 #define CCOID(x) ((x).oid)
78 typedef const unsigned char * ccoid_t
;
79 #define CCOID(oid) (oid)
82 /* Returns *der iff *der points to a DER encoded oid that fits within *der_len. */
83 ccoid_t
ccoid_for_der(size_t *der_len
, const uint8_t **der
);
85 /* Returns the size of an oid including it's tag and length. */
86 CC_INLINE CC_PURE
CC_NONNULL_TU((1))
87 size_t ccoid_size(ccoid_t oid
) {
88 return 2 + CCOID(oid
)[1];
91 CC_INLINE CC_PURE
CC_NONNULL((1)) CC_NONNULL((2))
92 bool ccoid_equal(ccoid_t oid1
, ccoid_t oid2
) {
93 return (ccoid_size(oid1
) == ccoid_size(oid2
)
94 && memcmp(CCOID(oid1
), CCOID(oid2
), ccoid_size(oid1
))== 0);
97 #endif /* _CORECRYPTO_CCASN1_H_ */