summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/lib/openjp2/t2.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/src/lib/openjp2/t2.c b/src/lib/openjp2/t2.c
index 9c212a1e..781a6a59 100644
--- a/src/lib/openjp2/t2.c
+++ b/src/lib/openjp2/t2.c
@@ -1229,9 +1229,17 @@ static OPJ_BOOL opj_t2_read_packet_header(opj_t2_t* p_t2,
while (!opj_tgt_decode(l_bio, l_prc->imsbtree, cblkno, (OPJ_INT32)i)) {
++i;
}
-
l_cblk->Mb = (OPJ_UINT32)l_band->numbps;
- l_cblk->numbps = (OPJ_UINT32)l_band->numbps + 1 - i;
+ if ((OPJ_UINT32)l_band->numbps + 1 < i) {
+ /* Not totally sure what we should do in that situation,
+ * but that avoids the integer overflow of
+ * https://github.com/uclouvain/openjpeg/pull/1488
+ * while keeping the regression test suite happy.
+ */
+ l_cblk->numbps = (OPJ_UINT32)(l_band->numbps + 1 - (int)i);
+ } else {
+ l_cblk->numbps = (OPJ_UINT32)l_band->numbps + 1 - i;
+ }
l_cblk->numlenbits = 3;
}