iPXE
|
ASN.1 encoding. More...
#include <stddef.h>
#include <stdint.h>
#include <stdarg.h>
#include <assert.h>
#include <time.h>
#include <ipxe/tables.h>
Go to the source code of this file.
Data Structures | |
struct | asn1_cursor |
An ASN.1 object cursor. More... | |
struct | asn1_builder |
An ASN.1 object builder. More... | |
struct | asn1_builder_header |
An ASN.1 header. More... | |
struct | asn1_algorithm |
An ASN.1 OID-identified algorithm. More... | |
struct | asn1_bit_string |
An ASN.1 bit string. More... | |
Macros | |
#define | ASN1_MAX_LEN_LEN ( 1 + sizeof ( size_t ) ) |
Maximum (viable) length of ASN.1 length. More... | |
#define | ASN1_END 0x00 |
ASN.1 end. More... | |
#define | ASN1_BOOLEAN 0x01 |
ASN.1 boolean. More... | |
#define | ASN1_INTEGER 0x02 |
ASN.1 integer. More... | |
#define | ASN1_BIT_STRING 0x03 |
ASN.1 bit string. More... | |
#define | ASN1_OCTET_STRING 0x04 |
ASN.1 octet string. More... | |
#define | ASN1_NULL 0x05 |
ASN.1 null. More... | |
#define | ASN1_OID 0x06 |
ASN.1 object identifier. More... | |
#define | ASN1_ENUMERATED 0x0a |
ASN.1 enumeration. More... | |
#define | ASN1_UTF8_STRING 0x0c |
ASN.1 UTF-8 string. More... | |
#define | ASN1_UTC_TIME 0x17 |
ASN.1 UTC time. More... | |
#define | ASN1_GENERALIZED_TIME 0x18 |
ASN.1 generalized time. More... | |
#define | ASN1_SEQUENCE 0x30 |
ASN.1 sequence. More... | |
#define | ASN1_SET 0x31 |
ASN.1 set. More... | |
#define | ASN1_IMPLICIT_TAG(number) ( 0x80 | (number) ) |
ASN.1 implicit tag. More... | |
#define | ASN1_EXPLICIT_TAG(number) ( 0xa0 | (number) ) |
ASN.1 explicit tag. More... | |
#define | ASN1_ANY -1U |
ASN.1 "any tag" magic value. More... | |
#define | ASN1_SHORT(tag, ...) (tag), VA_ARG_COUNT ( __VA_ARGS__ ), __VA_ARGS__ |
Construct a short ASN.1 value. More... | |
#define | ASN1_OID_INITIAL(first, second) ( ( (first) * 40 ) + (second) ) |
Initial OID byte. More... | |
#define | ASN1_OID_SINGLE(value) ( (value) & 0x7f ) |
Single-byte OID value. More... | |
#define | ASN1_OID_DOUBLE(value) ( 0x80 | ( ( (value) >> 7 ) & 0x7f ) ), ASN1_OID_SINGLE ( (value) ) |
Double-byte OID value. More... | |
#define | ASN1_OID_TRIPLE(value) ( 0x80 | ( ( (value) >> 14 ) & 0x7f ) ), ASN1_OID_DOUBLE ( (value) ) |
Double-byte OID value. More... | |
#define | ASN1_OID_RSAENCRYPTION |
ASN.1 OID for rsaEncryption (1.2.840.113549.1.1.1) More... | |
#define | ASN1_OID_MD5WITHRSAENCRYPTION |
ASN.1 OID for md5WithRSAEncryption (1.2.840.113549.1.1.4) More... | |
#define | ASN1_OID_SHA1WITHRSAENCRYPTION |
ASN.1 OID for sha1WithRSAEncryption (1.2.840.113549.1.1.5) More... | |
#define | ASN1_OID_SHA256WITHRSAENCRYPTION |
ASN.1 OID for sha256WithRSAEncryption (1.2.840.113549.1.1.11) More... | |
#define | ASN1_OID_SHA384WITHRSAENCRYPTION |
ASN.1 OID for sha384WithRSAEncryption (1.2.840.113549.1.1.12) More... | |
#define | ASN1_OID_SHA512WITHRSAENCRYPTION |
ASN.1 OID for sha512WithRSAEncryption (1.2.840.113549.1.1.13) More... | |
#define | ASN1_OID_SHA224WITHRSAENCRYPTION |
ASN.1 OID for sha224WithRSAEncryption (1.2.840.113549.1.1.14) More... | |
#define | ASN1_OID_MD4 |
ASN.1 OID for id-md4 (1.2.840.113549.2.4) More... | |
#define | ASN1_OID_MD5 |
ASN.1 OID for id-md5 (1.2.840.113549.2.5) More... | |
#define | ASN1_OID_SHA1 |
ASN.1 OID for id-sha1 (1.3.14.3.2.26) More... | |
#define | ASN1_OID_SHA256 |
ASN.1 OID for id-sha256 (2.16.840.1.101.3.4.2.1) More... | |
#define | ASN1_OID_SHA384 |
ASN.1 OID for id-sha384 (2.16.840.1.101.3.4.2.2) More... | |
#define | ASN1_OID_SHA512 |
ASN.1 OID for id-sha512 (2.16.840.1.101.3.4.2.3) More... | |
#define | ASN1_OID_SHA224 |
ASN.1 OID for id-sha224 (2.16.840.1.101.3.4.2.4) More... | |
#define | ASN1_OID_SHA512_224 |
ASN.1 OID for id-sha512-224 (2.16.840.1.101.3.4.2.5) More... | |
#define | ASN1_OID_SHA512_256 |
ASN.1 OID for id-sha512-256 (2.16.840.1.101.3.4.2.6) More... | |
#define | ASN1_OID_COMMON_NAME |
ASN.1 OID for commonName (2.5.4.3) More... | |
#define | ASN1_OID_KEYUSAGE |
ASN.1 OID for id-ce-keyUsage (2.5.29.15) More... | |
#define | ASN1_OID_BASICCONSTRAINTS |
ASN.1 OID for id-ce-basicConstraints (2.5.29.19) More... | |
#define | ASN1_OID_EXTKEYUSAGE |
ASN.1 OID for id-ce-extKeyUsage (2.5.29.37) More... | |
#define | ASN1_OID_CODESIGNING |
ASN.1 OID for id-kp-codeSigning (1.3.6.1.5.5.7.3.3) More... | |
#define | ASN1_OID_SIGNEDDATA |
ASN.1 OID for pkcs-signedData (1.2.840.113549.1.7.2) More... | |
#define | ASN1_OID_AUTHORITYINFOACCESS |
ASN.1 OID for id-pe-authorityInfoAccess (1.3.6.1.5.5.7.1.1) More... | |
#define | ASN1_OID_OCSP |
ASN.1 OID for id-ad-ocsp (1.3.6.1.5.5.7.48.1) More... | |
#define | ASN1_OID_OCSP_BASIC |
ASN.1 OID for id-pkix-ocsp-basic ( 1.3.6.1.5.5.7.48.1.1) More... | |
#define | ASN1_OID_OCSPSIGNING |
ASN.1 OID for id-kp-OCSPSigning (1.3.6.1.5.5.7.3.9) More... | |
#define | ASN1_OID_SUBJECTALTNAME |
ASN.1 OID for id-ce-subjectAltName (2.5.29.17) More... | |
#define | ASN1_CURSOR(value) |
Define an ASN.1 cursor for a static value. More... | |
#define | ASN1_ALGORITHMS __table ( struct asn1_algorithm, "asn1_algorithms" ) |
ASN.1 OID-identified algorithms. More... | |
#define | __asn1_algorithm __table_entry ( ASN1_ALGORITHMS, 01 ) |
Declare an ASN.1 OID-identified algorithm. More... | |
Functions | |
FILE_LICENCE (GPL2_OR_LATER_OR_UBDL) | |
static void | asn1_invalidate_cursor (struct asn1_cursor *cursor) |
Invalidate ASN.1 object cursor. More... | |
static unsigned int | asn1_type (const struct asn1_cursor *cursor) |
Extract ASN.1 type. More... | |
static struct asn1_cursor * | asn1_built (struct asn1_builder *builder) |
Get cursor for built object. More... | |
int | asn1_start (struct asn1_cursor *cursor, unsigned int type, size_t extra) |
Start parsing ASN.1 object. More... | |
int | asn1_enter (struct asn1_cursor *cursor, unsigned int type) |
Enter ASN.1 object. More... | |
int | asn1_skip_if_exists (struct asn1_cursor *cursor, unsigned int type) |
Skip ASN.1 object if present. More... | |
int | asn1_skip (struct asn1_cursor *cursor, unsigned int type) |
Skip ASN.1 object. More... | |
int | asn1_shrink (struct asn1_cursor *cursor, unsigned int type) |
Shrink ASN.1 cursor to fit object. More... | |
int | asn1_enter_any (struct asn1_cursor *cursor) |
Enter ASN.1 object of any type. More... | |
int | asn1_skip_any (struct asn1_cursor *cursor) |
Skip ASN.1 object of any type. More... | |
int | asn1_shrink_any (struct asn1_cursor *cursor) |
Shrink ASN.1 object of any type. More... | |
int | asn1_boolean (const struct asn1_cursor *cursor) |
Parse value of ASN.1 boolean. More... | |
int | asn1_integer (const struct asn1_cursor *cursor, int *value) |
Parse value of ASN.1 integer. More... | |
int | asn1_bit_string (const struct asn1_cursor *cursor, struct asn1_bit_string *bits) |
Parse ASN.1 bit string. More... | |
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. More... | |
int | asn1_compare (const struct asn1_cursor *cursor1, const struct asn1_cursor *cursor2) |
Compare two ASN.1 objects. More... | |
int | asn1_algorithm (const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm) |
Parse ASN.1 OID-identified algorithm. More... | |
int | asn1_pubkey_algorithm (const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm) |
Parse ASN.1 OID-identified public-key algorithm. More... | |
int | asn1_digest_algorithm (const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm) |
Parse ASN.1 OID-identified digest algorithm. More... | |
int | asn1_signature_algorithm (const struct asn1_cursor *cursor, struct asn1_algorithm **algorithm) |
Parse ASN.1 OID-identified signature algorithm. More... | |
int | asn1_check_algorithm (const struct asn1_cursor *cursor, struct asn1_algorithm *expected) |
Check ASN.1 OID-identified algorithm. More... | |
int | asn1_generalized_time (const struct asn1_cursor *cursor, time_t *time) |
Parse ASN.1 GeneralizedTime. More... | |
int | asn1_grow (struct asn1_builder *builder, size_t extra) |
Grow ASN.1 builder. More... | |
int | asn1_prepend_raw (struct asn1_builder *builder, const void *data, size_t len) |
Prepend raw data to ASN.1 builder. More... | |
int | asn1_prepend (struct asn1_builder *builder, unsigned int type, const void *data, size_t len) |
Prepend data to ASN.1 builder. More... | |
int | asn1_wrap (struct asn1_builder *builder, unsigned int type) |
Wrap ASN.1 builder. More... | |
Variables | |
struct asn1_algorithm rsa_encryption_algorithm | __asn1_algorithm |
"md4" OID-identified algorithm More... | |
ASN.1 encoding.
Definition in file asn1.h.
#define ASN1_MAX_LEN_LEN ( 1 + sizeof ( size_t ) ) |
#define ASN1_IMPLICIT_TAG | ( | number | ) | ( 0x80 | (number) ) |
#define ASN1_EXPLICIT_TAG | ( | number | ) | ( 0xa0 | (number) ) |
#define ASN1_SHORT | ( | tag, | |
... | |||
) | (tag), VA_ARG_COUNT ( __VA_ARGS__ ), __VA_ARGS__ |
#define ASN1_OID_DOUBLE | ( | value | ) | ( 0x80 | ( ( (value) >> 7 ) & 0x7f ) ), ASN1_OID_SINGLE ( (value) ) |
#define ASN1_OID_TRIPLE | ( | value | ) | ( 0x80 | ( ( (value) >> 14 ) & 0x7f ) ), ASN1_OID_DOUBLE ( (value) ) |
#define ASN1_OID_RSAENCRYPTION |
ASN.1 OID for rsaEncryption (1.2.840.113549.1.1.1)
#define ASN1_OID_MD5WITHRSAENCRYPTION |
ASN.1 OID for md5WithRSAEncryption (1.2.840.113549.1.1.4)
#define ASN1_OID_SHA1WITHRSAENCRYPTION |
ASN.1 OID for sha1WithRSAEncryption (1.2.840.113549.1.1.5)
#define ASN1_OID_SHA256WITHRSAENCRYPTION |
ASN.1 OID for sha256WithRSAEncryption (1.2.840.113549.1.1.11)
#define ASN1_OID_SHA384WITHRSAENCRYPTION |
ASN.1 OID for sha384WithRSAEncryption (1.2.840.113549.1.1.12)
#define ASN1_OID_SHA512WITHRSAENCRYPTION |
ASN.1 OID for sha512WithRSAEncryption (1.2.840.113549.1.1.13)
#define ASN1_OID_SHA224WITHRSAENCRYPTION |
ASN.1 OID for sha224WithRSAEncryption (1.2.840.113549.1.1.14)
#define ASN1_OID_MD4 |
ASN.1 OID for id-md4 (1.2.840.113549.2.4)
#define ASN1_OID_MD5 |
ASN.1 OID for id-md5 (1.2.840.113549.2.5)
#define ASN1_OID_SHA1 |
ASN.1 OID for id-sha1 (1.3.14.3.2.26)
#define ASN1_OID_SHA256 |
ASN.1 OID for id-sha256 (2.16.840.1.101.3.4.2.1)
#define ASN1_OID_SHA384 |
ASN.1 OID for id-sha384 (2.16.840.1.101.3.4.2.2)
#define ASN1_OID_SHA512 |
ASN.1 OID for id-sha512 (2.16.840.1.101.3.4.2.3)
#define ASN1_OID_SHA224 |
ASN.1 OID for id-sha224 (2.16.840.1.101.3.4.2.4)
#define ASN1_OID_SHA512_224 |
ASN.1 OID for id-sha512-224 (2.16.840.1.101.3.4.2.5)
#define ASN1_OID_SHA512_256 |
ASN.1 OID for id-sha512-256 (2.16.840.1.101.3.4.2.6)
#define ASN1_OID_COMMON_NAME |
ASN.1 OID for commonName (2.5.4.3)
#define ASN1_OID_KEYUSAGE |
ASN.1 OID for id-ce-keyUsage (2.5.29.15)
#define ASN1_OID_BASICCONSTRAINTS |
ASN.1 OID for id-ce-basicConstraints (2.5.29.19)
#define ASN1_OID_EXTKEYUSAGE |
ASN.1 OID for id-ce-extKeyUsage (2.5.29.37)
#define ASN1_OID_CODESIGNING |
ASN.1 OID for id-kp-codeSigning (1.3.6.1.5.5.7.3.3)
#define ASN1_OID_SIGNEDDATA |
ASN.1 OID for pkcs-signedData (1.2.840.113549.1.7.2)
#define ASN1_OID_AUTHORITYINFOACCESS |
ASN.1 OID for id-pe-authorityInfoAccess (1.3.6.1.5.5.7.1.1)
#define ASN1_OID_OCSP |
ASN.1 OID for id-ad-ocsp (1.3.6.1.5.5.7.48.1)
#define ASN1_OID_OCSP_BASIC |
ASN.1 OID for id-pkix-ocsp-basic ( 1.3.6.1.5.5.7.48.1.1)
#define ASN1_OID_OCSPSIGNING |
ASN.1 OID for id-kp-OCSPSigning (1.3.6.1.5.5.7.3.9)
#define ASN1_OID_SUBJECTALTNAME |
ASN.1 OID for id-ce-subjectAltName (2.5.29.17)
#define ASN1_CURSOR | ( | value | ) |
#define ASN1_ALGORITHMS __table ( struct asn1_algorithm, "asn1_algorithms" ) |
struct asn1_algorithm oid_sha512_256_algorithm __asn1_algorithm __table_entry ( ASN1_ALGORITHMS, 01 ) |
FILE_LICENCE | ( | GPL2_OR_LATER_OR_UBDL | ) |
|
inlinestatic |
Invalidate ASN.1 object cursor.
cursor | ASN.1 object cursor |
Definition at line 362 of file asn1.h.
References asn1_cursor::len.
Referenced by asn1_enter(), asn1_shrink(), and asn1_skip().
|
inlinestatic |
Extract ASN.1 type.
cursor | ASN.1 object cursor |
type | Type, or ASN1_END if cursor is invalid |
Definition at line 373 of file asn1.h.
References ASN1_END, asn1_cursor::data, asn1_cursor::len, and type.
Referenced by asn1_generalized_time(), asn1_start(), ocsp_parse_basic_response(), ocsp_parse_responder_id(), ocsp_parse_responses(), rsa_parse_mod_exp(), x509_check_alt_name(), x509_parse_basic_constraints(), x509_parse_extension(), and x509_parse_tbscertificate().
|
inlinestatic |
Get cursor for built object.
builder | ASN.1 object builder |
cursor | ASN.1 object cursor |
Definition at line 386 of file asn1.h.
References container_of, linker_assert, typeof(), and u.
Referenced by icert_certs(), and privkey_cursor().
int asn1_start | ( | struct asn1_cursor * | cursor, |
unsigned int | type, | ||
size_t | extra | ||
) |
Start parsing ASN.1 object.
cursor | ASN.1 object cursor |
type | Expected type, or ASN1_ANY |
extra | Additional length not present within partial cursor |
len | Length of object body, or negative error |
The object cursor will be updated to point to the start of the object body (i.e. the first byte following the length byte(s)), and the length of the object body (i.e. the number of bytes until the following object tag, if any) is returned.
Definition at line 98 of file asn1.c.
References ASN1_ANY, asn1_type(), asn1_cursor::data, DBGC, EINVAL_ASN1_EMPTY, EINVAL_ASN1_LEN, EINVAL_ASN1_LEN_LEN, ENXIO, extra, len, asn1_cursor::len, and type.
Referenced by asn1_enter(), asn1_shrink(), asn1_skip_if_exists(), and der_probe().
int asn1_enter | ( | struct asn1_cursor * | cursor, |
unsigned int | type | ||
) |
Enter ASN.1 object.
cursor | ASN.1 object cursor |
type | Expected type, or ASN1_ANY |
rc | Return status code |
The object cursor will be updated to point to the body of the current ASN.1 object. If any error occurs, the object cursor will be invalidated.
Definition at line 160 of file asn1.c.
References asn1_invalidate_cursor(), asn1_start(), DBGC, len, asn1_cursor::len, and type.
Referenced by asn1_algorithm(), asn1_bit_string(), asn1_boolean(), asn1_enter_any(), asn1_generalized_time(), asn1_integer(), cms_parse(), cms_parse_certificates(), cms_parse_content_type(), cms_parse_signature_value(), cms_parse_signer_identifier(), cms_parse_signer_info(), ocsp_compare_responder_key_hash(), ocsp_parse_basic_response(), ocsp_parse_cert_id(), ocsp_parse_certs(), ocsp_parse_response(), ocsp_parse_response_bytes(), ocsp_parse_response_status(), ocsp_parse_response_type(), ocsp_parse_responses(), ocsp_parse_tbs_response_data(), ocsp_request(), rsa_parse_integer(), rsa_parse_mod_exp(), validator_append(), x509_parse(), x509_parse_access_description(), x509_parse_authority_info_access(), x509_parse_basic_constraints(), x509_parse_common_name(), x509_parse_extended_key_usage(), x509_parse_extension(), x509_parse_extensions(), x509_parse_key_purpose(), x509_parse_ocsp(), x509_parse_public_key(), x509_parse_subject_alt_name(), x509_parse_tbscertificate(), x509_parse_validity(), and x509_parse_version().
int asn1_skip_if_exists | ( | struct asn1_cursor * | cursor, |
unsigned int | type | ||
) |
Skip ASN.1 object if present.
cursor | ASN.1 object cursor |
type | Expected type, or ASN1_ANY |
rc | Return status code |
The object cursor will be updated to point to the next ASN.1 object. If any error occurs, the object cursor will not be modified.
Definition at line 187 of file asn1.c.
References asn1_start(), asn1_cursor::data, DBGC, ENOENT, len, asn1_cursor::len, and type.
Referenced by asn1_skip(), cms_parse(), cms_parse_signer_info(), and ocsp_parse_tbs_response_data().
int asn1_skip | ( | struct asn1_cursor * | cursor, |
unsigned int | type | ||
) |
Skip ASN.1 object.
cursor | ASN.1 object cursor |
type | Expected type, or ASN1_ANY |
rc | Return status code |
The object cursor will be updated to point to the next ASN.1 object. If any error occurs, the object cursor will be invalidated.
Definition at line 218 of file asn1.c.
References asn1_invalidate_cursor(), asn1_skip_if_exists(), rc, and type.
Referenced by asn1_skip_any(), cms_parse(), cms_parse_signer_info(), ocsp_parse_cert_id(), ocsp_request(), and rsa_parse_mod_exp().
int asn1_shrink | ( | struct asn1_cursor * | cursor, |
unsigned int | type | ||
) |
Shrink ASN.1 cursor to fit object.
cursor | ASN.1 object cursor |
type | Expected type, or ASN1_ANY |
rc | Return status code |
The object cursor will be shrunk to contain only the current ASN.1 object. If any error occurs, the object cursor will be invalidated.
Definition at line 240 of file asn1.c.
References asn1_invalidate_cursor(), asn1_start(), asn1_cursor::data, end, len, asn1_cursor::len, memcpy(), and type.
Referenced by asn1_shrink_any(), cms_parse_signer_identifier(), ocsp_parse_cert_id(), x509_parse_issuer(), and x509_parse_serial().
int asn1_enter_any | ( | struct asn1_cursor * | cursor | ) |
Enter ASN.1 object of any type.
cursor | ASN.1 object cursor |
rc | Return status code |
Definition at line 266 of file asn1.c.
References ASN1_ANY, and asn1_enter().
Referenced by ocsp_parse_responder_id(), x509_check_alt_name(), and x509_parse_common_name().
int asn1_skip_any | ( | struct asn1_cursor * | cursor | ) |
Skip ASN.1 object of any type.
cursor | ASN.1 object cursor |
rc | Return status code |
Definition at line 276 of file asn1.c.
References ASN1_ANY, and asn1_skip().
Referenced by cms_parse(), cms_parse_certificates(), cms_parse_signer_identifier(), cms_parse_signer_info(), ocsp_parse_basic_response(), ocsp_parse_certs(), ocsp_parse_response(), ocsp_parse_response_bytes(), ocsp_parse_responses(), ocsp_parse_tbs_response_data(), rsa_parse_mod_exp(), validator_append(), x509_check_name(), x509_parse(), x509_parse_access_description(), x509_parse_authority_info_access(), x509_parse_basic_constraints(), x509_parse_common_name(), x509_parse_extended_key_usage(), x509_parse_extension(), x509_parse_extensions(), x509_parse_public_key(), x509_parse_tbscertificate(), and x509_parse_validity().
int asn1_shrink_any | ( | struct asn1_cursor * | cursor | ) |
Shrink ASN.1 object of any type.
cursor | ASN.1 object cursor |
rc | Return status code |
Definition at line 286 of file asn1.c.
References ASN1_ANY, and asn1_shrink().
Referenced by cms_signature(), ocsp_parse_tbs_response_data(), x509_certificate(), x509_parse_public_key(), x509_parse_subject(), and x509_parse_tbscertificate().
int asn1_boolean | ( | const struct asn1_cursor * | cursor | ) |
Parse value of ASN.1 boolean.
cursor | ASN.1 object cursor |
value | Value, or negative error |
Definition at line 296 of file asn1.c.
References __attribute__, ASN1_BOOLEAN, asn1_enter(), asn1_cursor::data, EINVAL_ASN1_BOOLEAN, asn1_cursor::len, memcpy(), and value.
Referenced by x509_parse_basic_constraints(), and x509_parse_extension().
int asn1_integer | ( | const struct asn1_cursor * | cursor, |
int * | value | ||
) |
Parse value of ASN.1 integer.
cursor | ASN.1 object cursor |
value | Value to fill in |
rc | Return status code |
Definition at line 320 of file asn1.c.
References asn1_enter(), ASN1_INTEGER, asn1_cursor::data, DBGC, EINVAL_ASN1_INTEGER, asn1_cursor::len, memcpy(), rc, and value.
Referenced by x509_parse_basic_constraints(), and x509_parse_version().
int asn1_bit_string | ( | const struct asn1_cursor * | cursor, |
struct asn1_bit_string * | bits | ||
) |
Parse ASN.1 bit string.
cursor | ASN.1 cursor |
bits | Bit string to fill in |
rc | Return status code |
Definition at line 359 of file asn1.c.
References __attribute__, ASN1_BIT_STRING, asn1_enter(), bits, data, asn1_cursor::data, DBGC, DBGC_HDA, EINVAL_BIT_STRING, last, len, asn1_cursor::len, memcpy(), offsetof, rc, typeof(), and unused.
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.
cursor | ASN.1 cursor |
bits | Bit string to fill in |
rc | Return status code |
Definition at line 414 of file asn1.c.
References bits, asn1_cursor::data, DBGC, DBGC_HDA, EINVAL_BIT_STRING, asn1_cursor::len, and rc.
Referenced by ocsp_parse_basic_response(), rsa_parse_mod_exp(), and x509_parse().
int asn1_compare | ( | const struct asn1_cursor * | cursor1, |
const struct asn1_cursor * | cursor2 | ||
) |
Compare two ASN.1 objects.
cursor1 | ASN.1 object cursor |
cursor2 | ASN.1 object cursor |
difference | Difference as returned by memcmp() |
Note that invalid and empty cursors will compare as equal with each other.
Definition at line 443 of file asn1.c.
References asn1_cursor::data, asn1_cursor::len, and memcmp().
Referenced by asn1_find_algorithm(), certstore_find(), cms_find_issuer_serial(), cms_parse_content_type(), ocsp_compare_responder_name(), ocsp_parse_cert_id(), ocsp_parse_response_type(), rsa_match(), validator_step(), x509_check_issuer(), x509_find_access_method(), x509_find_extension(), x509_find_subject(), x509_parse_common_name(), and x509_parse_key_purpose().
int asn1_algorithm | ( | const struct asn1_cursor * | cursor, |
struct asn1_algorithm ** | algorithm | ||
) |
Parse ASN.1 OID-identified algorithm.
cursor | ASN.1 object cursor |
algorithm | Algorithm |
rc | Return status code |
Definition at line 478 of file asn1.c.
References algorithm, asn1_enter(), asn1_find_algorithm(), ASN1_OID, ASN1_SEQUENCE, asn1_cursor::data, DBGC, DBGC_HDA, EINVAL_ASN1_ALGORITHM, ENOTSUP_ALGORITHM, asn1_cursor::len, memcpy(), and rc.
int asn1_pubkey_algorithm | ( | const struct asn1_cursor * | cursor, |
struct asn1_algorithm ** | algorithm | ||
) |
Parse ASN.1 OID-identified public-key algorithm.
cursor | ASN.1 object cursor |
algorithm | Algorithm |
rc | Return status code |
Definition at line 513 of file asn1.c.
References algorithm, asn1_cursor::data, DBGC, DBGC_HDA, ENOTTY_ALGORITHM, asn1_cursor::len, and rc.
Referenced by cms_parse_signature_algorithm(), and x509_parse_public_key().
int asn1_digest_algorithm | ( | const struct asn1_cursor * | cursor, |
struct asn1_algorithm ** | algorithm | ||
) |
Parse ASN.1 OID-identified digest algorithm.
cursor | ASN.1 object cursor |
algorithm | Algorithm |
rc | Return status code |
Definition at line 539 of file asn1.c.
References algorithm, asn1_cursor::data, DBGC, DBGC_HDA, ENOTTY_ALGORITHM, asn1_cursor::len, and rc.
Referenced by cms_parse_digest_algorithm().
int asn1_signature_algorithm | ( | const struct asn1_cursor * | cursor, |
struct asn1_algorithm ** | algorithm | ||
) |
Parse ASN.1 OID-identified signature algorithm.
cursor | ASN.1 object cursor |
algorithm | Algorithm |
rc | Return status code |
Definition at line 565 of file asn1.c.
References algorithm, asn1_cursor::data, DBGC, DBGC_HDA, ENOTTY_ALGORITHM, asn1_cursor::len, and rc.
Referenced by ocsp_parse_basic_response(), x509_parse(), and x509_parse_tbscertificate().
int asn1_check_algorithm | ( | const struct asn1_cursor * | cursor, |
struct asn1_algorithm * | expected | ||
) |
Check ASN.1 OID-identified algorithm.
cursor | ASN.1 object cursor |
expected | Expected algorithm |
rc | Return status code |
Definition at line 599 of file asn1.c.
References DBGC, ENOTTY_ALGORITHM, asn1_algorithm::name, and rc.
Referenced by rsa_parse_mod_exp().
int asn1_generalized_time | ( | const struct asn1_cursor * | cursor, |
time_t * | time | ||
) |
Parse ASN.1 GeneralizedTime.
cursor | ASN.1 cursor |
time | Time to fill in |
rc | Return status code |
RFC 5280 section 4.1.2.5 places several restrictions on the allowed formats for UTCTime and GeneralizedTime, and mandates the interpretation of centuryless year values.
Definition at line 629 of file asn1.c.
References __attribute__, asn1_enter(), ASN1_GENERALIZED_TIME, asn1_type(), ASN1_UTC_TIME, data, asn1_cursor::data, DBGC, DBGC_HDA, EINVAL_ASN1_TIME, isdigit(), asn1_cursor::len, memcpy(), memset(), mktime(), raw, rc, second, time, tm::tm_hour, tm::tm_mday, tm::tm_min, tm::tm_mon, tm::tm_sec, tm::tm_year, and type.
Referenced by ocsp_parse_responses(), and x509_parse_validity().
int asn1_grow | ( | struct asn1_builder * | builder, |
size_t | extra | ||
) |
Grow ASN.1 builder.
builder | ASN.1 builder |
extra | Extra space to prepend |
rc | Return status code |
Definition at line 768 of file asn1.c.
References asn1_builder::data, ENOMEM, extra, free, asn1_builder::len, memmove(), NULL, and realloc().
Referenced by asn1_prepend(), asn1_prepend_raw(), asn1_wrap(), and icert_cert().
int asn1_prepend_raw | ( | struct asn1_builder * | builder, |
const void * | data, | ||
size_t | len | ||
) |
Prepend raw data to ASN.1 builder.
builder | ASN.1 builder |
data | Data to prepend |
len | Length of data to prepend |
rc | Return status code |
Definition at line 801 of file asn1.c.
References asn1_grow(), data, asn1_builder::data, len, memcpy(), and rc.
Referenced by icert_cert(), icert_certs(), and ocsp_request().
int asn1_prepend | ( | struct asn1_builder * | builder, |
unsigned int | type, | ||
const void * | data, | ||
size_t | len | ||
) |
Prepend data to ASN.1 builder.
builder | ASN.1 builder |
type | Type |
data | Data to prepend |
len | Length of data to prepend |
rc | Return status code |
Definition at line 824 of file asn1.c.
References asn1_grow(), asn1_header(), data, asn1_builder::data, header, len, memcpy(), rc, and type.
Referenced by icert_certs(), and ocsp_request().
int asn1_wrap | ( | struct asn1_builder * | builder, |
unsigned int | type | ||
) |
Wrap ASN.1 builder.
builder | ASN.1 builder |
type | Type |
rc | Return status code |
Definition at line 851 of file asn1.c.
References asn1_grow(), asn1_header(), asn1_builder::data, header, asn1_builder::len, memcpy(), rc, and type.
Referenced by icert_cert(), icert_certs(), and ocsp_request().
struct asn1_algorithm oid_sha512_256_algorithm __asn1_algorithm |