For n > 7, we might get uninitialized (unzeroed) data. Spotted by "Kyoungho Jeon" <k.h.jeon@securesoft.co.kr>.
diff --git a/crypto/asn1/a_bitstr.c b/crypto/asn1/a_bitstr.c index c0501e1..7013a40 100644 --- a/crypto/asn1/a_bitstr.c +++ b/crypto/asn1/a_bitstr.c
@@ -236,10 +236,10 @@ else c=(unsigned char *)OPENSSL_realloc(a->data,w+1); if (c == NULL) return(0); + if (w+1-a->length > 0) memset(c+a->length, 0, w+1-a->length); a->data=c; a->length=w+1; - c[w]=0; - } + } a->data[w]=((a->data[w])&iv)|v; while ((a->length > 0) && (a->data[a->length-1] == 0)) a->length--;