Blame SOURCES/jasper-1.900.1-CVE-2011-4516-CVE-2011-4517-CERT-VU-887409.patch

ca8428
diff -up jasper-1.900.1/src/libjasper/jpc/jpc_cs.c.CERT-VU-887409 jasper-1.900.1/src/libjasper/jpc/jpc_cs.c
ca8428
--- jasper-1.900.1/src/libjasper/jpc/jpc_cs.c.CERT-VU-887409	2011-10-25 17:25:39.000000000 +0200
ca8428
+++ jasper-1.900.1/src/libjasper/jpc/jpc_cs.c	2011-10-25 17:29:14.379371908 +0200
ca8428
@@ -744,6 +744,10 @@ static int jpc_cox_getcompparms(jpc_ms_t
ca8428
 		return -1;
ca8428
 	}
ca8428
 	compparms->numrlvls = compparms->numdlvls + 1;
ca8428
+	if (compparms->numrlvls > JPC_MAXRLVLS) {
ca8428
+		jpc_cox_destroycompparms(compparms);
ca8428
+		return -1;
ca8428
+	}
ca8428
 	if (prtflag) {
ca8428
 		for (i = 0; i < compparms->numrlvls; ++i) {
ca8428
 			if (jpc_getuint8(in, &tmp)) {
ca8428
@@ -1331,7 +1335,7 @@ static int jpc_crg_getparms(jpc_ms_t *ms
ca8428
 	jpc_crgcomp_t *comp;
ca8428
 	uint_fast16_t compno;
ca8428
 	crg->numcomps = cstate->numcomps;
ca8428
-	if (!(crg->comps = jas_alloc2(cstate->numcomps, sizeof(uint_fast16_t)))) {
ca8428
+	if (!(crg->comps = jas_alloc2(cstate->numcomps, sizeof(jpc_crgcomp_t)))) {
ca8428
 		return -1;
ca8428
 	}
ca8428
 	for (compno = 0, comp = crg->comps; compno < cstate->numcomps;