Merge pull request #144 from libtom/fix/coverity-dsa_import-double-free
fix coverity finding: dsa_import double free
This commit is contained in:
commit
30382d0e31
@ -99,14 +99,16 @@ int dsa_import(const unsigned char *in, unsigned long inlen, dsa_key *key)
|
|||||||
goto LBL_ERR;
|
goto LBL_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = der_decode_subject_public_key_info(in, inlen,
|
err = der_decode_subject_public_key_info(in, inlen, PKA_DSA,
|
||||||
PKA_DSA, tmpbuf, &tmpbuf_len,
|
tmpbuf, &tmpbuf_len,
|
||||||
LTC_ASN1_SEQUENCE, params, 3);
|
LTC_ASN1_SEQUENCE, params, 3);
|
||||||
if (err != CRYPT_OK) {
|
if (err != CRYPT_OK) {
|
||||||
|
XFREE(tmpbuf);
|
||||||
goto LBL_ERR;
|
goto LBL_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((err=der_decode_integer(tmpbuf, tmpbuf_len, key->y)) != CRYPT_OK) {
|
if ((err=der_decode_integer(tmpbuf, tmpbuf_len, key->y)) != CRYPT_OK) {
|
||||||
|
XFREE(tmpbuf);
|
||||||
goto LBL_ERR;
|
goto LBL_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -125,7 +127,6 @@ LBL_OK:
|
|||||||
|
|
||||||
return CRYPT_OK;
|
return CRYPT_OK;
|
||||||
LBL_ERR:
|
LBL_ERR:
|
||||||
XFREE(tmpbuf);
|
|
||||||
mp_clear_multi(key->p, key->g, key->q, key->x, key->y, NULL);
|
mp_clear_multi(key->p, key->g, key->q, key->x, key->y, NULL);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user