Merge pull request #1240 from rouault/fix_crash_opj_decompress
opj_decompress: add sanity checks to avoid segfault in case of decoding error
This commit is contained in:
commit
9c1cfb034a
src/bin/jp2
|
@ -2067,10 +2067,26 @@ int imagetopnm(opj_image_t * image, const char *outfile, int force_split)
|
|||
has_alpha = (ncomp == 4 || ncomp == 2);
|
||||
|
||||
red = image->comps[0].data;
|
||||
if (red == NULL) {
|
||||
fprintf(stderr,
|
||||
"imagetopnm: planes[%d] == NULL.\n", 0);
|
||||
fprintf(stderr, "\tAborting\n");
|
||||
fclose(fdest);
|
||||
return fails;
|
||||
}
|
||||
|
||||
if (triple) {
|
||||
green = image->comps[1].data;
|
||||
blue = image->comps[2].data;
|
||||
for (i = 1; i <= 2; i++) {
|
||||
if (image->comps[i].data == NULL) {
|
||||
fprintf(stderr,
|
||||
"imagetopnm: planes[%d] == NULL.\n", i);
|
||||
fprintf(stderr, "\tAborting\n");
|
||||
fclose(fdest);
|
||||
return fails;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
green = blue = NULL;
|
||||
}
|
||||
|
|
|
@ -297,6 +297,12 @@ int imagetopng(opj_image_t * image, const char *write_idf)
|
|||
memset(&sig_bit, 0, sizeof(sig_bit));
|
||||
prec = (int)image->comps[0].prec;
|
||||
planes[0] = image->comps[0].data;
|
||||
if (planes[0] == NULL) {
|
||||
fprintf(stderr,
|
||||
"imagetopng: planes[%d] == NULL.\n", 0);
|
||||
fprintf(stderr, "\tAborting\n");
|
||||
return 1;
|
||||
}
|
||||
nr_comp = (int)image->numcomps;
|
||||
|
||||
if (nr_comp > 4) {
|
||||
|
@ -316,6 +322,12 @@ int imagetopng(opj_image_t * image, const char *write_idf)
|
|||
break;
|
||||
}
|
||||
planes[i] = image->comps[i].data;
|
||||
if (planes[i] == NULL) {
|
||||
fprintf(stderr,
|
||||
"imagetopng: planes[%d] == NULL.\n", i);
|
||||
fprintf(stderr, "\tAborting\n");
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
if (i != nr_comp) {
|
||||
fprintf(stderr,
|
||||
|
|
|
@ -616,6 +616,12 @@ int imagetotif(opj_image_t * image, const char *outfile)
|
|||
break;
|
||||
}
|
||||
planes[i] = image->comps[i].data;
|
||||
if (planes[i] == NULL) {
|
||||
fprintf(stderr,
|
||||
"imagetotif: planes[%d] == NULL.\n", i);
|
||||
fprintf(stderr, "\tAborting\n");
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
if (i != numcomps) {
|
||||
fprintf(stderr,
|
||||
|
|
Loading…
Reference in New Issue