asn1: Trade template crash for leak (AFL)
Yesterday's fix for an unlikely leak in the template interpreter introduced a crash found by American Fuzzy Lop (AFL).
This commit is contained in:
@@ -1059,10 +1059,8 @@ _asn1_decode(const struct asn1_template *t, unsigned flags,
|
|||||||
|
|
||||||
ret = _asn1_decode(t->ptr, flags & (~A1_PF_INDEFINTE), p, len,
|
ret = _asn1_decode(t->ptr, flags & (~A1_PF_INDEFINTE), p, len,
|
||||||
DPO(el->val, vallength), &newsize);
|
DPO(el->val, vallength), &newsize);
|
||||||
if (ret) {
|
if (ret)
|
||||||
_asn1_free(t->ptr, DPO(el->val, vallength));
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
|
||||||
vallength = newlen;
|
vallength = newlen;
|
||||||
el->len++;
|
el->len++;
|
||||||
p += newsize; len -= newsize;
|
p += newsize; len -= newsize;
|
||||||
|
Reference in New Issue
Block a user