File gnutls-CVE-2015-3622.patch of Package gnutls.openSUSE_13.2_Update
From: Nikos Mavrogiannopoulos <nmav@redhat.com>
Date: Mon, 20 Apr 2015 14:56:27 +0200
Subject: [PATCH 1/1] _asn1_extract_der_octet: prevent past of boundary access
This version backported to 3.7 branch.
---
lib/decoding.c | 3 ++-
1 files changed, 2 insertions(+), 1 deletions(-)
Index: gnutls-3.2.18/lib/minitasn1/decoding.c
===================================================================
--- gnutls-3.2.18.orig/lib/minitasn1/decoding.c 2014-09-04 21:06:50.000000000 +0200
+++ gnutls-3.2.18/lib/minitasn1/decoding.c 2015-08-03 15:03:45.553498541 +0200
@@ -730,6 +730,7 @@ _asn1_extract_der_octet (asn1_node node,
return ASN1_DER_ERROR;
counter = len3 + 1;
+ DECR_LEN(der_len, len3);
if (len2 == -1)
counter_end = der_len - 2;
@@ -738,6 +739,7 @@ _asn1_extract_der_octet (asn1_node node,
while (counter < counter_end)
{
+ DECR_LEN(der_len, 1);
len2 = asn1_get_length_der (der + counter, der_len, &len3);
if (IS_ERR(len2, flags))
@@ -762,7 +764,6 @@ _asn1_extract_der_octet (asn1_node node,
len2 = 0;
}
- DECR_LEN(der_len, 1);
counter += len2 + len3 + 1;
}