mirror of
https://github.com/ipxe/ipxe
synced 2026-01-24 13:13:42 +03:00
[crypto] Generalise rsa_parse_integer() to asn1_enter_unsigned()
ECDSA signature values and private keys are fixed-length unsigned integers modulo N (the group order of the elliptic curve) and are therefore most naturally represented in ASN.1 using ASN1_OCTET_STRING. Private key representations do use ASN1_OCTET_STRING, but signature values tend to use ASN1_INTEGER, which adds no value but does ensure that the encoding becomes variable-length and requires handling a pointless extra zero byte if the MSB of the unsigned value happens to be set. RSA also makes use of ASN1_INTEGER for modulus and exponent values. Generalise the existing rsa_parse_integer() to asn1_enter_unsigned() to allow this code to be reused for ECDSA. Signed-off-by: Michael Brown <mcb30@ipxe.org>
This commit is contained in:
@@ -488,6 +488,7 @@ extern int asn1_skip_any ( struct asn1_cursor *cursor );
|
||||
extern int asn1_shrink_any ( struct asn1_cursor *cursor );
|
||||
extern int asn1_enter_bits ( struct asn1_cursor *cursor,
|
||||
unsigned int *unused );
|
||||
extern int asn1_enter_unsigned ( struct asn1_cursor *cursor );
|
||||
extern int asn1_boolean ( const struct asn1_cursor *cursor );
|
||||
extern int asn1_integer ( const struct asn1_cursor *cursor, int *value );
|
||||
extern int asn1_compare ( const struct asn1_cursor *cursor1,
|
||||
|
||||
Reference in New Issue
Block a user