summaryrefslogtreecommitdiffstats
path: root/meta/recipes-support/libcroco
diff options
context:
space:
mode:
authorChangqing Li <changqing.li@windriver.com>2018-08-28 17:39:23 +0800
committerRichard Purdie <richard.purdie@linuxfoundation.org>2018-08-29 10:42:48 +0100
commitbd369f288d3fb0f2ebee57e43eb7cd8731383788 (patch)
tree38c7e5f43922fd6032c0b045a978915cd718b83c /meta/recipes-support/libcroco
parent1e1b1ab769c58be9c677cf77407b5da78166b6a1 (diff)
downloadpoky-bd369f288d3fb0f2ebee57e43eb7cd8731383788.tar.gz
libcroco: patch for CVE-2017-7960
(From OE-Core rev: 2539d7334cbe9693ebe68d33c7a97872a1645510) Signed-off-by: Changqing Li <changqing.li@windriver.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-support/libcroco')
-rw-r--r--meta/recipes-support/libcroco/libcroco/CVE-2017-7960.patch56
-rw-r--r--meta/recipes-support/libcroco/libcroco_0.6.12.bb2
2 files changed, 58 insertions, 0 deletions
diff --git a/meta/recipes-support/libcroco/libcroco/CVE-2017-7960.patch b/meta/recipes-support/libcroco/libcroco/CVE-2017-7960.patch
new file mode 100644
index 0000000000..f6f43c3d26
--- /dev/null
+++ b/meta/recipes-support/libcroco/libcroco/CVE-2017-7960.patch
@@ -0,0 +1,56 @@
1input: check end of input before reading a byte
2
3When reading bytes we weren't check that the index wasn't
4out of bound and this could produce an invalid read which
5could deal to a security bug.
6
7Upstream-Status: Backport[https://gitlab.gnome.org/GNOME/libcroco/
8 commit/898e3a8c8c0314d2e6b106809a8e3e93cf9d4394]
9
10CVE: CVE-2017-7960
11
12Signed-off-by: Changqing Li <changqing.li@windriver.com>
13
14diff --git a/src/cr-input.c b/src/cr-input.c
15index 49000b1f5f07fe057135f1b8fc69bdcf9613e300..3b63a88ee3b1c56778e58172d147d958951bf099 100644
16--- a/src/cr-input.c
17+++ b/src/cr-input.c
18@@ -256,7 +256,7 @@ cr_input_new_from_uri (const gchar * a_file_uri, enum CREncoding a_enc)
19 *we should free buf here because it's own by CRInput.
20 *(see the last parameter of cr_input_new_from_buf().
21 */
22- buf = NULL ;
23+ buf = NULL;
24 }
25
26 cleanup:
27@@ -404,6 +404,8 @@ cr_input_get_nb_bytes_left (CRInput const * a_this)
28 enum CRStatus
29 cr_input_read_byte (CRInput * a_this, guchar * a_byte)
30 {
31+ gulong nb_bytes_left = 0;
32+
33 g_return_val_if_fail (a_this && PRIVATE (a_this)
34 && a_byte, CR_BAD_PARAM_ERROR);
35
36@@ -413,6 +415,12 @@ cr_input_read_byte (CRInput * a_this, guchar * a_byte)
37 if (PRIVATE (a_this)->end_of_input == TRUE)
38 return CR_END_OF_INPUT_ERROR;
39
40+ nb_bytes_left = cr_input_get_nb_bytes_left (a_this);
41+
42+ if (nb_bytes_left < 1) {
43+ return CR_END_OF_INPUT_ERROR;
44+ }
45+
46 *a_byte = PRIVATE (a_this)->in_buf[PRIVATE (a_this)->next_byte_index];
47
48 if (PRIVATE (a_this)->nb_bytes -
49@@ -477,7 +485,6 @@ cr_input_read_char (CRInput * a_this, guint32 * a_char)
50 if (*a_char == '\n') {
51 PRIVATE (a_this)->end_of_line = TRUE;
52 }
53-
54 }
55
56 return status;
diff --git a/meta/recipes-support/libcroco/libcroco_0.6.12.bb b/meta/recipes-support/libcroco/libcroco_0.6.12.bb
index d86ddd6464..5b962ee738 100644
--- a/meta/recipes-support/libcroco/libcroco_0.6.12.bb
+++ b/meta/recipes-support/libcroco/libcroco_0.6.12.bb
@@ -16,5 +16,7 @@ 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"
20
19SRC_URI[archive.md5sum] = "bc0984fce078ba2ce29f9500c6b9ddce" 21SRC_URI[archive.md5sum] = "bc0984fce078ba2ce29f9500c6b9ddce"
20SRC_URI[archive.sha256sum] = "ddc4b5546c9fb4280a5017e2707fbd4839034ed1aba5b7d4372212f34f84f860" 22SRC_URI[archive.sha256sum] = "ddc4b5546c9fb4280a5017e2707fbd4839034ed1aba5b7d4372212f34f84f860"