From: Antonin Descampe Date: Fri, 3 Oct 2014 10:15:28 +0000 (+0000) Subject: [trunk]fixes buffer overflow in t2.c X-Git-Tag: wg1n6848~22 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=48832d944f25b6e8f81c44ce2f2b780ab6a53f7c;p=openjpeg [trunk]fixes buffer overflow in t2.c Update issue 390 Summary: check for negative-size params in code Patch from Matthieu applied. Left open to apply this to other places in code. --- diff --git a/src/lib/openjp2/t2.c b/src/lib/openjp2/t2.c index f2a7c9a5..cdd35e8c 100644 --- a/src/lib/openjp2/t2.c +++ b/src/lib/openjp2/t2.c @@ -1132,7 +1132,7 @@ OPJ_BOOL opj_t2_read_packet_data( opj_t2_t* p_t2, do { /* Check possible overflow (on l_current_data only, assumes input args already checked) then size */ - if (((OPJ_SIZE_T)(l_current_data + l_seg->newlen) < (OPJ_SIZE_T)l_current_data) || (l_current_data + l_seg->newlen > p_src_data + p_max_length)) { + if ((((OPJ_SIZE_T)l_current_data + (OPJ_SIZE_T)l_seg->newlen) < (OPJ_SIZE_T)l_current_data) || (l_current_data + l_seg->newlen > p_src_data + p_max_length)) { fprintf(stderr, "read: segment too long (%d) with max (%d) for codeblock %d (p=%d, b=%d, r=%d, c=%d)\n", l_seg->newlen, p_max_length, cblkno, p_pi->precno, bandno, p_pi->resno, p_pi->compno); return OPJ_FALSE;