Make ASN1_{INTEGER,ENUMERATED}_get() return 0 on NULL again
authortb <tb@openbsd.org>
Sat, 9 Jul 2022 14:46:42 +0000 (14:46 +0000)
committertb <tb@openbsd.org>
Sat, 9 Jul 2022 14:46:42 +0000 (14:46 +0000)
This is the documented behavior which got lost in the recent rewrite.

Mismatch of documentation and reality pointed out by schwarze

ok jsing

lib/libcrypto/asn1/a_enum.c
lib/libcrypto/asn1/a_int.c

index 11868ce..3b6cd9f 100644 (file)
@@ -1,4 +1,4 @@
-/* $OpenBSD: a_enum.c,v 1.24 2022/06/25 16:15:18 jsing Exp $ */
+/* $OpenBSD: a_enum.c,v 1.25 2022/07/09 14:46:43 tb Exp $ */
 /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
  * All rights reserved.
  *
@@ -141,6 +141,8 @@ ASN1_ENUMERATED_get(const ASN1_ENUMERATED *aenum)
 {
        int64_t val;
 
+       if (aenum == NULL)
+               return 0;
        if (!ASN1_ENUMERATED_get_int64(&val, aenum))
                return -1;
        if (val < LONG_MIN || val > LONG_MAX) {
index 38a2e1c..1f1e587 100644 (file)
@@ -1,4 +1,4 @@
-/* $OpenBSD: a_int.c,v 1.42 2022/06/28 19:44:28 jsing Exp $ */
+/* $OpenBSD: a_int.c,v 1.43 2022/07/09 14:46:42 tb Exp $ */
 /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
  * All rights reserved.
  *
@@ -297,6 +297,8 @@ ASN1_INTEGER_get(const ASN1_INTEGER *aint)
 {
        int64_t val;
 
+       if (aint == NULL)
+               return 0;
        if (!ASN1_INTEGER_get_int64(&val, aint))
                return -1;
        if (val < LONG_MIN || val > LONG_MAX) {