]> git.ipfire.org Git - thirdparty/openssl.git/commitdiff
Add negative integer check when using ASN1_BIT_STRING
authormlitre <martinlitre@mac.com>
Mon, 1 May 2023 09:07:21 +0000 (11:07 +0200)
committerPauli <pauli@openssl.org>
Wed, 3 May 2023 23:09:21 +0000 (09:09 +1000)
The negative integer check is done to prevent potential overflow.
Fixes #20719.

CLA: trivial

Reviewed-by: Tomas Mraz <tomas@openssl.org>
Reviewed-by: Paul Dale <pauli@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/20862)

(cherry picked from commit 1258a8e4361320cd3cfaf9ede692492ce01034c8)

crypto/asn1/a_bitstr.c

index f462dd107368caa4ff90ea4318653072fb65ce47..31a1e11359c82e690022f4a6804fc4b2fec0d39f 100644 (file)
@@ -148,6 +148,9 @@ int ASN1_BIT_STRING_set_bit(ASN1_BIT_STRING *a, int n, int value)
     int w, v, iv;
     unsigned char *c;
 
+    if (n < 0)
+        return 0;
+
     w = n / 8;
     v = 1 << (7 - (n & 0x07));
     iv = ~v;
@@ -182,6 +185,9 @@ int ASN1_BIT_STRING_get_bit(const ASN1_BIT_STRING *a, int n)
 {
     int w, v;
 
+    if (n < 0)
+        return 0;
+
     w = n / 8;
     v = 1 << (7 - (n & 0x07));
     if ((a == NULL) || (a->length < (w + 1)) || (a->data == NULL))