ref: 117c8cb448c1f43ce2e9027e8ac155283d68062f
parent: 87411156c29ade8ab5dca9811bc6804140d885a4
author: Sebastian Rasmussen <[email protected]>
date: Sun Mar 18 10:09:16 EDT 2018
Fix 699127: JBIG2 adaptive pixels restricted to field. When decoding generic regions the adaptive pixels must be restricted to a field, previously this was not validated, leading to out of buffer accesses. This is now validated and may generate a fatal error.
--- a/jbig2_generic.c
+++ b/jbig2_generic.c
@@ -61,6 +61,7 @@
byte *gbreg_line = (byte *) image->data;
/* todo: currently we only handle the nominal gbat location */
+ /* when resolved make sure to call jbig2_check_adaptive_pixel_in_field() */
#ifdef OUTPUT_PBM
printf("P4\n%d %d\n", GBW, GBH);
@@ -110,6 +111,9 @@
return 0;
}
+#define pixel_outside_field(x, y) \
+ ((y) < -128 || (y) > 0 || (x) < -128 || ((y) < 0 && (x) > 127) || ((y) == 0 && (x) > 0))
+
static int
jbig2_decode_generic_template0_unopt(Jbig2Ctx *ctx,
Jbig2Segment *segment,
@@ -121,6 +125,13 @@
int x, y;
bool bit;
+ if (pixel_outside_field(params->gbat[0], params->gbat[1]) ||
+ pixel_outside_field(params->gbat[2], params->gbat[3]) ||
+ pixel_outside_field(params->gbat[4], params->gbat[5]) ||
+ pixel_outside_field(params->gbat[6], params->gbat[7]))
+ return jbig2_error(ctx, JBIG2_SEVERITY_FATAL, segment->number,
+ "adaptive template pixel is out of field");
+
/* this version is generic and easy to understand, but very slow */
for (y = 0; y < GBH; y++) {
@@ -161,6 +172,7 @@
byte *gbreg_line = (byte *) image->data;
/* todo: currently we only handle the nominal gbat location */
+ /* when resolved make sure to call jbig2_check_adaptive_pixel_in_field() */
#ifdef OUTPUT_PBM
printf("P4\n%d %d\n", GBW, GBH);
@@ -222,6 +234,7 @@
byte *gbreg_line = (byte *) image->data;
/* todo: currently we only handle the nominal gbat location */
+ /* when resolved make sure to call jbig2_check_adaptive_pixel_in_field() */
#ifdef OUTPUT_PBM
printf("P4\n%d %d\n", GBW, GBH);
@@ -402,6 +415,10 @@
int x, y;
bool bit;
+ if (pixel_outside_field(params->gbat[0], params->gbat[1]))
+ return jbig2_error(ctx, JBIG2_SEVERITY_FATAL, segment->number,
+ "adaptive template pixel is out of field");
+
/* this version is generic and easy to understand, but very slow */
for (y = 0; y < GBH; y++) {
@@ -450,6 +467,13 @@
bool bit;
int LTP = 0;
+ if (pixel_outside_field(params->gbat[0], params->gbat[1]) ||
+ pixel_outside_field(params->gbat[2], params->gbat[3]) ||
+ pixel_outside_field(params->gbat[4], params->gbat[5]) ||
+ pixel_outside_field(params->gbat[6], params->gbat[7]))
+ return jbig2_error(ctx, JBIG2_SEVERITY_FATAL, segment->number,
+ "adaptive template pixel is out of field");
+
for (y = 0; y < GBH; y++) {
LTP ^= jbig2_arith_decode(as, &GB_stats[0x9B25]);
if (!LTP) {
@@ -493,6 +517,10 @@
bool bit;
int LTP = 0;
+ if (pixel_outside_field(params->gbat[0], params->gbat[1]))
+ return jbig2_error(ctx, JBIG2_SEVERITY_FATAL, segment->number,
+ "adaptive template pixel is out of field");
+
for (y = 0; y < GBH; y++) {
LTP ^= jbig2_arith_decode(as, &GB_stats[0x0795]);
if (!LTP) {
@@ -533,6 +561,10 @@
bool bit;
int LTP = 0;
+ if (pixel_outside_field(params->gbat[0], params->gbat[1]))
+ return jbig2_error(ctx, JBIG2_SEVERITY_FATAL, segment->number,
+ "adaptive template pixel is out of field");
+
for (y = 0; y < GBH; y++) {
LTP ^= jbig2_arith_decode(as, &GB_stats[0xE5]);
if (!LTP) {
@@ -569,6 +601,10 @@
int x, y;
bool bit;
int LTP = 0;
+
+ if (pixel_outside_field(params->gbat[0], params->gbat[1]))
+ return jbig2_error(ctx, JBIG2_SEVERITY_FATAL, segment->number,
+ "adaptive template pixel is out of field");
for (y = 0; y < GBH; y++) {
LTP ^= jbig2_arith_decode(as, &GB_stats[0x0195]);