[trunk] update mqc global functions with opj_ prefix

This commit is contained in:
Mickael Savinaud 2012-10-03 12:12:33 +00:00
parent 5ffe6f5acf
commit 439337fb1b
3 changed files with 124 additions and 124 deletions

View File

@ -353,7 +353,7 @@ static INLINE void opj_mqc_renormd(opj_mqc_t *const mqc) {
========================================================== ==========================================================
*/ */
opj_mqc_t* mqc_create(void) { opj_mqc_t* opj_mqc_create(void) {
opj_mqc_t *mqc = (opj_mqc_t*)opj_malloc(sizeof(opj_mqc_t)); opj_mqc_t *mqc = (opj_mqc_t*)opj_malloc(sizeof(opj_mqc_t));
#ifdef MQC_PERF_OPT #ifdef MQC_PERF_OPT
mqc->buffer = NULL; mqc->buffer = NULL;
@ -361,7 +361,7 @@ opj_mqc_t* mqc_create(void) {
return mqc; return mqc;
} }
void mqc_destroy(opj_mqc_t *mqc) { void opj_mqc_destroy(opj_mqc_t *mqc) {
if(mqc) { if(mqc) {
#ifdef MQC_PERF_OPT #ifdef MQC_PERF_OPT
if (mqc->buffer) { /* TODO: LH: this test is pointless as free() is a no-op on 0 */ if (mqc->buffer) { /* TODO: LH: this test is pointless as free() is a no-op on 0 */
@ -372,13 +372,13 @@ void mqc_destroy(opj_mqc_t *mqc) {
} }
} }
OPJ_UINT32 mqc_numbytes(opj_mqc_t *mqc) { OPJ_UINT32 opj_mqc_numbytes(opj_mqc_t *mqc) {
return mqc->bp - mqc->start; return mqc->bp - mqc->start;
} }
void mqc_init_enc(opj_mqc_t *mqc, OPJ_BYTE *bp) { void opj_mqc_init_enc(opj_mqc_t *mqc, OPJ_BYTE *bp) {
/* TODO MSD: need to take a look to the v2 version */ /* TODO MSD: need to take a look to the v2 version */
mqc_setcurctx(mqc, 0); opj_mqc_setcurctx(mqc, 0);
mqc->a = 0x8000; mqc->a = 0x8000;
mqc->c = 0; mqc->c = 0;
mqc->bp = bp - 1; mqc->bp = bp - 1;
@ -389,7 +389,7 @@ void mqc_init_enc(opj_mqc_t *mqc, OPJ_BYTE *bp) {
mqc->start = bp; mqc->start = bp;
} }
void mqc_encode(opj_mqc_t *mqc, OPJ_UINT32 d) { void opj_mqc_encode(opj_mqc_t *mqc, OPJ_UINT32 d) {
if ((*mqc->curctx)->mps == d) { if ((*mqc->curctx)->mps == d) {
opj_mqc_codemps(mqc); opj_mqc_codemps(mqc);
} else { } else {
@ -397,7 +397,7 @@ void mqc_encode(opj_mqc_t *mqc, OPJ_UINT32 d) {
} }
} }
void mqc_flush(opj_mqc_t *mqc) { void opj_mqc_flush(opj_mqc_t *mqc) {
opj_mqc_setbits(mqc); opj_mqc_setbits(mqc);
mqc->c <<= mqc->ct; mqc->c <<= mqc->ct;
opj_mqc_byteout(mqc); opj_mqc_byteout(mqc);
@ -409,7 +409,7 @@ void mqc_flush(opj_mqc_t *mqc) {
} }
} }
void mqc_bypass_init_enc(opj_mqc_t *mqc) { void opj_mqc_bypass_init_enc(opj_mqc_t *mqc) {
mqc->c = 0; mqc->c = 0;
mqc->ct = 8; mqc->ct = 8;
/*if (*mqc->bp == 0xff) { /*if (*mqc->bp == 0xff) {
@ -417,7 +417,7 @@ void mqc_bypass_init_enc(opj_mqc_t *mqc) {
} */ } */
} }
void mqc_bypass_enc(opj_mqc_t *mqc, OPJ_UINT32 d) { void opj_mqc_bypass_enc(opj_mqc_t *mqc, OPJ_UINT32 d) {
mqc->ct--; mqc->ct--;
mqc->c = mqc->c + (d << mqc->ct); mqc->c = mqc->c + (d << mqc->ct);
if (mqc->ct == 0) { if (mqc->ct == 0) {
@ -431,7 +431,7 @@ void mqc_bypass_enc(opj_mqc_t *mqc, OPJ_UINT32 d) {
} }
} }
OPJ_UINT32 mqc_bypass_flush_enc(opj_mqc_t *mqc) { OPJ_UINT32 opj_mqc_bypass_flush_enc(opj_mqc_t *mqc) {
OPJ_BYTE bit_padding; OPJ_BYTE bit_padding;
bit_padding = 0; bit_padding = 0;
@ -451,14 +451,14 @@ OPJ_UINT32 mqc_bypass_flush_enc(opj_mqc_t *mqc) {
return 1; return 1;
} }
void mqc_reset_enc(opj_mqc_t *mqc) { void opj_mqc_reset_enc(opj_mqc_t *mqc) {
mqc_resetstates(mqc); opj_mqc_resetstates(mqc);
mqc_setstate(mqc, T1_CTXNO_UNI, 0, 46); opj_mqc_setstate(mqc, T1_CTXNO_UNI, 0, 46);
mqc_setstate(mqc, T1_CTXNO_AGG, 0, 3); opj_mqc_setstate(mqc, T1_CTXNO_AGG, 0, 3);
mqc_setstate(mqc, T1_CTXNO_ZC, 0, 4); opj_mqc_setstate(mqc, T1_CTXNO_ZC, 0, 4);
} }
OPJ_UINT32 mqc_restart_enc(opj_mqc_t *mqc) { OPJ_UINT32 opj_mqc_restart_enc(opj_mqc_t *mqc) {
OPJ_UINT32 correction = 1; OPJ_UINT32 correction = 1;
/* <flush part> */ /* <flush part> */
@ -474,9 +474,9 @@ OPJ_UINT32 mqc_restart_enc(opj_mqc_t *mqc) {
return correction; return correction;
} }
void mqc_restart_init_enc(opj_mqc_t *mqc) { void opj_mqc_restart_init_enc(opj_mqc_t *mqc) {
/* <Re-init part> */ /* <Re-init part> */
mqc_setcurctx(mqc, 0); opj_mqc_setcurctx(mqc, 0);
mqc->a = 0x8000; mqc->a = 0x8000;
mqc->c = 0; mqc->c = 0;
mqc->ct = 12; mqc->ct = 12;
@ -486,7 +486,7 @@ void mqc_restart_init_enc(opj_mqc_t *mqc) {
} }
} }
void mqc_erterm_enc(opj_mqc_t *mqc) { void opj_mqc_erterm_enc(opj_mqc_t *mqc) {
OPJ_INT32 k = 11 - mqc->ct + 1; OPJ_INT32 k = 11 - mqc->ct + 1;
while (k > 0) { while (k > 0) {
@ -501,17 +501,17 @@ void mqc_erterm_enc(opj_mqc_t *mqc) {
} }
} }
void mqc_segmark_enc(opj_mqc_t *mqc) { void opj_mqc_segmark_enc(opj_mqc_t *mqc) {
OPJ_UINT32 i; OPJ_UINT32 i;
mqc_setcurctx(mqc, 18); opj_mqc_setcurctx(mqc, 18);
for (i = 1; i < 5; i++) { for (i = 1; i < 5; i++) {
mqc_encode(mqc, i % 2); opj_mqc_encode(mqc, i % 2);
} }
} }
opj_bool mqc_init_dec(opj_mqc_t *mqc, OPJ_BYTE *bp, OPJ_UINT32 len) { opj_bool opj_mqc_init_dec(opj_mqc_t *mqc, OPJ_BYTE *bp, OPJ_UINT32 len) {
mqc_setcurctx(mqc, 0); opj_mqc_setcurctx(mqc, 0);
mqc->start = bp; mqc->start = bp;
mqc->end = bp + len; mqc->end = bp + len;
mqc->bp = bp; mqc->bp = bp;
@ -569,7 +569,7 @@ opj_bool mqc_init_dec(opj_mqc_t *mqc, OPJ_BYTE *bp, OPJ_UINT32 len) {
return OPJ_TRUE; return OPJ_TRUE;
} }
OPJ_INT32 mqc_decode(opj_mqc_t *const mqc) { OPJ_INT32 opj_mqc_decode(opj_mqc_t *const mqc) {
OPJ_INT32 d; OPJ_INT32 d;
mqc->a -= (*mqc->curctx)->qeval; mqc->a -= (*mqc->curctx)->qeval;
if ((mqc->c >> 16) < (*mqc->curctx)->qeval) { if ((mqc->c >> 16) < (*mqc->curctx)->qeval) {
@ -588,14 +588,14 @@ OPJ_INT32 mqc_decode(opj_mqc_t *const mqc) {
return d; return d;
} }
void mqc_resetstates(opj_mqc_t *mqc) { void opj_mqc_resetstates(opj_mqc_t *mqc) {
OPJ_UINT32 i; OPJ_UINT32 i;
for (i = 0; i < MQC_NUMCTXS; i++) { for (i = 0; i < MQC_NUMCTXS; i++) {
mqc->ctxs[i] = mqc_states; mqc->ctxs[i] = mqc_states;
} }
} }
void mqc_setstate(opj_mqc_t *mqc, OPJ_UINT32 ctxno, OPJ_UINT32 msb, OPJ_INT32 prob) { void opj_mqc_setstate(opj_mqc_t *mqc, OPJ_UINT32 ctxno, OPJ_UINT32 msb, OPJ_INT32 prob) {
mqc->ctxs[ctxno] = &mqc_states[msb + (prob << 1)]; mqc->ctxs[ctxno] = &mqc_states[msb + (prob << 1)];
} }

View File

@ -83,24 +83,24 @@ typedef struct opj_mqc {
Create a new MQC handle Create a new MQC handle
@return Returns a new MQC handle if successful, returns NULL otherwise @return Returns a new MQC handle if successful, returns NULL otherwise
*/ */
opj_mqc_t* mqc_create(void); opj_mqc_t* opj_mqc_create(void);
/** /**
Destroy a previously created MQC handle Destroy a previously created MQC handle
@param mqc MQC handle to destroy @param mqc MQC handle to destroy
*/ */
void mqc_destroy(opj_mqc_t *mqc); void opj_mqc_destroy(opj_mqc_t *mqc);
/** /**
Return the number of bytes written/read since initialisation Return the number of bytes written/read since initialisation
@param mqc MQC handle @param mqc MQC handle
@return Returns the number of bytes already encoded @return Returns the number of bytes already encoded
*/ */
OPJ_UINT32 mqc_numbytes(opj_mqc_t *mqc); OPJ_UINT32 opj_mqc_numbytes(opj_mqc_t *mqc);
/** /**
Reset the states of all the context of the coder/decoder Reset the states of all the context of the coder/decoder
(each context is set to a state where 0 and 1 are more or less equiprobable) (each context is set to a state where 0 and 1 are more or less equiprobable)
@param mqc MQC handle @param mqc MQC handle
*/ */
void mqc_resetstates(opj_mqc_t *mqc); void opj_mqc_resetstates(opj_mqc_t *mqc);
/** /**
Set the state of a particular context Set the state of a particular context
@param mqc MQC handle @param mqc MQC handle
@ -108,37 +108,37 @@ Set the state of a particular context
@param msb The MSB of the new state of the context @param msb The MSB of the new state of the context
@param prob Number that identifies the probability of the symbols for the new state of the context @param prob Number that identifies the probability of the symbols for the new state of the context
*/ */
void mqc_setstate(opj_mqc_t *mqc, OPJ_UINT32 ctxno, OPJ_UINT32 msb, OPJ_INT32 prob); void opj_mqc_setstate(opj_mqc_t *mqc, OPJ_UINT32 ctxno, OPJ_UINT32 msb, OPJ_INT32 prob);
/** /**
Initialize the encoder Initialize the encoder
@param mqc MQC handle @param mqc MQC handle
@param bp Pointer to the start of the buffer where the bytes will be written @param bp Pointer to the start of the buffer where the bytes will be written
*/ */
void mqc_init_enc(opj_mqc_t *mqc, OPJ_BYTE *bp); void opj_mqc_init_enc(opj_mqc_t *mqc, OPJ_BYTE *bp);
/** /**
Set the current context used for coding/decoding Set the current context used for coding/decoding
@param mqc MQC handle @param mqc MQC handle
@param ctxno Number that identifies the context @param ctxno Number that identifies the context
*/ */
#define mqc_setcurctx(mqc, ctxno) (mqc)->curctx = &(mqc)->ctxs[(OPJ_UINT32)(ctxno)] #define opj_mqc_setcurctx(mqc, ctxno) (mqc)->curctx = &(mqc)->ctxs[(OPJ_UINT32)(ctxno)]
/** /**
Encode a symbol using the MQ-coder Encode a symbol using the MQ-coder
@param mqc MQC handle @param mqc MQC handle
@param d The symbol to be encoded (0 or 1) @param d The symbol to be encoded (0 or 1)
*/ */
void mqc_encode(opj_mqc_t *mqc, OPJ_UINT32 d); void opj_mqc_encode(opj_mqc_t *mqc, OPJ_UINT32 d);
/** /**
Flush the encoder, so that all remaining data is written Flush the encoder, so that all remaining data is written
@param mqc MQC handle @param mqc MQC handle
*/ */
void mqc_flush(opj_mqc_t *mqc); void opj_mqc_flush(opj_mqc_t *mqc);
/** /**
BYPASS mode switch, initialization operation. BYPASS mode switch, initialization operation.
JPEG 2000 p 505. JPEG 2000 p 505.
<h2>Not fully implemented and tested !!</h2> <h2>Not fully implemented and tested !!</h2>
@param mqc MQC handle @param mqc MQC handle
*/ */
void mqc_bypass_init_enc(opj_mqc_t *mqc); void opj_mqc_bypass_init_enc(opj_mqc_t *mqc);
/** /**
BYPASS mode switch, coding operation. BYPASS mode switch, coding operation.
JPEG 2000 p 505. JPEG 2000 p 505.
@ -146,53 +146,53 @@ JPEG 2000 p 505.
@param mqc MQC handle @param mqc MQC handle
@param d The symbol to be encoded (0 or 1) @param d The symbol to be encoded (0 or 1)
*/ */
void mqc_bypass_enc(opj_mqc_t *mqc, OPJ_UINT32 d); void opj_mqc_bypass_enc(opj_mqc_t *mqc, OPJ_UINT32 d);
/** /**
BYPASS mode switch, flush operation BYPASS mode switch, flush operation
<h2>Not fully implemented and tested !!</h2> <h2>Not fully implemented and tested !!</h2>
@param mqc MQC handle @param mqc MQC handle
@return Returns 1 (always) @return Returns 1 (always)
*/ */
OPJ_UINT32 mqc_bypass_flush_enc(opj_mqc_t *mqc); OPJ_UINT32 opj_mqc_bypass_flush_enc(opj_mqc_t *mqc);
/** /**
RESET mode switch RESET mode switch
@param mqc MQC handle @param mqc MQC handle
*/ */
void mqc_reset_enc(opj_mqc_t *mqc); void opj_mqc_reset_enc(opj_mqc_t *mqc);
/** /**
RESTART mode switch (TERMALL) RESTART mode switch (TERMALL)
@param mqc MQC handle @param mqc MQC handle
@return Returns 1 (always) @return Returns 1 (always)
*/ */
OPJ_UINT32 mqc_restart_enc(opj_mqc_t *mqc); OPJ_UINT32 opj_mqc_restart_enc(opj_mqc_t *mqc);
/** /**
RESTART mode switch (TERMALL) reinitialisation RESTART mode switch (TERMALL) reinitialisation
@param mqc MQC handle @param mqc MQC handle
*/ */
void mqc_restart_init_enc(opj_mqc_t *mqc); void opj_mqc_restart_init_enc(opj_mqc_t *mqc);
/** /**
ERTERM mode switch (PTERM) ERTERM mode switch (PTERM)
@param mqc MQC handle @param mqc MQC handle
*/ */
void mqc_erterm_enc(opj_mqc_t *mqc); void opj_mqc_erterm_enc(opj_mqc_t *mqc);
/** /**
SEGMARK mode switch (SEGSYM) SEGMARK mode switch (SEGSYM)
@param mqc MQC handle @param mqc MQC handle
*/ */
void mqc_segmark_enc(opj_mqc_t *mqc); void opj_mqc_segmark_enc(opj_mqc_t *mqc);
/** /**
Initialize the decoder Initialize the decoder
@param mqc MQC handle @param mqc MQC handle
@param bp Pointer to the start of the buffer from which the bytes will be read @param bp Pointer to the start of the buffer from which the bytes will be read
@param len Length of the input buffer @param len Length of the input buffer
*/ */
opj_bool mqc_init_dec(opj_mqc_t *mqc, OPJ_BYTE *bp, OPJ_UINT32 len); opj_bool opj_mqc_init_dec(opj_mqc_t *mqc, OPJ_BYTE *bp, OPJ_UINT32 len);
/** /**
Decode a symbol Decode a symbol
@param mqc MQC handle @param mqc MQC handle
@return Returns the decoded symbol (0 or 1) @return Returns the decoded symbol (0 or 1)
*/ */
OPJ_INT32 mqc_decode(opj_mqc_t * const mqc); OPJ_INT32 opj_mqc_decode(opj_mqc_t * const mqc);
/* ----------------------------------------------------------------------- */ /* ----------------------------------------------------------------------- */
/*@}*/ /*@}*/

View File

@ -319,20 +319,20 @@ void opj_t1_enc_sigpass_step( opj_t1_t *t1,
flag = vsc ? ((*flagsp) & (~(T1_SIG_S | T1_SIG_SE | T1_SIG_SW | T1_SGN_S))) : (*flagsp); flag = vsc ? ((*flagsp) & (~(T1_SIG_S | T1_SIG_SE | T1_SIG_SW | T1_SGN_S))) : (*flagsp);
if ((flag & T1_SIG_OTH) && !(flag & (T1_SIG | T1_VISIT))) { if ((flag & T1_SIG_OTH) && !(flag & (T1_SIG | T1_VISIT))) {
v = int_abs(*datap) & one ? 1 : 0; v = int_abs(*datap) & one ? 1 : 0;
mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient)); /* ESSAI */ opj_mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient)); /* ESSAI */
if (type == T1_TYPE_RAW) { /* BYPASS/LAZY MODE */ if (type == T1_TYPE_RAW) { /* BYPASS/LAZY MODE */
mqc_bypass_enc(mqc, v); opj_mqc_bypass_enc(mqc, v);
} else { } else {
mqc_encode(mqc, v); opj_mqc_encode(mqc, v);
} }
if (v) { if (v) {
v = *datap < 0 ? 1 : 0; v = *datap < 0 ? 1 : 0;
*nmsedec += opj_t1_getnmsedec_sig(int_abs(*datap), bpno + T1_NMSEDEC_FRACBITS); *nmsedec += opj_t1_getnmsedec_sig(int_abs(*datap), bpno + T1_NMSEDEC_FRACBITS);
mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag)); /* ESSAI */ opj_mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag)); /* ESSAI */
if (type == T1_TYPE_RAW) { /* BYPASS/LAZY MODE */ if (type == T1_TYPE_RAW) { /* BYPASS/LAZY MODE */
mqc_bypass_enc(mqc, v); opj_mqc_bypass_enc(mqc, v);
} else { } else {
mqc_encode(mqc, v ^ opj_t1_getspb(flag)); opj_mqc_encode(mqc, v ^ opj_t1_getspb(flag));
} }
opj_t1_updateflags(flagsp, v, t1->flags_stride); opj_t1_updateflags(flagsp, v, t1->flags_stride);
} }
@ -390,11 +390,11 @@ void opj_t1_enc_refpass_step( opj_t1_t *t1,
if ((flag & (T1_SIG | T1_VISIT)) == T1_SIG) { if ((flag & (T1_SIG | T1_VISIT)) == T1_SIG) {
*nmsedec += opj_t1_getnmsedec_ref(int_abs(*datap), bpno + T1_NMSEDEC_FRACBITS); *nmsedec += opj_t1_getnmsedec_ref(int_abs(*datap), bpno + T1_NMSEDEC_FRACBITS);
v = int_abs(*datap) & one ? 1 : 0; v = int_abs(*datap) & one ? 1 : 0;
mqc_setcurctx(mqc, opj_t1_getctxno_mag(flag)); /* ESSAI */ opj_mqc_setcurctx(mqc, opj_t1_getctxno_mag(flag)); /* ESSAI */
if (type == T1_TYPE_RAW) { /* BYPASS/LAZY MODE */ if (type == T1_TYPE_RAW) { /* BYPASS/LAZY MODE */
mqc_bypass_enc(mqc, v); opj_mqc_bypass_enc(mqc, v);
} else { } else {
mqc_encode(mqc, v); opj_mqc_encode(mqc, v);
} }
*flagsp |= T1_REFINE; *flagsp |= T1_REFINE;
} }
@ -453,15 +453,15 @@ void opj_t1_enc_clnpass_step(
goto LABEL_PARTIAL; goto LABEL_PARTIAL;
} }
if (!(*flagsp & (T1_SIG | T1_VISIT))) { if (!(*flagsp & (T1_SIG | T1_VISIT))) {
mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient));
v = int_abs(*datap) & one ? 1 : 0; v = int_abs(*datap) & one ? 1 : 0;
mqc_encode(mqc, v); opj_mqc_encode(mqc, v);
if (v) { if (v) {
LABEL_PARTIAL: LABEL_PARTIAL:
*nmsedec += opj_t1_getnmsedec_sig(int_abs(*datap), bpno + T1_NMSEDEC_FRACBITS); *nmsedec += opj_t1_getnmsedec_sig(int_abs(*datap), bpno + T1_NMSEDEC_FRACBITS);
mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag));
v = *datap < 0 ? 1 : 0; v = *datap < 0 ? 1 : 0;
mqc_encode(mqc, v ^ opj_t1_getspb(flag)); opj_mqc_encode(mqc, v ^ opj_t1_getspb(flag));
opj_t1_updateflags(flagsp, v, t1->flags_stride); opj_t1_updateflags(flagsp, v, t1->flags_stride);
} }
} }
@ -481,8 +481,8 @@ static void t1_dec_clnpass_step_partial(
OPJ_ARG_NOT_USED(orient); OPJ_ARG_NOT_USED(orient);
flag = *flagsp; flag = *flagsp;
mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag));
v = mqc_decode(mqc) ^ opj_t1_getspb(flag); v = opj_mqc_decode(mqc) ^ opj_t1_getspb(flag);
*datap = v ? -oneplushalf : oneplushalf; *datap = v ? -oneplushalf : oneplushalf;
opj_t1_updateflags(flagsp, v, t1->flags_stride); opj_t1_updateflags(flagsp, v, t1->flags_stride);
*flagsp &= ~T1_VISIT; *flagsp &= ~T1_VISIT;
@ -501,10 +501,10 @@ static void t1_dec_clnpass_step(
flag = *flagsp; flag = *flagsp;
if (!(flag & (T1_SIG | T1_VISIT))) { if (!(flag & (T1_SIG | T1_VISIT))) {
mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient));
if (mqc_decode(mqc)) { if (opj_mqc_decode(mqc)) {
mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag));
v = mqc_decode(mqc) ^ opj_t1_getspb(flag); v = opj_mqc_decode(mqc) ^ opj_t1_getspb(flag);
*datap = v ? -oneplushalf : oneplushalf; *datap = v ? -oneplushalf : oneplushalf;
opj_t1_updateflags(flagsp, v, t1->flags_stride); opj_t1_updateflags(flagsp, v, t1->flags_stride);
} }
@ -530,11 +530,11 @@ static void t1_dec_clnpass_step_vsc(
goto LABEL_PARTIAL; goto LABEL_PARTIAL;
} }
if (!(flag & (T1_SIG | T1_VISIT))) { if (!(flag & (T1_SIG | T1_VISIT))) {
mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient));
if (mqc_decode(mqc)) { if (opj_mqc_decode(mqc)) {
LABEL_PARTIAL: LABEL_PARTIAL:
mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag));
v = mqc_decode(mqc) ^ opj_t1_getspb(flag); v = opj_mqc_decode(mqc) ^ opj_t1_getspb(flag);
*datap = v ? -oneplushalf : oneplushalf; *datap = v ? -oneplushalf : oneplushalf;
opj_t1_updateflags(flagsp, v, t1->flags_stride); opj_t1_updateflags(flagsp, v, t1->flags_stride);
} }
@ -580,14 +580,14 @@ void opj_t1_enc_clnpass(
if (int_abs(t1->data[((k + runlen)*t1->w) + i]) & one) if (int_abs(t1->data[((k + runlen)*t1->w) + i]) & one)
break; break;
} }
mqc_setcurctx(mqc, T1_CTXNO_AGG); opj_mqc_setcurctx(mqc, T1_CTXNO_AGG);
mqc_encode(mqc, runlen != 4); opj_mqc_encode(mqc, runlen != 4);
if (runlen == 4) { if (runlen == 4) {
continue; continue;
} }
mqc_setcurctx(mqc, T1_CTXNO_UNI); opj_mqc_setcurctx(mqc, T1_CTXNO_UNI);
mqc_encode(mqc, runlen >> 1); opj_mqc_encode(mqc, runlen >> 1);
mqc_encode(mqc, runlen & 1); opj_mqc_encode(mqc, runlen & 1);
} else { } else {
runlen = 0; runlen = 0;
} }
@ -635,13 +635,13 @@ static void t1_dec_clnpass(
agg = 0; agg = 0;
} }
if (agg) { if (agg) {
mqc_setcurctx(mqc, T1_CTXNO_AGG); opj_mqc_setcurctx(mqc, T1_CTXNO_AGG);
if (!mqc_decode(mqc)) { if (!opj_mqc_decode(mqc)) {
continue; continue;
} }
mqc_setcurctx(mqc, T1_CTXNO_UNI); opj_mqc_setcurctx(mqc, T1_CTXNO_UNI);
runlen = mqc_decode(mqc); runlen = opj_mqc_decode(mqc);
runlen = (runlen << 1) | mqc_decode(mqc); runlen = (runlen << 1) | opj_mqc_decode(mqc);
} else { } else {
runlen = 0; runlen = 0;
} }
@ -670,13 +670,13 @@ static void t1_dec_clnpass(
|| MACRO_t1_flags(1 + k + 2,1 + i) & (T1_SIG | T1_VISIT | T1_SIG_OTH) || MACRO_t1_flags(1 + k + 2,1 + i) & (T1_SIG | T1_VISIT | T1_SIG_OTH)
|| MACRO_t1_flags(1 + k + 3,1 + i) & (T1_SIG | T1_VISIT | T1_SIG_OTH)); || MACRO_t1_flags(1 + k + 3,1 + i) & (T1_SIG | T1_VISIT | T1_SIG_OTH));
if (agg) { if (agg) {
mqc_setcurctx(mqc, T1_CTXNO_AGG); opj_mqc_setcurctx(mqc, T1_CTXNO_AGG);
if (!mqc_decode(mqc)) { if (!opj_mqc_decode(mqc)) {
continue; continue;
} }
mqc_setcurctx(mqc, T1_CTXNO_UNI); opj_mqc_setcurctx(mqc, T1_CTXNO_UNI);
runlen = mqc_decode(mqc); runlen = opj_mqc_decode(mqc);
runlen = (runlen << 1) | mqc_decode(mqc); runlen = (runlen << 1) | opj_mqc_decode(mqc);
flags2 += runlen * t1->flags_stride; flags2 += runlen * t1->flags_stride;
data2 += runlen * t1->w; data2 += runlen * t1->w;
for (j = k + runlen; j < k + 4 && j < t1->h; ++j) { for (j = k + runlen; j < k + 4 && j < t1->h; ++j) {
@ -719,11 +719,11 @@ static void t1_dec_clnpass(
if (segsym) { if (segsym) {
int v = 0; int v = 0;
mqc_setcurctx(mqc, T1_CTXNO_UNI); opj_mqc_setcurctx(mqc, T1_CTXNO_UNI);
v = mqc_decode(mqc); v = opj_mqc_decode(mqc);
v = (v << 1) | mqc_decode(mqc); v = (v << 1) | opj_mqc_decode(mqc);
v = (v << 1) | mqc_decode(mqc); v = (v << 1) | opj_mqc_decode(mqc);
v = (v << 1) | mqc_decode(mqc); v = (v << 1) | opj_mqc_decode(mqc);
/* /*
if (v!=0xa) { if (v!=0xa) {
opj_event_msg(t1->cinfo, EVT_WARNING, "Bad segmentation symbol %x\n", v); opj_event_msg(t1->cinfo, EVT_WARNING, "Bad segmentation symbol %x\n", v);
@ -845,7 +845,7 @@ opj_t1_t* opj_t1_create()
memset(l_t1,0,sizeof(opj_t1_t)); memset(l_t1,0,sizeof(opj_t1_t));
/* create MQC and RAW handles */ /* create MQC and RAW handles */
l_t1->mqc = mqc_create(); l_t1->mqc = opj_mqc_create();
if (! l_t1->mqc) { if (! l_t1->mqc) {
opj_t1_destroy(l_t1); opj_t1_destroy(l_t1);
return 00; return 00;
@ -873,7 +873,7 @@ void opj_t1_destroy(opj_t1_t *p_t1)
} }
/* destroy MQC and RAW handles */ /* destroy MQC and RAW handles */
mqc_destroy(p_t1->mqc); opj_mqc_destroy(p_t1->mqc);
p_t1->mqc = 00; p_t1->mqc = 00;
raw_destroy(p_t1->raw); raw_destroy(p_t1->raw);
p_t1->raw = 00; p_t1->raw = 00;
@ -1005,10 +1005,10 @@ opj_bool opj_t1_decode_cblk(opj_t1_t *t1,
bpno = roishift + cblk->numbps - 1; bpno = roishift + cblk->numbps - 1;
passtype = 2; passtype = 2;
mqc_resetstates(mqc); opj_mqc_resetstates(mqc);
mqc_setstate(mqc, T1_CTXNO_UNI, 0, 46); opj_mqc_setstate(mqc, T1_CTXNO_UNI, 0, 46);
mqc_setstate(mqc, T1_CTXNO_AGG, 0, 3); opj_mqc_setstate(mqc, T1_CTXNO_AGG, 0, 3);
mqc_setstate(mqc, T1_CTXNO_ZC, 0, 4); opj_mqc_setstate(mqc, T1_CTXNO_ZC, 0, 4);
for (segno = 0; segno < cblk->real_num_segs; ++segno) { for (segno = 0; segno < cblk->real_num_segs; ++segno) {
opj_tcd_seg_t *seg = &cblk->segs[segno]; opj_tcd_seg_t *seg = &cblk->segs[segno];
@ -1022,7 +1022,7 @@ opj_bool opj_t1_decode_cblk(opj_t1_t *t1,
if (type == T1_TYPE_RAW) { if (type == T1_TYPE_RAW) {
raw_init_dec(raw, (*seg->data) + seg->dataindex, seg->len); raw_init_dec(raw, (*seg->data) + seg->dataindex, seg->len);
} else { } else {
if (OPJ_FALSE == mqc_init_dec(mqc, (*seg->data) + seg->dataindex, seg->len)) { if (OPJ_FALSE == opj_mqc_init_dec(mqc, (*seg->data) + seg->dataindex, seg->len)) {
return OPJ_FALSE; return OPJ_FALSE;
} }
} }
@ -1041,10 +1041,10 @@ opj_bool opj_t1_decode_cblk(opj_t1_t *t1,
} }
if ((cblksty & J2K_CCP_CBLKSTY_RESET) && type == T1_TYPE_MQ) { if ((cblksty & J2K_CCP_CBLKSTY_RESET) && type == T1_TYPE_MQ) {
mqc_resetstates(mqc); opj_mqc_resetstates(mqc);
mqc_setstate(mqc, T1_CTXNO_UNI, 0, 46); opj_mqc_setstate(mqc, T1_CTXNO_UNI, 0, 46);
mqc_setstate(mqc, T1_CTXNO_AGG, 0, 3); opj_mqc_setstate(mqc, T1_CTXNO_AGG, 0, 3);
mqc_setstate(mqc, T1_CTXNO_ZC, 0, 4); opj_mqc_setstate(mqc, T1_CTXNO_ZC, 0, 4);
} }
if (++passtype == 3) { if (++passtype == 3) {
passtype = 0; passtype = 0;
@ -1189,11 +1189,11 @@ void opj_t1_encode_cblk(opj_t1_t *t1,
bpno = cblk->numbps - 1; bpno = cblk->numbps - 1;
passtype = 2; passtype = 2;
mqc_resetstates(mqc); opj_mqc_resetstates(mqc);
mqc_setstate(mqc, T1_CTXNO_UNI, 0, 46); opj_mqc_setstate(mqc, T1_CTXNO_UNI, 0, 46);
mqc_setstate(mqc, T1_CTXNO_AGG, 0, 3); opj_mqc_setstate(mqc, T1_CTXNO_AGG, 0, 3);
mqc_setstate(mqc, T1_CTXNO_ZC, 0, 4); opj_mqc_setstate(mqc, T1_CTXNO_ZC, 0, 4);
mqc_init_enc(mqc, cblk->data); opj_mqc_init_enc(mqc, cblk->data);
for (passno = 0; bpno >= 0; ++passno) { for (passno = 0; bpno >= 0; ++passno) {
opj_tcd_pass_v2_t *pass = &cblk->passes[passno]; opj_tcd_pass_v2_t *pass = &cblk->passes[passno];
@ -1211,7 +1211,7 @@ void opj_t1_encode_cblk(opj_t1_t *t1,
opj_t1_enc_clnpass(t1, bpno, orient, &nmsedec, cblksty); opj_t1_enc_clnpass(t1, bpno, orient, &nmsedec, cblksty);
/* code switch SEGMARK (i.e. SEGSYM) */ /* code switch SEGMARK (i.e. SEGSYM) */
if (cblksty & J2K_CCP_CBLKSTY_SEGSYM) if (cblksty & J2K_CCP_CBLKSTY_SEGSYM)
mqc_segmark_enc(mqc); opj_mqc_segmark_enc(mqc);
break; break;
} }
@ -1223,11 +1223,11 @@ void opj_t1_encode_cblk(opj_t1_t *t1,
/* Code switch "RESTART" (i.e. TERMALL) */ /* Code switch "RESTART" (i.e. TERMALL) */
if ((cblksty & J2K_CCP_CBLKSTY_TERMALL) && !((passtype == 2) && (bpno - 1 < 0))) { if ((cblksty & J2K_CCP_CBLKSTY_TERMALL) && !((passtype == 2) && (bpno - 1 < 0))) {
if (type == T1_TYPE_RAW) { if (type == T1_TYPE_RAW) {
mqc_flush(mqc); opj_mqc_flush(mqc);
correction = 1; correction = 1;
/* correction = mqc_bypass_flush_enc(); */ /* correction = mqc_bypass_flush_enc(); */
} else { /* correction = mqc_restart_enc(); */ } else { /* correction = mqc_restart_enc(); */
mqc_flush(mqc); opj_mqc_flush(mqc);
correction = 1; correction = 1;
} }
pass->term = 1; pass->term = 1;
@ -1235,11 +1235,11 @@ void opj_t1_encode_cblk(opj_t1_t *t1,
if (((bpno < ((OPJ_INT32) (cblk->numbps) - 4) && (passtype > 0)) if (((bpno < ((OPJ_INT32) (cblk->numbps) - 4) && (passtype > 0))
|| ((bpno == (cblk->numbps - 4)) && (passtype == 2))) && (cblksty & J2K_CCP_CBLKSTY_LAZY)) { || ((bpno == (cblk->numbps - 4)) && (passtype == 2))) && (cblksty & J2K_CCP_CBLKSTY_LAZY)) {
if (type == T1_TYPE_RAW) { if (type == T1_TYPE_RAW) {
mqc_flush(mqc); opj_mqc_flush(mqc);
correction = 1; correction = 1;
/* correction = mqc_bypass_flush_enc(); */ /* correction = mqc_bypass_flush_enc(); */
} else { /* correction = mqc_restart_enc(); */ } else { /* correction = mqc_restart_enc(); */
mqc_flush(mqc); opj_mqc_flush(mqc);
correction = 1; correction = 1;
} }
pass->term = 1; pass->term = 1;
@ -1256,31 +1256,31 @@ void opj_t1_encode_cblk(opj_t1_t *t1,
if (pass->term && bpno > 0) { if (pass->term && bpno > 0) {
type = ((bpno < ((OPJ_INT32) (cblk->numbps) - 4)) && (passtype < 2) && (cblksty & J2K_CCP_CBLKSTY_LAZY)) ? T1_TYPE_RAW : T1_TYPE_MQ; type = ((bpno < ((OPJ_INT32) (cblk->numbps) - 4)) && (passtype < 2) && (cblksty & J2K_CCP_CBLKSTY_LAZY)) ? T1_TYPE_RAW : T1_TYPE_MQ;
if (type == T1_TYPE_RAW) if (type == T1_TYPE_RAW)
mqc_bypass_init_enc(mqc); opj_mqc_bypass_init_enc(mqc);
else else
mqc_restart_init_enc(mqc); opj_mqc_restart_init_enc(mqc);
} }
pass->distortiondec = cumwmsedec; pass->distortiondec = cumwmsedec;
pass->rate = mqc_numbytes(mqc) + correction; /* FIXME */ pass->rate = opj_mqc_numbytes(mqc) + correction; /* FIXME */
/* Code-switch "RESET" */ /* Code-switch "RESET" */
if (cblksty & J2K_CCP_CBLKSTY_RESET) if (cblksty & J2K_CCP_CBLKSTY_RESET)
mqc_reset_enc(mqc); opj_mqc_reset_enc(mqc);
} }
/* Code switch "ERTERM" (i.e. PTERM) */ /* Code switch "ERTERM" (i.e. PTERM) */
if (cblksty & J2K_CCP_CBLKSTY_PTERM) if (cblksty & J2K_CCP_CBLKSTY_PTERM)
mqc_erterm_enc(mqc); opj_mqc_erterm_enc(mqc);
else /* Default coding */ if (!(cblksty & J2K_CCP_CBLKSTY_LAZY)) else /* Default coding */ if (!(cblksty & J2K_CCP_CBLKSTY_LAZY))
mqc_flush(mqc); opj_mqc_flush(mqc);
cblk->totalpasses = passno; cblk->totalpasses = passno;
for (passno = 0; passno<cblk->totalpasses; passno++) { for (passno = 0; passno<cblk->totalpasses; passno++) {
opj_tcd_pass_v2_t *pass = &cblk->passes[passno]; opj_tcd_pass_v2_t *pass = &cblk->passes[passno];
if (pass->rate > mqc_numbytes(mqc)) if (pass->rate > opj_mqc_numbytes(mqc))
pass->rate = mqc_numbytes(mqc); pass->rate = opj_mqc_numbytes(mqc);
/*Preventing generation of FF as last data byte of a pass*/ /*Preventing generation of FF as last data byte of a pass*/
if((pass->rate>1) && (cblk->data[pass->rate - 1] == 0xFF)){ if((pass->rate>1) && (cblk->data[pass->rate - 1] == 0xFF)){
pass->rate--; pass->rate--;
@ -1334,11 +1334,11 @@ void opj_t1_dec_refpass_step( opj_t1_t *t1,
flag = vsc ? ((*flagsp) & (~(T1_SIG_S | T1_SIG_SE | T1_SIG_SW | T1_SGN_S))) : (*flagsp); flag = vsc ? ((*flagsp) & (~(T1_SIG_S | T1_SIG_SE | T1_SIG_SW | T1_SGN_S))) : (*flagsp);
if ((flag & (T1_SIG | T1_VISIT)) == T1_SIG) { if ((flag & (T1_SIG | T1_VISIT)) == T1_SIG) {
mqc_setcurctx(mqc, opj_t1_getctxno_mag(flag)); /* ESSAI */ opj_mqc_setcurctx(mqc, opj_t1_getctxno_mag(flag)); /* ESSAI */
if (type == T1_TYPE_RAW) { if (type == T1_TYPE_RAW) {
v = raw_decode(raw); v = raw_decode(raw);
} else { } else {
v = mqc_decode(mqc); v = opj_mqc_decode(mqc);
} }
t = v ? poshalf : neghalf; t = v ? poshalf : neghalf;
*datap += *datap < 0 ? -t : t; *datap += *datap < 0 ? -t : t;
@ -1396,10 +1396,10 @@ void opj_t1_dec_sigpass_step( opj_t1_t *t1,
opj_t1_updateflags(flagsp, v, t1->flags_stride); opj_t1_updateflags(flagsp, v, t1->flags_stride);
} }
} else { } else {
mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_zc(flag, orient));
if (mqc_decode(mqc)) { if (opj_mqc_decode(mqc)) {
mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag)); opj_mqc_setcurctx(mqc, opj_t1_getctxno_sc(flag));
v = mqc_decode(mqc) ^ opj_t1_getspb(flag); v = opj_mqc_decode(mqc) ^ opj_t1_getspb(flag);
*datap = v ? -oneplushalf : oneplushalf; *datap = v ? -oneplushalf : oneplushalf;
opj_t1_updateflags(flagsp, v, t1->flags_stride); opj_t1_updateflags(flagsp, v, t1->flags_stride);
} }