summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNikos Mavrogiannopoulos <nmav@redhat.com>2016-02-29 10:39:17 +0100
committerNikos Mavrogiannopoulos <nmav@redhat.com>2016-02-29 10:39:17 +0100
commitdd215e40f1f1c499359fb09e9cfd856b125413e2 (patch)
tree6d351b3abcf7f491a63374a321bb34e30ec468ca
parent0d42c018d1031e1e87263c85b02e13037bd958d1 (diff)
downloadlibtasn1-dd215e40f1f1c499359fb09e9cfd856b125413e2.tar.gz
coding: Fixes to prevent undefined behavior (found with libubsan)
-rw-r--r--lib/coding.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/lib/coding.c b/lib/coding.c
index b23ca16..78615a1 100644
--- a/lib/coding.c
+++ b/lib/coding.c
@@ -443,7 +443,9 @@ asn1_bit_der (const unsigned char *str, int bit_len,
len_byte++;
asn1_length_der (len_byte + 1, der, &len_len);
der[len_len] = len_pad;
- memcpy (der + len_len + 1, str, len_byte);
+
+ if (str)
+ memcpy (der + len_len + 1, str, len_byte);
der[len_len + len_byte] &= bit_mask[len_pad];
*der_len = len_byte + len_len + 1;
}
@@ -628,7 +630,7 @@ _asn1_insert_tag_der (asn1_node node, unsigned char *der, int *counter,
tag_der, &tag_len);
*max_len -= tag_len;
- if (*max_len >= 0)
+ if (der && *max_len >= 0)
memcpy (der + *counter, tag_der, tag_len);
*counter += tag_len;
@@ -680,7 +682,7 @@ _asn1_insert_tag_der (asn1_node node, unsigned char *der, int *counter,
}
*max_len -= tag_len;
- if (*max_len >= 0)
+ if (der && *max_len >= 0)
memcpy (der + *counter, tag_der, tag_len);
*counter += tag_len;