Script 'mail_helper' called by obssrc
Hello community,

here is the log from the commit of package libwebp for openSUSE:Factory checked 
in at 2023-10-02 20:04:08
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/libwebp (Old)
 and      /work/SRC/openSUSE:Factory/.libwebp.new.28202 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "libwebp"

Mon Oct  2 20:04:08 2023 rev:39 rq:1114613 version:1.3.2

Changes:
--------
--- /work/SRC/openSUSE:Factory/libwebp/libwebp.changes  2023-09-17 
19:29:23.373776197 +0200
+++ /work/SRC/openSUSE:Factory/.libwebp.new.28202/libwebp.changes       
2023-10-02 20:04:32.390647352 +0200
@@ -1,0 +2,6 @@
+Wed Sep 27 20:37:54 UTC 2023 - Andreas Stieger <andreas.stie...@gmx.de>
+
+- Add 0001-Fix-invalid-incremental-decoding-check.patch
+  A fuzzing finding fixed in the SLE/Leap updates
+
+-------------------------------------------------------------------

New:
----
  0001-Fix-invalid-incremental-decoding-check.patch

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ libwebp.spec ++++++
--- /var/tmp/diff_new_pack.5Os1T1/_old  2023-10-02 20:04:33.678693674 +0200
+++ /var/tmp/diff_new_pack.5Os1T1/_new  2023-10-02 20:04:33.678693674 +0200
@@ -29,6 +29,9 @@
 Source3:        %name.keyring
 Source4:        baselibs.conf
 
+# PATCH-FIX-UPSTREAM 0001-Fix-invalid-incremental-decoding-check.patch 
boo#1215231 CVE-2023-4863 xw...@suse.com -- Fix invalid incremental decoding 
check
+Patch2:         0001-Fix-invalid-incremental-decoding-check.patch
+
 BuildRequires:  giflib-devel
 BuildRequires:  pkgconfig
 BuildRequires:  pkgconfig(glut)

++++++ 0001-Fix-invalid-incremental-decoding-check.patch ++++++
>From 95ea5226c870449522240ccff26f0b006037c520 Mon Sep 17 00:00:00 2001
From: Vincent Rabaud <vrab...@google.com>
Date: Mon, 11 Sep 2023 16:06:08 +0200
Subject: [PATCH] Fix invalid incremental decoding check.

The first condition is only necessary if we have not read enough
(enough being defined by src_last, not src_end which is the end
of the image).
The second condition now fits the comment below: "if not
incremental, and we are past the end of buffer".

BUG=oss-fuzz:62136

Change-Id: I0700f67c62db8e1c02c2e429a069a71e606a5e4f
---
 src/dec/vp8l_dec.c | 15 +++++++++++++--
 1 file changed, 13 insertions(+), 2 deletions(-)

diff --git a/src/dec/vp8l_dec.c b/src/dec/vp8l_dec.c
index 5ab34f56..809b1aa9 100644
--- a/src/dec/vp8l_dec.c
+++ b/src/dec/vp8l_dec.c
@@ -1233,9 +1233,20 @@ static int DecodeImageData(VP8LDecoder* const dec, 
uint32_t* const data,
   }
 
   br->eos_ = VP8LIsEndOfStream(br);
-  if (dec->incremental_ && br->eos_ && src < src_end) {
+  // In incremental decoding:
+  // br->eos_ && src < src_last: if 'br' reached the end of the buffer and
+  // 'src_last' has not been reached yet, there is not enough data. 'dec' has 
to
+  // be reset until there is more data.
+  // !br->eos_ && src < src_last: this cannot happen as either the buffer is
+  // fully read, either enough has been read to reach 'src_last'.
+  // src >= src_last: 'src_last' is reached, all is fine. 'src' can actually go
+  // beyond 'src_last' in case the image is cropped and an LZ77 goes further.
+  // The buffer might have been enough or there is some left. 'br->eos_' does
+  // not matter.
+  assert(!dec->incremental_ || (br->eos_ && src < src_last) || src >= 
src_last);
+  if (dec->incremental_ && br->eos_ && src < src_last) {
     RestoreState(dec);
-  } else if (!br->eos_) {
+  } else if ((dec->incremental_ && src >= src_last) || !br->eos_) {
     // Process the remaining rows corresponding to last row-block.
     if (process_func != NULL) {
       process_func(dec, row > last_row ? last_row : row);
-- 
2.41.0

Reply via email to