commit:     93ef99f17ee716bb4e5d10add0b0ab6184c80600
Author:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Tue May 30 19:35:59 2017 +0000
Commit:     Andreas Hüttel <dilfridge <AT> gentoo <DOT> org>
CommitDate: Tue May 30 19:35:59 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=93ef99f1

media-libs/jbig2dec: Revision bump for bug 620202

Package-Manager: Portage-2.3.6, Repoman-2.3.2

 .../files/jbig2dec-0.13-CVE-2017-9216.patch        | 31 ++++++++++++++
 media-libs/jbig2dec/jbig2dec-0.13-r2.ebuild        | 49 ++++++++++++++++++++++
 2 files changed, 80 insertions(+)

diff --git a/media-libs/jbig2dec/files/jbig2dec-0.13-CVE-2017-9216.patch 
b/media-libs/jbig2dec/files/jbig2dec-0.13-CVE-2017-9216.patch
new file mode 100644
index 00000000000..789ed6c9656
--- /dev/null
+++ b/media-libs/jbig2dec/files/jbig2dec-0.13-CVE-2017-9216.patch
@@ -0,0 +1,31 @@
+From 3ebffb1d96ba0cacec23016eccb4047dab365853 Mon Sep 17 00:00:00 2001
+From: Shailesh Mistry <[email protected]>
+Date: Wed, 24 May 2017 19:29:57 +0100
+Subject: [PATCH] Bug 697934: Fix SEGV due to error code being ignored.
+
+The return code from jbig2_decode_text_region was being ignored so the
+code continued to try and parse the invalid file using incomplete/empty
+structures.
+---
+ jbig2dec/jbig2_symbol_dict.c | 4 +++-
+ 1 file changed, 3 insertions(+), 1 deletion(-)
+
+diff --git a/jbig2_symbol_dict.c b/jbig2_symbol_dict.c
+index 3cc1731..672425d 100644
+--- a/jbig2_symbol_dict.c
++++ b/jbig2_symbol_dict.c
+@@ -493,8 +493,10 @@ jbig2_decode_symbol_dict(Jbig2Ctx *ctx,
+                         }
+ 
+                         /* multiple symbols are handled as a text region */
+-                        jbig2_decode_text_region(ctx, segment, tparams, 
(const Jbig2SymbolDict * const *)refagg_dicts,
++                        code = jbig2_decode_text_region(ctx, segment, 
tparams, (const Jbig2SymbolDict * const *)refagg_dicts,
+                                                  n_refagg_dicts, image, data, 
size, GR_stats, as, ws);
++                        if (code < 0)
++                            goto cleanup4;
+ 
+                         SDNEWSYMS->glyphs[NSYMSDECODED] = image;
+                         refagg_dicts[0]->glyphs[params->SDNUMINSYMS + 
NSYMSDECODED] = jbig2_image_clone(ctx, SDNEWSYMS->glyphs[NSYMSDECODED]);
+-- 
+2.9.1
+

diff --git a/media-libs/jbig2dec/jbig2dec-0.13-r2.ebuild 
b/media-libs/jbig2dec/jbig2dec-0.13-r2.ebuild
new file mode 100644
index 00000000000..16b53ba954a
--- /dev/null
+++ b/media-libs/jbig2dec/jbig2dec-0.13-r2.ebuild
@@ -0,0 +1,49 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+
+DESCRIPTION="A decoder implementation of the JBIG2 image compression format"
+HOMEPAGE="http://ghostscript.com/jbig2dec.html";
+SRC_URI="http://downloads.ghostscript.com/public/${PN}/${P}.tar.gz
+       test? ( http://jbig2dec.sourceforge.net/ubc/jb2streams.zip )"
+
+LICENSE="AGPL-3"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 
~sh ~sparc ~x86 ~x64-cygwin ~amd64-fbsd ~x86-fbsd ~amd64-linux ~x86-linux 
~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~x86-solaris"
+IUSE="png static-libs test"
+
+RDEPEND="png? ( media-libs/libpng:0= )"
+DEPEND="${RDEPEND}
+       test? ( app-arch/unzip )"
+
+RESTRICT="test"
+# bug 324275
+
+DOCS="CHANGES README"
+
+PATCHES=(
+       "${FILESDIR}/${P}-CVE-2016-9601.patch"
+       "${FILESDIR}/${P}-CVE-2017-9216.patch"
+)
+
+src_prepare() {
+       default
+
+       if use test; then
+               mkdir "${WORKDIR}/ubc" || die
+               mv -v "${WORKDIR}"/*.jb2 "${WORKDIR}/ubc/" || die
+               mv -v "${WORKDIR}"/*.bmp "${WORKDIR}/ubc/" || die
+       fi
+}
+
+src_configure() {
+       econf \
+               $(use_enable static-libs static) \
+               $(use_with png libpng)
+}
+
+src_install() {
+       default
+       find "${ED}" -name '*.la' -exec rm {} + || die
+}

Reply via email to