diff --git a/src/lib/openjp2/mqc.c b/src/lib/openjp2/mqc.c index 64a44ef5..d5ba1ab6 100644 --- a/src/lib/openjp2/mqc.c +++ b/src/lib/openjp2/mqc.c @@ -448,6 +448,11 @@ void opj_mqc_segmark_enc(opj_mqc_t *mqc) OPJ_BOOL opj_mqc_init_dec(opj_mqc_t *mqc, OPJ_BYTE *bp, OPJ_UINT32 len) { + /* Implements ISO 15444-1 C.3.5 Initialization of the decoder (INITDEC) */ + /* Note: alternate "J.1 - Initialization of the software-conventions */ + /* decoder" has been tried, but does */ + /* not bring any improvement. */ + /* See https://github.com/uclouvain/openjpeg/issues/921 */ opj_mqc_setcurctx(mqc, 0); mqc->start = bp; mqc->end = bp + len; diff --git a/src/lib/openjp2/mqc_inl.h b/src/lib/openjp2/mqc_inl.h index 7e1c17d1..e6558c59 100644 --- a/src/lib/openjp2/mqc_inl.h +++ b/src/lib/openjp2/mqc_inl.h @@ -93,6 +93,10 @@ static INLINE void opj_mqc_bytein(opj_mqc_t *const mqc) #else static INLINE void opj_mqc_bytein(opj_mqc_t *const mqc) { + /* Implements ISO 15444-1 C.3.4 Compressed image data input (BYTEIN) */ + /* Note: alternate "J.3 - Inserting a new byte into the C register in the */ + /* software-conventions decoder" has been tried, but does not bring any */ + /* improvement. See https://github.com/uclouvain/openjpeg/issues/921 */ if (mqc->bp != mqc->end) { OPJ_UINT32 c; if (mqc->bp + 1 != mqc->end) { @@ -144,6 +148,10 @@ Decode a symbol */ static INLINE OPJ_INT32 opj_mqc_decode(opj_mqc_t *const mqc) { + /* Implements ISO 15444-1 C.3.2 Decoding a decision (DECODE) */ + /* Note: alternate "J.2 - Decoding an MPS or an LPS in the */ + /* software-conventions decoder" has been tried, but does not bring any */ + /* improvement. See https://github.com/uclouvain/openjpeg/issues/921 */ OPJ_INT32 d; mqc->a -= (*mqc->curctx)->qeval; if ((mqc->c >> 16) < (*mqc->curctx)->qeval) {