Fix a nasty quirk in ASN1_STRING_copy(3).
authorschwarze <schwarze@openbsd.org>
Sat, 13 Nov 2021 20:44:00 +0000 (20:44 +0000)
committerschwarze <schwarze@openbsd.org>
Sat, 13 Nov 2021 20:44:00 +0000 (20:44 +0000)
In case of failure, it reported the failure
but corrupted the type of the destination string.
Instead, let's make sure that in case of failure,
existing objects remain in their original state.

OK tb@

lib/libcrypto/asn1/asn1_lib.c

index d760ccc..b04fa3c 100644 (file)
@@ -1,4 +1,4 @@
-/* $OpenBSD: asn1_lib.c,v 1.45 2020/12/08 15:06:42 tb Exp $ */
+/* $OpenBSD: asn1_lib.c,v 1.46 2021/11/13 20:44:00 schwarze Exp $ */
 /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
  * All rights reserved.
  *
@@ -290,9 +290,9 @@ ASN1_STRING_copy(ASN1_STRING *dst, const ASN1_STRING *str)
 {
        if (str == NULL)
                return 0;
-       dst->type = str->type;
        if (!ASN1_STRING_set(dst, str->data, str->length))
                return 0;
+       dst->type = str->type;
        dst->flags = str->flags;
        return 1;
 }