diff options
author | Maxin B. John <maxin.john@enea.com> | 2014-04-07 17:48:11 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2014-04-08 17:51:04 +0100 |
commit | 344049ccfa59ae489c35fe0fb7592f7d34720b51 (patch) | |
tree | dba8a2f3a231bd7019f0ca5aa41637382af03eeb | |
parent | 9d142a7f523f89cd65bef2cd6ce75e4f4500711b (diff) | |
download | openembedded-core-344049ccfa59ae489c35fe0fb7592f7d34720b51.tar.gz openembedded-core-344049ccfa59ae489c35fe0fb7592f7d34720b51.tar.bz2 openembedded-core-344049ccfa59ae489c35fe0fb7592f7d34720b51.zip |
python: Fix CVE-2014-1912
A remote user can send specially crafted data to trigger a buffer overflow
in socket.recvfrom_into() and execute arbitrary code on the target system.
The code will run with the privileges of the target service.
This back-ported patch fixes CVE-2014-1912
Signed-off-by: Maxin B. John <maxin.john@enea.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/recipes-devtools/python/python/python-2.7.3-CVE-2014-1912.patch | 26 | ||||
-rw-r--r-- | meta/recipes-devtools/python/python_2.7.3.bb | 1 |
2 files changed, 27 insertions, 0 deletions
diff --git a/meta/recipes-devtools/python/python/python-2.7.3-CVE-2014-1912.patch b/meta/recipes-devtools/python/python/python-2.7.3-CVE-2014-1912.patch new file mode 100644 index 0000000000..02cc83d314 --- /dev/null +++ b/meta/recipes-devtools/python/python/python-2.7.3-CVE-2014-1912.patch @@ -0,0 +1,26 @@ +Upstream-Status: Backport + +Reference: http://bugs.python.org/issue20246 + +CVE-2014-1912: Python buffer overflow in socket.recvfrom_into() +lets remote users execute arbitrary code.Original patch by Benjamin Peterson + +Signed-off-by: Maxin B. John <maxin.john@enea.com> +--- +diff -r 40fb60df4755 Modules/socketmodule.c +--- a/Modules/socketmodule.c Sun Jan 12 12:11:47 2014 +0200 ++++ b/Modules/socketmodule.c Mon Jan 13 16:36:35 2014 -0800 +@@ -2744,6 +2744,13 @@ + recvlen = buflen; + } + ++ /* Check if the buffer is large enough */ ++ if (buflen < recvlen) { ++ PyErr_SetString(PyExc_ValueError, ++ "buffer too small for requested bytes"); ++ goto error; ++ } ++ + readlen = sock_recvfrom_guts(s, buf.buf, recvlen, flags, &addr); + if (readlen < 0) { + /* Return an error */ diff --git a/meta/recipes-devtools/python/python_2.7.3.bb b/meta/recipes-devtools/python/python_2.7.3.bb index c7bb9b4131..0d641720f1 100644 --- a/meta/recipes-devtools/python/python_2.7.3.bb +++ b/meta/recipes-devtools/python/python_2.7.3.bb @@ -35,6 +35,7 @@ SRC_URI += "\ file://parallel-makeinst-create-bindir.patch \ file://python-2.7.3-CVE-2013-1752-smtplib-fix.patch \ file://python-fix-build-error-with-Readline-6.3.patch \ + file://python-2.7.3-CVE-2014-1912.patch \ " S = "${WORKDIR}/Python-${PV}" |