diff options
-rw-r--r-- | meta-oe/recipes-extended/brotli/brotli/0001-brotli-fix-CVE-2020-8927.patch | 44 | ||||
-rw-r--r-- | meta-oe/recipes-extended/brotli/brotli_1.0.7.bb | 4 |
2 files changed, 47 insertions, 1 deletions
diff --git a/meta-oe/recipes-extended/brotli/brotli/0001-brotli-fix-CVE-2020-8927.patch b/meta-oe/recipes-extended/brotli/brotli/0001-brotli-fix-CVE-2020-8927.patch new file mode 100644 index 0000000000..c21794d147 --- /dev/null +++ b/meta-oe/recipes-extended/brotli/brotli/0001-brotli-fix-CVE-2020-8927.patch | |||
@@ -0,0 +1,44 @@ | |||
1 | From 95ab3786ce0f16e08e41f7bf216969a37dc86cad Mon Sep 17 00:00:00 2001 | ||
2 | From: Jan Kraemer <jan@spectrejan.de> | ||
3 | Date: Thu, 7 Oct 2021 12:48:04 +0200 | ||
4 | Subject: [PATCH] brotli: fix CVE-2020-8927 | ||
5 | |||
6 | [No upstream tracking] -- | ||
7 | |||
8 | This fixes a potential overflow when input chunk is >2GiB in | ||
9 | BrotliGetAvailableBits by capping the returned value to 2^30 | ||
10 | |||
11 | Fixed in brotli version 1.0.8 | ||
12 | https://github.com/google/brotli as of commit id | ||
13 | 223d80cfbec8fd346e32906c732c8ede21f0cea6 | ||
14 | |||
15 | Patch taken from Debian Buster: 1.0.7-2+deb10u1 | ||
16 | http://deb.debian.org/debian/pool/main/b/brotli/brotli_1.0.7-2+deb10u1.dsc | ||
17 | https://security-tracker.debian.org/tracker/CVE-2020-8927 | ||
18 | |||
19 | |||
20 | Upstream-Status: Backported | ||
21 | CVE: CVE-2020-8927 | ||
22 | |||
23 | Signed-off-by: Jan Kraemer <jan@spectrejan.de> | ||
24 | --- | ||
25 | c/dec/bit_reader.h | 5 ++++- | ||
26 | 1 file changed, 4 insertions(+), 1 deletion(-) | ||
27 | |||
28 | diff --git a/c/dec/bit_reader.h b/c/dec/bit_reader.h | ||
29 | index c06e914..0d20312 100644 | ||
30 | --- a/c/dec/bit_reader.h | ||
31 | +++ b/c/dec/bit_reader.h | ||
32 | @@ -87,8 +87,11 @@ static BROTLI_INLINE uint32_t BrotliGetAvailableBits( | ||
33 | } | ||
34 | |||
35 | /* Returns amount of unread bytes the bit reader still has buffered from the | ||
36 | - BrotliInput, including whole bytes in br->val_. */ | ||
37 | + BrotliInput, including whole bytes in br->val_. Result is capped with | ||
38 | + maximal ring-buffer size (larger number won't be utilized anyway). */ | ||
39 | static BROTLI_INLINE size_t BrotliGetRemainingBytes(BrotliBitReader* br) { | ||
40 | + static const size_t kCap = (size_t)1 << 30; | ||
41 | + if (br->avail_in > kCap) return kCap; | ||
42 | return br->avail_in + (BrotliGetAvailableBits(br) >> 3); | ||
43 | } | ||
44 | |||
diff --git a/meta-oe/recipes-extended/brotli/brotli_1.0.7.bb b/meta-oe/recipes-extended/brotli/brotli_1.0.7.bb index 731eaf63a8..77fef778a4 100644 --- a/meta-oe/recipes-extended/brotli/brotli_1.0.7.bb +++ b/meta-oe/recipes-extended/brotli/brotli_1.0.7.bb | |||
@@ -6,7 +6,9 @@ BUGTRACKER = "https://github.com/google/brotli/issues" | |||
6 | LICENSE = "MIT" | 6 | LICENSE = "MIT" |
7 | LIC_FILES_CHKSUM = "file://${S}/LICENSE;md5=941ee9cd1609382f946352712a319b4b" | 7 | LIC_FILES_CHKSUM = "file://${S}/LICENSE;md5=941ee9cd1609382f946352712a319b4b" |
8 | 8 | ||
9 | SRC_URI = "git://github.com/google/brotli.git;branch=master;protocol=https" | 9 | SRC_URI = "git://github.com/google/brotli.git;branch=master;protocol=https \ |
10 | file://0001-brotli-fix-CVE-2020-8927.patch \ | ||
11 | " | ||
10 | # tag 1.0.7 | 12 | # tag 1.0.7 |
11 | SRCREV= "d6d98957ca8ccb1ef45922e978bb10efca0ea541" | 13 | SRCREV= "d6d98957ca8ccb1ef45922e978bb10efca0ea541" |
12 | S = "${WORKDIR}/git" | 14 | S = "${WORKDIR}/git" |