iPXE
|
ASN.1 encoding. More...
#include <stdint.h>
#include <stddef.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <errno.h>
#include <time.h>
#include <ipxe/tables.h>
#include <ipxe/image.h>
#include <ipxe/asn1.h>
Go to the source code of this file.
Functions | |
FILE_LICENCE (GPL2_OR_LATER_OR_UBDL) | |
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... | |
static struct asn1_algorithm * | asn1_find_algorithm (const struct asn1_cursor *cursor) |
Identify ASN.1 algorithm by OID. 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... | |
static size_t | asn1_header (struct asn1_builder_header *header, unsigned int type, size_t len) |
Construct ASN.1 header. 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... | |
int | image_asn1 (struct image *image, size_t offset, struct asn1_cursor **cursor) |
Extract ASN.1 object from image. More... | |
REQUIRING_SYMBOL (image_asn1) | |
REQUIRE_OBJECT (config_asn1) | |
ASN.1 encoding.
Definition in file asn1.c.
#define EINVAL_ASN1_EMPTY __einfo_error ( EINFO_EINVAL_ASN1_EMPTY ) |
#define EINFO_EINVAL_ASN1_EMPTY __einfo_uniqify ( EINFO_EINVAL, 0x01, "Empty or underlength cursor" ) |
#define EINVAL_ASN1_LEN_LEN __einfo_error ( EINFO_EINVAL_ASN1_LEN_LEN ) |
#define EINFO_EINVAL_ASN1_LEN_LEN __einfo_uniqify ( EINFO_EINVAL, 0x02, "Length field overruns cursor" ) |
#define EINVAL_ASN1_LEN __einfo_error ( EINFO_EINVAL_ASN1_LEN ) |
#define EINFO_EINVAL_ASN1_LEN __einfo_uniqify ( EINFO_EINVAL, 0x03, "Field overruns cursor" ) |
#define EINVAL_ASN1_BOOLEAN __einfo_error ( EINFO_EINVAL_ASN1_BOOLEAN ) |
#define EINFO_EINVAL_ASN1_BOOLEAN __einfo_uniqify ( EINFO_EINVAL, 0x04, "Invalid boolean" ) |
#define EINVAL_ASN1_INTEGER __einfo_error ( EINFO_EINVAL_ASN1_INTEGER ) |
#define EINFO_EINVAL_ASN1_INTEGER __einfo_uniqify ( EINFO_EINVAL, 0x04, "Invalid integer" ) |
#define EINVAL_ASN1_TIME __einfo_error ( EINFO_EINVAL_ASN1_TIME ) |
#define EINFO_EINVAL_ASN1_TIME __einfo_uniqify ( EINFO_EINVAL, 0x05, "Invalid time" ) |
#define EINVAL_ASN1_ALGORITHM __einfo_error ( EINFO_EINVAL_ASN1_ALGORITHM ) |
#define EINFO_EINVAL_ASN1_ALGORITHM __einfo_uniqify ( EINFO_EINVAL, 0x06, "Invalid algorithm" ) |
#define EINVAL_BIT_STRING __einfo_error ( EINFO_EINVAL_BIT_STRING ) |
#define EINFO_EINVAL_BIT_STRING __einfo_uniqify ( EINFO_EINVAL, 0x07, "Invalid bit string" ) |
#define ENOTSUP_ALGORITHM __einfo_error ( EINFO_ENOTSUP_ALGORITHM ) |
#define EINFO_ENOTSUP_ALGORITHM __einfo_uniqify ( EINFO_ENOTSUP, 0x01, "Unsupported algorithm" ) |
#define ENOTTY_ALGORITHM __einfo_error ( EINFO_ENOTTY_ALGORITHM ) |
#define EINFO_ENOTTY_ALGORITHM __einfo_uniqify ( EINFO_ENOTTY, 0x01, "Inappropriate algorithm" ) |
FILE_LICENCE | ( | GPL2_OR_LATER_OR_UBDL | ) |
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().
|
static |
Identify ASN.1 algorithm by OID.
cursor | ASN.1 object cursor |
algorithm | Algorithm, or NULL |
Definition at line 460 of file asn1.c.
References algorithm, ASN1_ALGORITHMS, asn1_compare(), for_each_table_entry, and NULL.
Referenced by asn1_algorithm().
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().
|
static |
Construct ASN.1 header.
header | ASN.1 builder header |
type | Type |
len | Content length |
header_len | Header length |
Definition at line 739 of file asn1.c.
References header, len, and type.
Referenced by asn1_prepend(), and asn1_wrap().
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().
int image_asn1 | ( | struct image * | image, |
size_t | offset, | ||
struct asn1_cursor ** | cursor | ||
) |
Extract ASN.1 object from image.
image | Image |
offset | Offset within image |
cursor | ASN.1 cursor to fill in |
next | Offset to next image, or negative error |
The caller is responsible for eventually calling free() on the allocated ASN.1 cursor.
Definition at line 880 of file asn1.c.
References image_type::asn1, assert(), DBGC, ENOTSUP, len, image::name, next, offset, rc, strerror(), and image::type.
Referenced by asn1_okx(), image_x509(), and imgverify().
REQUIRING_SYMBOL | ( | image_asn1 | ) |
REQUIRE_OBJECT | ( | config_asn1 | ) |