Blame SOURCES/php-5.5.6-CVE-2014-3710.patch

e9ca13
From 1803228597e82218a8c105e67975bc50e6f5bf0d Mon Sep 17 00:00:00 2001
e9ca13
From: Remi Collet <remi@php.net>
e9ca13
Date: Wed, 22 Oct 2014 15:37:04 +0200
e9ca13
Subject: [PATCH] Fix bug #68283: fileinfo: out-of-bounds read in elf note
e9ca13
 headers
e9ca13
e9ca13
Upstream commit
e9ca13
https://github.com/file/file/commit/39c7ac1106be844a5296d3eb5971946cc09ffda0
e9ca13
e9ca13
CVE -2014-3710
e9ca13
---
e9ca13
 ext/fileinfo/libmagic/readelf.c | 7 +++++++
e9ca13
 1 file changed, 7 insertions(+)
e9ca13
e9ca13
diff --git a/ext/fileinfo/libmagic/readelf.c b/ext/fileinfo/libmagic/readelf.c
e9ca13
index 1c3845f..bb6f70f 100644
e9ca13
--- a/ext/fileinfo/libmagic/readelf.c
e9ca13
+++ b/ext/fileinfo/libmagic/readelf.c
e9ca13
@@ -372,6 +372,13 @@ donote(struct magic_set *ms, void *vbuf, size_t offset, size_t size,
e9ca13
 	uint32_t namesz, descsz;
e9ca13
 	unsigned char *nbuf = CAST(unsigned char *, vbuf);
e9ca13
 
e9ca13
+	if (xnh_sizeof + offset > size) {
e9ca13
+		/*
e9ca13
+		 * We're out of note headers.
e9ca13
+		 */
e9ca13
+		return xnh_sizeof + offset;
e9ca13
+	}
e9ca13
+
e9ca13
 	(void)memcpy(xnh_addr, &nbuf[offset], xnh_sizeof);
e9ca13
 	offset += xnh_sizeof;
e9ca13
 
e9ca13
-- 
e9ca13
2.1.0
e9ca13