提交 1447a514 编写于 作者: B bae

6804998: JRE GIF Decoding Heap Corruption [V-y6g5jlm8e1]

Reviewed-by: prr
上级 19b2b253
...@@ -585,9 +585,16 @@ public class GifImageDecoder extends ImageDecoder { ...@@ -585,9 +585,16 @@ public class GifImageDecoder extends ImageDecoder {
System.out.print("Reading a " + width + " by " + height + " " + System.out.print("Reading a " + width + " by " + height + " " +
(interlace ? "" : "non-") + "interlaced image..."); (interlace ? "" : "non-") + "interlaced image...");
} }
int initCodeSize = ExtractByte(block, 9);
if (initCodeSize >= 12) {
if (verbose) {
System.out.println("Invalid initial code size: " +
initCodeSize);
}
return false;
}
boolean ret = parseImage(x, y, width, height, boolean ret = parseImage(x, y, width, height,
interlace, ExtractByte(block, 9), interlace, initCodeSize,
block, rasline, model); block, rasline, model);
if (!ret) { if (!ret) {
......
...@@ -191,6 +191,11 @@ Java_sun_awt_image_GifImageDecoder_parseImage(JNIEnv *env, ...@@ -191,6 +191,11 @@ Java_sun_awt_image_GifImageDecoder_parseImage(JNIEnv *env,
int passht = passinc; int passht = passinc;
int len; int len;
/* We have verified the initial code size on the java layer.
* Here we just check bounds for particular indexes. */
if (freeCode >= 4096 || maxCode >= 4096) {
return 0;
}
if (blockh == 0 || raslineh == 0 if (blockh == 0 || raslineh == 0
|| prefixh == 0 || suffixh == 0 || prefixh == 0 || suffixh == 0
|| outCodeh == 0) || outCodeh == 0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册