summaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
authorEven Rouault <even.rouault@spatialys.com>2019-04-25 01:27:02 +0200
committerEven Rouault <even.rouault@spatialys.com>2019-04-25 14:40:56 +0200
commit6423163141412cb93364de4e33d90bcffefa0885 (patch)
treee58330d93683a62e942c6b8c909731d7d22dcf89 /src/lib
parentb86717fdd36b628ea7ecb5c24f7a086bf5bcd3a7 (diff)
Fix POC in multi-tile scenarios: avoid almost endless loop when a tile has no POC settings
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/openjp2/j2k.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/lib/openjp2/j2k.c b/src/lib/openjp2/j2k.c
index fcf62653..a40ea05a 100644
--- a/src/lib/openjp2/j2k.c
+++ b/src/lib/openjp2/j2k.c
@@ -1669,7 +1669,6 @@ static OPJ_BOOL opj_j2k_check_poc_val(const opj_poc_t *p_pocs,
index += step_r;
}
-
++p_pocs;
}
@@ -7179,7 +7178,6 @@ OPJ_BOOL opj_j2k_setup_encoder(opj_j2k_t *p_j2k,
if (parameters->numpocs) {
/* initialisation of POC */
- tcp->POC = 1;
for (i = 0; i < parameters->numpocs; i++) {
if (tileno + 1 == parameters->POC[i].tile) {
opj_poc_t *tcp_poc = &tcp->pocs[numpocs_tile];
@@ -7196,7 +7194,10 @@ OPJ_BOOL opj_j2k_setup_encoder(opj_j2k_t *p_j2k,
}
}
- tcp->numpocs = numpocs_tile - 1 ;
+ if (numpocs_tile) {
+ tcp->POC = 1;
+ tcp->numpocs = numpocs_tile - 1 ;
+ }
} else {
tcp->numpocs = 0;
}