dsa_verify_hash: fix wycheproof - appending unused 0's

This commit is contained in:
Karel Miko 2017-08-29 23:25:05 +02:00
parent 7e4bd971de
commit c927e4315a

View File

@ -98,16 +98,23 @@ int dsa_verify_hash(const unsigned char *sig, unsigned long siglen,
{ {
int err; int err;
void *r, *s; void *r, *s;
ltc_asn1_list sig_seq[2];
unsigned long reallen = 0;
if ((err = mp_init_multi(&r, &s, NULL)) != CRYPT_OK) { if ((err = mp_init_multi(&r, &s, NULL)) != CRYPT_OK) {
return err; return err;
} }
/* decode the sequence */ LTC_SET_ASN1(sig_seq, 0, LTC_ASN1_INTEGER, r, 1UL);
if ((err = der_decode_sequence_multi(sig, siglen, LTC_SET_ASN1(sig_seq, 1, LTC_ASN1_INTEGER, s, 1UL);
LTC_ASN1_INTEGER, 1UL, r,
LTC_ASN1_INTEGER, 1UL, s, err = der_decode_sequence(sig, siglen, sig_seq, 2);
LTC_ASN1_EOL, 0UL, NULL)) != CRYPT_OK) { if (err != CRYPT_OK) {
goto LBL_ERR;
}
err = der_length_sequence(sig_seq, 2, &reallen);
if (err != CRYPT_OK || reallen != siglen) {
goto LBL_ERR; goto LBL_ERR;
} }