summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEven Rouault <even.rouault@spatialys.com>2020-04-01 22:00:19 +0200
committerGitHub <noreply@github.com>2020-04-01 22:00:19 +0200
commit9c1cfb034a8cf24eb5e35fe9c7074fd079d14b80 (patch)
tree86ce2c02bf2cc2f11cab5bd7130a66d4ce34381c /src
parent563ecfb55ca77c0fc5ea19e4885e00f55ec82ca9 (diff)
parent1c54024165fd5db0e6047f28903274eb27d0980f (diff)
Merge pull request #1240 from rouault/fix_crash_opj_decompress
opj_decompress: add sanity checks to avoid segfault in case of decoding error
Diffstat (limited to 'src')
-rw-r--r--src/bin/jp2/convert.c16
-rw-r--r--src/bin/jp2/convertpng.c12
-rw-r--r--src/bin/jp2/converttif.c6
3 files changed, 34 insertions, 0 deletions
diff --git a/src/bin/jp2/convert.c b/src/bin/jp2/convert.c
index e670cd82..23f820c0 100644
--- a/src/bin/jp2/convert.c
+++ b/src/bin/jp2/convert.c
@@ -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;
}
diff --git a/src/bin/jp2/convertpng.c b/src/bin/jp2/convertpng.c
index 44d985f2..328c91be 100644
--- a/src/bin/jp2/convertpng.c
+++ b/src/bin/jp2/convertpng.c
@@ -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,
diff --git a/src/bin/jp2/converttif.c b/src/bin/jp2/converttif.c
index 6714d69c..9d1037ac 100644
--- a/src/bin/jp2/converttif.c
+++ b/src/bin/jp2/converttif.c
@@ -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,