summaryrefslogtreecommitdiff
path: root/third_party/libopenjpeg20/0015-read_SPCod_SPCoc_overflow.patch
diff options
context:
space:
mode:
authorochang <ochang@chromium.org>2016-05-20 09:54:24 -0700
committerCommit bot <commit-bot@chromium.org>2016-05-20 09:54:24 -0700
commit3cbb6fbcc7077d94161ec95b7bc1421671317c65 (patch)
treeed4082fde34f3f41ee31587552e202a129ff2c2f /third_party/libopenjpeg20/0015-read_SPCod_SPCoc_overflow.patch
parent788ac38e25fc6c000b36ec1722764673e192dea3 (diff)
downloadpdfium-3cbb6fbcc7077d94161ec95b7bc1421671317c65.tar.xz
openjpeg: Prevent a buffer overflow in opj_j2k_read_SPCod_SPCoc.chromium/2747chromium/2746chromium/2745chromium/2744
BUG=chromium:613160 Review-Url: https://codereview.chromium.org/2001663002
Diffstat (limited to 'third_party/libopenjpeg20/0015-read_SPCod_SPCoc_overflow.patch')
-rw-r--r--third_party/libopenjpeg20/0015-read_SPCod_SPCoc_overflow.patch15
1 files changed, 15 insertions, 0 deletions
diff --git a/third_party/libopenjpeg20/0015-read_SPCod_SPCoc_overflow.patch b/third_party/libopenjpeg20/0015-read_SPCod_SPCoc_overflow.patch
new file mode 100644
index 0000000000..56f0cf0e8e
--- /dev/null
+++ b/third_party/libopenjpeg20/0015-read_SPCod_SPCoc_overflow.patch
@@ -0,0 +1,15 @@
+diff --git a/third_party/libopenjpeg20/j2k.c b/third_party/libopenjpeg20/j2k.c
+index 9056feb..c7aa8db 100644
+--- a/third_party/libopenjpeg20/j2k.c
++++ b/third_party/libopenjpeg20/j2k.c
+@@ -8744,7 +8744,9 @@ static OPJ_BOOL opj_j2k_read_SPCod_SPCoc( opj_j2k_t *p_j2k,
+ p_j2k->m_specific_param.m_decoder.m_default_tcp;
+
+ /* precondition again */
+- assert(compno < p_j2k->m_private_image->numcomps);
++ if (compno >= p_j2k->m_private_image->numcomps) {
++ return OPJ_FALSE;
++ }
+
+ l_tccp = &l_tcp->tccps[compno];
+ l_current_ptr = p_header_data;