summaryrefslogtreecommitdiff
path: root/debian/patches/CVE-2016-9843.diff
diff options
context:
space:
mode:
authorIgor Pashev <pashev.igor@gmail.com>2019-11-19 17:35:47 +0300
committerIgor Pashev <pashev.igor@gmail.com>2019-11-19 17:35:47 +0300
commit03bebac19e6fef19299d7326d3ee41f8a7dd1316 (patch)
treebb413d22ada331790f08b7b9a592e5ab95cd8918 /debian/patches/CVE-2016-9843.diff
parent94a19f31b81e9e7e295414fe2ad2302e0db25a08 (diff)
parent8f6c4b0033c72f8ac14694c419a99458339dd6a9 (diff)
downloadgcc-9-03bebac19e6fef19299d7326d3ee41f8a7dd1316.tar.gz
Merge tag 'debian/9.2.1-19'
Diffstat (limited to 'debian/patches/CVE-2016-9843.diff')
-rw-r--r--debian/patches/CVE-2016-9843.diff47
1 files changed, 0 insertions, 47 deletions
diff --git a/debian/patches/CVE-2016-9843.diff b/debian/patches/CVE-2016-9843.diff
deleted file mode 100644
index ac1da9b..0000000
--- a/debian/patches/CVE-2016-9843.diff
+++ /dev/null
@@ -1,47 +0,0 @@
-commit d1d577490c15a0c6862473d7576352a9f18ef811
-Author: Mark Adler <madler@alumni.caltech.edu>
-Date: Wed Sep 28 20:20:25 2016 -0700
-
- Avoid pre-decrement of pointer in big-endian CRC calculation.
-
- There was a small optimization for PowerPCs to pre-increment a
- pointer when accessing a word, instead of post-incrementing. This
- required prefacing the loop with a decrement of the pointer,
- possibly pointing before the object passed. This is not compliant
- with the C standard, for which decrementing a pointer before its
- allocated memory is undefined. When tested on a modern PowerPC
- with a modern compiler, the optimization no longer has any effect.
- Due to all that, and per the recommendation of a security audit of
- the zlib code by Trail of Bits and TrustInSoft, in support of the
- Mozilla Foundation, this "optimization" was removed, in order to
- avoid the possibility of undefined behavior.
-
-diff --git a/crc32.c b/crc32.c
-index 979a719..05733f4 100644
---- a/src/zlib/crc32.c
-+++ b/src/zlib/crc32.c
-@@ -278,7 +278,7 @@ local unsigned long crc32_little(crc, buf, len)
- }
-
- /* ========================================================================= */
--#define DOBIG4 c ^= *++buf4; \
-+#define DOBIG4 c ^= *buf4++; \
- c = crc_table[4][c & 0xff] ^ crc_table[5][(c >> 8) & 0xff] ^ \
- crc_table[6][(c >> 16) & 0xff] ^ crc_table[7][c >> 24]
- #define DOBIG32 DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4
-@@ -300,7 +300,6 @@ local unsigned long crc32_big(crc, buf, len)
- }
-
- buf4 = (const z_crc_t FAR *)(const void FAR *)buf;
-- buf4--;
- while (len >= 32) {
- DOBIG32;
- len -= 32;
-@@ -309,7 +308,6 @@ local unsigned long crc32_big(crc, buf, len)
- DOBIG4;
- len -= 4;
- }
-- buf4++;
- buf = (const unsigned char FAR *)buf4;
-
- if (len) do {