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:
Nicolas Williams
2021-03-03 10:16:45 -06:00
parent a0f542486e
commit 4eff66a2cd

View File

@@ -1059,10 +1059,8 @@ _asn1_decode(const struct asn1_template *t, unsigned flags,
ret = _asn1_decode(t->ptr, flags & (~A1_PF_INDEFINTE), p, len,
DPO(el->val, vallength), &newsize);
if (ret) {
_asn1_free(t->ptr, DPO(el->val, vallength));
if (ret)
return ret;
}
vallength = newlen;
el->len++;
p += newsize; len -= newsize;