summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoss Burton <ross.burton@intel.com>2019-03-21 12:31:36 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2019-03-24 17:00:52 +0000
commit0775bf214756d4757196bbb4c80feb3d4347fd64 (patch)
tree0f21c38f809e6f2c954413b0602ab12337cf73d6
parent49c2351f3a50f4aab12a56ae587b71080e6f42b2 (diff)
downloadpoky-0775bf214756d4757196bbb4c80feb3d4347fd64.tar.gz
libcroco: fix CVE-2017-7961
(From OE-Core rev: 480f15850820746cecdfe0b8450b2be484c1f8f9) Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--meta/recipes-support/libcroco/libcroco/CVE-2017-7961.patch45
-rw-r--r--meta/recipes-support/libcroco/libcroco_0.6.12.bb4
2 files changed, 48 insertions, 1 deletions
diff --git a/meta/recipes-support/libcroco/libcroco/CVE-2017-7961.patch b/meta/recipes-support/libcroco/libcroco/CVE-2017-7961.patch
new file mode 100644
index 0000000000..35471ec7ee
--- /dev/null
+++ b/meta/recipes-support/libcroco/libcroco/CVE-2017-7961.patch
@@ -0,0 +1,45 @@
1CVE: CVE-2017-7961
2Upstream-Status: Backport
3Signed-off-by: Ross Burton <ross.burton@intel.com>
4
5From 9ad72875e9f08e4c519ef63d44cdbd94aa9504f7 Mon Sep 17 00:00:00 2001
6From: Ignacio Casal Quinteiro <qignacio@amazon.com>
7Date: Sun, 16 Apr 2017 13:56:09 +0200
8Subject: [PATCH] tknzr: support only max long rgb values
9
10This fixes a possible out of bound when reading rgbs which
11are longer than the support MAXLONG
12---
13 src/cr-tknzr.c | 10 ++++++++++
14 1 file changed, 10 insertions(+)
15
16diff --git a/src/cr-tknzr.c b/src/cr-tknzr.c
17index 1a7cfeb..1548c35 100644
18--- a/src/cr-tknzr.c
19+++ b/src/cr-tknzr.c
20@@ -1279,6 +1279,11 @@ cr_tknzr_parse_rgb (CRTknzr * a_this, CRRgb ** a_rgb)
21 status = cr_tknzr_parse_num (a_this, &num);
22 ENSURE_PARSING_COND ((status == CR_OK) && (num != NULL));
23
24+ if (num->val > G_MAXLONG) {
25+ status = CR_PARSING_ERROR;
26+ goto error;
27+ }
28+
29 red = num->val;
30 cr_num_destroy (num);
31 num = NULL;
32@@ -1298,6 +1303,11 @@ cr_tknzr_parse_rgb (CRTknzr * a_this, CRRgb ** a_rgb)
33 status = cr_tknzr_parse_num (a_this, &num);
34 ENSURE_PARSING_COND ((status == CR_OK) && (num != NULL));
35
36+ if (num->val > G_MAXLONG) {
37+ status = CR_PARSING_ERROR;
38+ goto error;
39+ }
40+
41 PEEK_BYTE (a_this, 1, &next_bytes[0]);
42 if (next_bytes[0] == '%') {
43 SKIP_CHARS (a_this, 1);
44--
452.18.1
diff --git a/meta/recipes-support/libcroco/libcroco_0.6.12.bb b/meta/recipes-support/libcroco/libcroco_0.6.12.bb
index 5b962ee738..f95a583134 100644
--- a/meta/recipes-support/libcroco/libcroco_0.6.12.bb
+++ b/meta/recipes-support/libcroco/libcroco_0.6.12.bb
@@ -16,7 +16,9 @@ BINCONFIG = "${bindir}/croco-0.6-config"
16 16
17inherit gnomebase gtk-doc binconfig-disabled 17inherit gnomebase gtk-doc binconfig-disabled
18 18
19SRC_URI += "file://CVE-2017-7960.patch" 19SRC_URI += "file://CVE-2017-7960.patch \
20 file://CVE-2017-7961.patch \
21 "
20 22
21SRC_URI[archive.md5sum] = "bc0984fce078ba2ce29f9500c6b9ddce" 23SRC_URI[archive.md5sum] = "bc0984fce078ba2ce29f9500c6b9ddce"
22SRC_URI[archive.sha256sum] = "ddc4b5546c9fb4280a5017e2707fbd4839034ed1aba5b7d4372212f34f84f860" 24SRC_URI[archive.sha256sum] = "ddc4b5546c9fb4280a5017e2707fbd4839034ed1aba5b7d4372212f34f84f860"