/src/libjpeg-turbo.main/jdarith.c
| Line | Count | Source (jump to first uncovered line) | 
| 1 |  | /* | 
| 2 |  |  * jdarith.c | 
| 3 |  |  * | 
| 4 |  |  * This file was part of the Independent JPEG Group's software: | 
| 5 |  |  * Developed 1997-2015 by Guido Vollbeding. | 
| 6 |  |  * libjpeg-turbo Modifications: | 
| 7 |  |  * Copyright (C) 2015-2020, 2022, D. R. Commander. | 
| 8 |  |  * For conditions of distribution and use, see the accompanying README.ijg | 
| 9 |  |  * file. | 
| 10 |  |  * | 
| 11 |  |  * This file contains portable arithmetic entropy encoding routines for JPEG | 
| 12 |  |  * (implementing Recommendation ITU-T T.81 | ISO/IEC 10918-1). | 
| 13 |  |  * | 
| 14 |  |  * Both sequential and progressive modes are supported in this single module. | 
| 15 |  |  * | 
| 16 |  |  * Suspension is not currently supported in this module. | 
| 17 |  |  * | 
| 18 |  |  * NOTE: All referenced figures are from | 
| 19 |  |  * Recommendation ITU-T T.81 (1992) | ISO/IEC 10918-1:1994. | 
| 20 |  |  */ | 
| 21 |  |  | 
| 22 |  | #define JPEG_INTERNALS | 
| 23 |  | #include "jinclude.h" | 
| 24 |  | #include "jpeglib.h" | 
| 25 |  |  | 
| 26 |  |  | 
| 27 | 8.22M | #define NEG_1  ((unsigned int)-1) | 
| 28 |  |  | 
| 29 |  |  | 
| 30 |  | /* Expanded entropy decoder object for arithmetic decoding. */ | 
| 31 |  |  | 
| 32 |  | typedef struct { | 
| 33 |  |   struct jpeg_entropy_decoder pub; /* public fields */ | 
| 34 |  |  | 
| 35 |  |   JLONG c;       /* C register, base of coding interval + input bit buffer */ | 
| 36 |  |   JLONG a;               /* A register, normalized size of coding interval */ | 
| 37 |  |   int ct;     /* bit shift counter, # of bits left in bit buffer part of C */ | 
| 38 |  |                                                          /* init: ct = -16 */ | 
| 39 |  |                                                          /* run: ct = 0..7 */ | 
| 40 |  |                                                          /* error: ct = -1 */ | 
| 41 |  |   int last_dc_val[MAX_COMPS_IN_SCAN]; /* last DC coef for each component */ | 
| 42 |  |   int dc_context[MAX_COMPS_IN_SCAN]; /* context index for DC conditioning */ | 
| 43 |  |  | 
| 44 |  |   unsigned int restarts_to_go;  /* MCUs left in this restart interval */ | 
| 45 |  |  | 
| 46 |  |   /* Pointers to statistics areas (these workspaces have image lifespan) */ | 
| 47 |  |   unsigned char *dc_stats[NUM_ARITH_TBLS]; | 
| 48 |  |   unsigned char *ac_stats[NUM_ARITH_TBLS]; | 
| 49 |  |  | 
| 50 |  |   /* Statistics bin for coding with fixed probability 0.5 */ | 
| 51 |  |   unsigned char fixed_bin[4]; | 
| 52 |  | } arith_entropy_decoder; | 
| 53 |  |  | 
| 54 |  | typedef arith_entropy_decoder *arith_entropy_ptr; | 
| 55 |  |  | 
| 56 |  | /* The following two definitions specify the allocation chunk size | 
| 57 |  |  * for the statistics area. | 
| 58 |  |  * According to sections F.1.4.4.1.3 and F.1.4.4.2, we need at least | 
| 59 |  |  * 49 statistics bins for DC, and 245 statistics bins for AC coding. | 
| 60 |  |  * | 
| 61 |  |  * We use a compact representation with 1 byte per statistics bin, | 
| 62 |  |  * thus the numbers directly represent byte sizes. | 
| 63 |  |  * This 1 byte per statistics bin contains the meaning of the MPS | 
| 64 |  |  * (more probable symbol) in the highest bit (mask 0x80), and the | 
| 65 |  |  * index into the probability estimation state machine table | 
| 66 |  |  * in the lower bits (mask 0x7F). | 
| 67 |  |  */ | 
| 68 |  |  | 
| 69 | 143k | #define DC_STAT_BINS  64 | 
| 70 | 7.13M | #define AC_STAT_BINS  256 | 
| 71 |  |  | 
| 72 |  |  | 
| 73 |  | LOCAL(int) | 
| 74 |  | get_byte(j_decompress_ptr cinfo) | 
| 75 |  | /* Read next input byte; we do not support suspension in this module. */ | 
| 76 | 83.5k | { | 
| 77 | 83.5k |   struct jpeg_source_mgr *src = cinfo->src; | 
| 78 |  |  | 
| 79 | 83.5k |   if (src->bytes_in_buffer == 0) | 
| 80 | 841 |     if (!(*src->fill_input_buffer) (cinfo)) | 
| 81 | 0 |       ERREXIT(cinfo, JERR_CANT_SUSPEND); | 
| 82 | 83.5k |   src->bytes_in_buffer--; | 
| 83 | 83.5k |   return *src->next_input_byte++; | 
| 84 | 83.5k | } | 
| 85 |  |  | 
| 86 |  |  | 
| 87 |  | /* | 
| 88 |  |  * The core arithmetic decoding routine (common in JPEG and JBIG). | 
| 89 |  |  * This needs to go as fast as possible. | 
| 90 |  |  * Machine-dependent optimization facilities | 
| 91 |  |  * are not utilized in this portable implementation. | 
| 92 |  |  * However, this code should be fairly efficient and | 
| 93 |  |  * may be a good base for further optimizations anyway. | 
| 94 |  |  * | 
| 95 |  |  * Return value is 0 or 1 (binary decision). | 
| 96 |  |  * | 
| 97 |  |  * Note: I've changed the handling of the code base & bit | 
| 98 |  |  * buffer register C compared to other implementations | 
| 99 |  |  * based on the standards layout & procedures. | 
| 100 |  |  * While it also contains both the actual base of the | 
| 101 |  |  * coding interval (16 bits) and the next-bits buffer, | 
| 102 |  |  * the cut-point between these two parts is floating | 
| 103 |  |  * (instead of fixed) with the bit shift counter CT. | 
| 104 |  |  * Thus, we also need only one (variable instead of | 
| 105 |  |  * fixed size) shift for the LPS/MPS decision, and | 
| 106 |  |  * we can do away with any renormalization update | 
| 107 |  |  * of C (except for new data insertion, of course). | 
| 108 |  |  * | 
| 109 |  |  * I've also introduced a new scheme for accessing | 
| 110 |  |  * the probability estimation state machine table, | 
| 111 |  |  * derived from Markus Kuhn's JBIG implementation. | 
| 112 |  |  */ | 
| 113 |  |  | 
| 114 |  | LOCAL(int) | 
| 115 |  | arith_decode(j_decompress_ptr cinfo, unsigned char *st) | 
| 116 | 246M | { | 
| 117 | 246M |   register arith_entropy_ptr e = (arith_entropy_ptr)cinfo->entropy; | 
| 118 | 246M |   register unsigned char nl, nm; | 
| 119 | 246M |   register JLONG qe, temp; | 
| 120 | 246M |   register int sv, data; | 
| 121 |  |  | 
| 122 |  |   /* Renormalization & data input per section D.2.6 */ | 
| 123 | 353M |   while (e->a < 0x8000L) { | 
| 124 | 106M |     if (--e->ct < 0) { | 
| 125 |  |       /* Need to fetch next data byte */ | 
| 126 | 28.8M |       if (cinfo->unread_marker) | 
| 127 | 28.8M |         data = 0;               /* stuff zero data */ | 
| 128 | 71.2k |       else { | 
| 129 | 71.2k |         data = get_byte(cinfo); /* read next input byte */ | 
| 130 | 71.2k |         if (data == 0xFF) {     /* zero stuff or marker code */ | 
| 131 | 12.3k |           do data = get_byte(cinfo); | 
| 132 | 12.3k |           while (data == 0xFF); /* swallow extra 0xFF bytes */ | 
| 133 | 10.5k |           if (data == 0) | 
| 134 | 986 |             data = 0xFF;        /* discard stuffed zero byte */ | 
| 135 | 9.54k |           else { | 
| 136 |  |             /* Note: Different from the Huffman decoder, hitting | 
| 137 |  |              * a marker while processing the compressed data | 
| 138 |  |              * segment is legal in arithmetic coding. | 
| 139 |  |              * The convention is to supply zero data | 
| 140 |  |              * then until decoding is complete. | 
| 141 |  |              */ | 
| 142 | 9.54k |             cinfo->unread_marker = data; | 
| 143 | 9.54k |             data = 0; | 
| 144 | 9.54k |           } | 
| 145 | 10.5k |         } | 
| 146 | 71.2k |       } | 
| 147 | 28.8M |       e->c = (e->c << 8) | data; /* insert data into C register */ | 
| 148 | 28.8M |       if ((e->ct += 8) < 0)      /* update bit shift counter */ | 
| 149 |  |         /* Need more initial bytes */ | 
| 150 | 14.3M |         if (++e->ct == 0) | 
| 151 |  |           /* Got 2 initial bytes -> re-init A and exit loop */ | 
| 152 | 7.16M |           e->a = 0x8000L; /* => e->a = 0x10000L after loop exit */ | 
| 153 | 28.8M |     } | 
| 154 | 106M |     e->a <<= 1; | 
| 155 | 106M |   } | 
| 156 |  |  | 
| 157 |  |   /* Fetch values from our compact representation of Table D.2: | 
| 158 |  |    * Qe values and probability estimation state machine | 
| 159 |  |    */ | 
| 160 | 246M |   sv = *st; | 
| 161 | 246M |   qe = jpeg_aritab[sv & 0x7F];  /* => Qe_Value */ | 
| 162 | 246M |   nl = qe & 0xFF;  qe >>= 8;    /* Next_Index_LPS + Switch_MPS */ | 
| 163 | 246M |   nm = qe & 0xFF;  qe >>= 8;    /* Next_Index_MPS */ | 
| 164 |  |  | 
| 165 |  |   /* Decode & estimation procedures per sections D.2.4 & D.2.5 */ | 
| 166 | 246M |   temp = e->a - qe; | 
| 167 | 246M |   e->a = temp; | 
| 168 | 246M |   temp <<= e->ct; | 
| 169 | 246M |   if (e->c >= temp) { | 
| 170 | 3.63M |     e->c -= temp; | 
| 171 |  |     /* Conditional LPS (less probable symbol) exchange */ | 
| 172 | 3.63M |     if (e->a < qe) { | 
| 173 | 967k |       e->a = qe; | 
| 174 | 967k |       *st = (sv & 0x80) ^ nm;   /* Estimate_after_MPS */ | 
| 175 | 2.66M |     } else { | 
| 176 | 2.66M |       e->a = qe; | 
| 177 | 2.66M |       *st = (sv & 0x80) ^ nl;   /* Estimate_after_LPS */ | 
| 178 | 2.66M |       sv ^= 0x80;               /* Exchange LPS/MPS */ | 
| 179 | 2.66M |     } | 
| 180 | 243M |   } else if (e->a < 0x8000L) { | 
| 181 |  |     /* Conditional MPS (more probable symbol) exchange */ | 
| 182 | 66.4M |     if (e->a < qe) { | 
| 183 | 49.4M |       *st = (sv & 0x80) ^ nl;   /* Estimate_after_LPS */ | 
| 184 | 49.4M |       sv ^= 0x80;               /* Exchange LPS/MPS */ | 
| 185 | 49.4M |     } else { | 
| 186 | 16.9M |       *st = (sv & 0x80) ^ nm;   /* Estimate_after_MPS */ | 
| 187 | 16.9M |     } | 
| 188 | 66.4M |   } | 
| 189 |  |  | 
| 190 | 246M |   return sv >> 7; | 
| 191 | 246M | } | 
| 192 |  |  | 
| 193 |  |  | 
| 194 |  | /* | 
| 195 |  |  * Check for a restart marker & resynchronize decoder. | 
| 196 |  |  */ | 
| 197 |  |  | 
| 198 |  | LOCAL(void) | 
| 199 |  | process_restart(j_decompress_ptr cinfo) | 
| 200 | 7.15M | { | 
| 201 | 7.15M |   arith_entropy_ptr entropy = (arith_entropy_ptr)cinfo->entropy; | 
| 202 | 7.15M |   int ci; | 
| 203 | 7.15M |   jpeg_component_info *compptr; | 
| 204 |  |  | 
| 205 |  |   /* Advance past the RSTn marker */ | 
| 206 | 7.15M |   if (!(*cinfo->marker->read_restart_marker) (cinfo)) | 
| 207 | 0 |     ERREXIT(cinfo, JERR_CANT_SUSPEND); | 
| 208 |  |  | 
| 209 |  |   /* Re-initialize statistics areas */ | 
| 210 | 14.3M |   for (ci = 0; ci < cinfo->comps_in_scan; ci++) { | 
| 211 | 7.20M |     compptr = cinfo->cur_comp_info[ci]; | 
| 212 | 7.20M |     if (!cinfo->progressive_mode || (cinfo->Ss == 0 && cinfo->Ah == 0)) { | 
| 213 | 129k |       memset(entropy->dc_stats[compptr->dc_tbl_no], 0, DC_STAT_BINS); | 
| 214 |  |       /* Reset DC predictions to 0 */ | 
| 215 | 129k |       entropy->last_dc_val[ci] = 0; | 
| 216 | 129k |       entropy->dc_context[ci] = 0; | 
| 217 | 129k |     } | 
| 218 | 7.20M |     if (!cinfo->progressive_mode || cinfo->Ss) { | 
| 219 | 7.12M |       memset(entropy->ac_stats[compptr->ac_tbl_no], 0, AC_STAT_BINS); | 
| 220 | 7.12M |     } | 
| 221 | 7.20M |   } | 
| 222 |  |  | 
| 223 |  |   /* Reset arithmetic decoding variables */ | 
| 224 | 7.15M |   entropy->c = 0; | 
| 225 | 7.15M |   entropy->a = 0; | 
| 226 | 7.15M |   entropy->ct = -16;    /* force reading 2 initial bytes to fill C */ | 
| 227 |  |  | 
| 228 |  |   /* Reset restart counter */ | 
| 229 | 7.15M |   entropy->restarts_to_go = cinfo->restart_interval; | 
| 230 | 7.15M | } | 
| 231 |  |  | 
| 232 |  |  | 
| 233 |  | /* | 
| 234 |  |  * Arithmetic MCU decoding. | 
| 235 |  |  * Each of these routines decodes and returns one MCU's worth of | 
| 236 |  |  * arithmetic-compressed coefficients. | 
| 237 |  |  * The coefficients are reordered from zigzag order into natural array order, | 
| 238 |  |  * but are not dequantized. | 
| 239 |  |  * | 
| 240 |  |  * The i'th block of the MCU is stored into the block pointed to by | 
| 241 |  |  * MCU_data[i].  WE ASSUME THIS AREA IS INITIALLY ZEROED BY THE CALLER. | 
| 242 |  |  */ | 
| 243 |  |  | 
| 244 |  | /* | 
| 245 |  |  * MCU decoding for DC initial scan (either spectral selection, | 
| 246 |  |  * or first pass of successive approximation). | 
| 247 |  |  */ | 
| 248 |  |  | 
| 249 |  | METHODDEF(boolean) | 
| 250 |  | decode_mcu_DC_first(j_decompress_ptr cinfo, JBLOCKROW *MCU_data) | 
| 251 | 18.6M | { | 
| 252 | 18.6M |   arith_entropy_ptr entropy = (arith_entropy_ptr)cinfo->entropy; | 
| 253 | 18.6M |   JBLOCKROW block; | 
| 254 | 18.6M |   unsigned char *st; | 
| 255 | 18.6M |   int blkn, ci, tbl, sign; | 
| 256 | 18.6M |   int v, m; | 
| 257 |  |  | 
| 258 |  |   /* Process restart marker if needed */ | 
| 259 | 18.6M |   if (cinfo->restart_interval) { | 
| 260 | 853k |     if (entropy->restarts_to_go == 0) | 
| 261 | 44.6k |       process_restart(cinfo); | 
| 262 | 853k |     entropy->restarts_to_go--; | 
| 263 | 853k |   } | 
| 264 |  |  | 
| 265 | 18.6M |   if (entropy->ct == -1) return TRUE;   /* if error do nothing */ | 
| 266 |  |  | 
| 267 |  |   /* Outer loop handles each block in the MCU */ | 
| 268 |  |  | 
| 269 | 46.0M |   for (blkn = 0; blkn < cinfo->blocks_in_MCU; blkn++) { | 
| 270 | 28.7M |     block = MCU_data[blkn]; | 
| 271 | 28.7M |     ci = cinfo->MCU_membership[blkn]; | 
| 272 | 28.7M |     tbl = cinfo->cur_comp_info[ci]->dc_tbl_no; | 
| 273 |  |  | 
| 274 |  |     /* Sections F.2.4.1 & F.1.4.4.1: Decoding of DC coefficients */ | 
| 275 |  |  | 
| 276 |  |     /* Table F.4: Point to statistics bin S0 for DC coefficient coding */ | 
| 277 | 28.7M |     st = entropy->dc_stats[tbl] + entropy->dc_context[ci]; | 
| 278 |  |  | 
| 279 |  |     /* Figure F.19: Decode_DC_DIFF */ | 
| 280 | 28.7M |     if (arith_decode(cinfo, st) == 0) | 
| 281 | 12.8M |       entropy->dc_context[ci] = 0; | 
| 282 | 15.9M |     else { | 
| 283 |  |       /* Figure F.21: Decoding nonzero value v */ | 
| 284 |  |       /* Figure F.22: Decoding the sign of v */ | 
| 285 | 15.9M |       sign = arith_decode(cinfo, st + 1); | 
| 286 | 15.9M |       st += 2;  st += sign; | 
| 287 |  |       /* Figure F.23: Decoding the magnitude category of v */ | 
| 288 | 15.9M |       if ((m = arith_decode(cinfo, st)) != 0) { | 
| 289 | 11.8M |         st = entropy->dc_stats[tbl] + 20;       /* Table F.4: X1 = 20 */ | 
| 290 | 27.1M |         while (arith_decode(cinfo, st)) { | 
| 291 | 15.3M |           if ((m <<= 1) == 0x8000) { | 
| 292 | 205 |             WARNMS(cinfo, JWRN_ARITH_BAD_CODE); | 
| 293 | 205 |             entropy->ct = -1;                   /* magnitude overflow */ | 
| 294 | 205 |             return TRUE; | 
| 295 | 205 |           } | 
| 296 | 15.3M |           st += 1; | 
| 297 | 15.3M |         } | 
| 298 | 11.8M |       } | 
| 299 |  |       /* Section F.1.4.4.1.2: Establish dc_context conditioning category */ | 
| 300 | 15.9M |       if (m < (int)((1L << cinfo->arith_dc_L[tbl]) >> 1)) | 
| 301 | 22.7k |         entropy->dc_context[ci] = 0;               /* zero diff category */ | 
| 302 | 15.8M |       else if (m > (int)((1L << cinfo->arith_dc_U[tbl]) >> 1)) | 
| 303 | 11.4M |         entropy->dc_context[ci] = 12 + (sign * 4); /* large diff category */ | 
| 304 | 4.42M |       else | 
| 305 | 4.42M |         entropy->dc_context[ci] = 4 + (sign * 4);  /* small diff category */ | 
| 306 | 15.9M |       v = m; | 
| 307 |  |       /* Figure F.24: Decoding the magnitude bit pattern of v */ | 
| 308 | 15.9M |       st += 14; | 
| 309 | 31.2M |       while (m >>= 1) | 
| 310 | 15.3M |         if (arith_decode(cinfo, st)) v |= m; | 
| 311 | 15.9M |       v += 1;  if (sign) v = -v; | 
| 312 | 15.9M |       entropy->last_dc_val[ci] = (entropy->last_dc_val[ci] + v) & 0xffff; | 
| 313 | 15.9M |     } | 
| 314 |  |  | 
| 315 |  |     /* Scale and output the DC coefficient (assumes jpeg_natural_order[0]=0) */ | 
| 316 | 28.7M |     (*block)[0] = (JCOEF)LEFT_SHIFT(entropy->last_dc_val[ci], cinfo->Al); | 
| 317 | 28.7M |   } | 
| 318 |  |  | 
| 319 | 17.3M |   return TRUE; | 
| 320 | 17.3M | } | 
| 321 |  |  | 
| 322 |  |  | 
| 323 |  | /* | 
| 324 |  |  * MCU decoding for AC initial scan (either spectral selection, | 
| 325 |  |  * or first pass of successive approximation). | 
| 326 |  |  */ | 
| 327 |  |  | 
| 328 |  | METHODDEF(boolean) | 
| 329 |  | decode_mcu_AC_first(j_decompress_ptr cinfo, JBLOCKROW *MCU_data) | 
| 330 | 6.19M | { | 
| 331 | 6.19M |   arith_entropy_ptr entropy = (arith_entropy_ptr)cinfo->entropy; | 
| 332 | 6.19M |   JBLOCKROW block; | 
| 333 | 6.19M |   unsigned char *st; | 
| 334 | 6.19M |   int tbl, sign, k; | 
| 335 | 6.19M |   int v, m; | 
| 336 |  |  | 
| 337 |  |   /* Process restart marker if needed */ | 
| 338 | 6.19M |   if (cinfo->restart_interval) { | 
| 339 | 1.69M |     if (entropy->restarts_to_go == 0) | 
| 340 | 161k |       process_restart(cinfo); | 
| 341 | 1.69M |     entropy->restarts_to_go--; | 
| 342 | 1.69M |   } | 
| 343 |  |  | 
| 344 | 6.19M |   if (entropy->ct == -1) return TRUE;   /* if error do nothing */ | 
| 345 |  |  | 
| 346 |  |   /* There is always only one block per MCU */ | 
| 347 | 5.47M |   block = MCU_data[0]; | 
| 348 | 5.47M |   tbl = cinfo->cur_comp_info[0]->ac_tbl_no; | 
| 349 |  |  | 
| 350 |  |   /* Sections F.2.4.2 & F.1.4.4.2: Decoding of AC coefficients */ | 
| 351 |  |  | 
| 352 |  |   /* Figure F.20: Decode_AC_coefficients */ | 
| 353 | 6.44M |   for (k = cinfo->Ss; k <= cinfo->Se; k++) { | 
| 354 | 6.41M |     st = entropy->ac_stats[tbl] + 3 * (k - 1); | 
| 355 | 6.41M |     if (arith_decode(cinfo, st)) break;         /* EOB flag */ | 
| 356 | 1.75M |     while (arith_decode(cinfo, st + 1) == 0) { | 
| 357 | 791k |       st += 3;  k++; | 
| 358 | 791k |       if (k > cinfo->Se) { | 
| 359 | 493 |         WARNMS(cinfo, JWRN_ARITH_BAD_CODE); | 
| 360 | 493 |         entropy->ct = -1;                       /* spectral overflow */ | 
| 361 | 493 |         return TRUE; | 
| 362 | 493 |       } | 
| 363 | 791k |     } | 
| 364 |  |     /* Figure F.21: Decoding nonzero value v */ | 
| 365 |  |     /* Figure F.22: Decoding the sign of v */ | 
| 366 | 967k |     sign = arith_decode(cinfo, entropy->fixed_bin); | 
| 367 | 967k |     st += 2; | 
| 368 |  |     /* Figure F.23: Decoding the magnitude category of v */ | 
| 369 | 967k |     if ((m = arith_decode(cinfo, st)) != 0) { | 
| 370 | 476k |       if (arith_decode(cinfo, st)) { | 
| 371 | 379k |         m <<= 1; | 
| 372 | 379k |         st = entropy->ac_stats[tbl] + | 
| 373 | 379k |              (k <= cinfo->arith_ac_K[tbl] ? 189 : 217); | 
| 374 | 832k |         while (arith_decode(cinfo, st)) { | 
| 375 | 453k |           if ((m <<= 1) == 0x8000) { | 
| 376 | 194 |             WARNMS(cinfo, JWRN_ARITH_BAD_CODE); | 
| 377 | 194 |             entropy->ct = -1;                   /* magnitude overflow */ | 
| 378 | 194 |             return TRUE; | 
| 379 | 194 |           } | 
| 380 | 453k |           st += 1; | 
| 381 | 453k |         } | 
| 382 | 379k |       } | 
| 383 | 476k |     } | 
| 384 | 966k |     v = m; | 
| 385 |  |     /* Figure F.24: Decoding the magnitude bit pattern of v */ | 
| 386 | 966k |     st += 14; | 
| 387 | 1.79M |     while (m >>= 1) | 
| 388 | 829k |       if (arith_decode(cinfo, st)) v |= m; | 
| 389 | 966k |     v += 1;  if (sign) v = -v; | 
| 390 |  |     /* Scale and output coefficient in natural (dezigzagged) order */ | 
| 391 | 966k |     (*block)[jpeg_natural_order[k]] = (JCOEF)((unsigned)v << cinfo->Al); | 
| 392 | 966k |   } | 
| 393 |  |  | 
| 394 | 5.47M |   return TRUE; | 
| 395 | 5.47M | } | 
| 396 |  |  | 
| 397 |  |  | 
| 398 |  | /* | 
| 399 |  |  * MCU decoding for DC successive approximation refinement scan. | 
| 400 |  |  */ | 
| 401 |  |  | 
| 402 |  | METHODDEF(boolean) | 
| 403 |  | decode_mcu_DC_refine(j_decompress_ptr cinfo, JBLOCKROW *MCU_data) | 
| 404 | 1.78M | { | 
| 405 | 1.78M |   arith_entropy_ptr entropy = (arith_entropy_ptr)cinfo->entropy; | 
| 406 | 1.78M |   unsigned char *st; | 
| 407 | 1.78M |   int p1, blkn; | 
| 408 |  |  | 
| 409 |  |   /* Process restart marker if needed */ | 
| 410 | 1.78M |   if (cinfo->restart_interval) { | 
| 411 | 98.1k |     if (entropy->restarts_to_go == 0) | 
| 412 | 7.98k |       process_restart(cinfo); | 
| 413 | 98.1k |     entropy->restarts_to_go--; | 
| 414 | 98.1k |   } | 
| 415 |  |  | 
| 416 | 1.78M |   st = entropy->fixed_bin;      /* use fixed probability estimation */ | 
| 417 | 1.78M |   p1 = 1 << cinfo->Al;          /* 1 in the bit position being coded */ | 
| 418 |  |  | 
| 419 |  |   /* Outer loop handles each block in the MCU */ | 
| 420 |  |  | 
| 421 | 3.96M |   for (blkn = 0; blkn < cinfo->blocks_in_MCU; blkn++) { | 
| 422 |  |     /* Encoded data is simply the next bit of the two's-complement DC value */ | 
| 423 | 2.18M |     if (arith_decode(cinfo, st)) | 
| 424 | 1.18M |       MCU_data[blkn][0][0] |= p1; | 
| 425 | 2.18M |   } | 
| 426 |  |  | 
| 427 | 1.78M |   return TRUE; | 
| 428 | 1.78M | } | 
| 429 |  |  | 
| 430 |  |  | 
| 431 |  | /* | 
| 432 |  |  * MCU decoding for AC successive approximation refinement scan. | 
| 433 |  |  */ | 
| 434 |  |  | 
| 435 |  | METHODDEF(boolean) | 
| 436 |  | decode_mcu_AC_refine(j_decompress_ptr cinfo, JBLOCKROW *MCU_data) | 
| 437 | 8.79M | { | 
| 438 | 8.79M |   arith_entropy_ptr entropy = (arith_entropy_ptr)cinfo->entropy; | 
| 439 | 8.79M |   JBLOCKROW block; | 
| 440 | 8.79M |   JCOEFPTR thiscoef; | 
| 441 | 8.79M |   unsigned char *st; | 
| 442 | 8.79M |   int tbl, k, kex; | 
| 443 | 8.79M |   int p1, m1; | 
| 444 |  |  | 
| 445 |  |   /* Process restart marker if needed */ | 
| 446 | 8.79M |   if (cinfo->restart_interval) { | 
| 447 | 7.20M |     if (entropy->restarts_to_go == 0) | 
| 448 | 6.89M |       process_restart(cinfo); | 
| 449 | 7.20M |     entropy->restarts_to_go--; | 
| 450 | 7.20M |   } | 
| 451 |  |  | 
| 452 | 8.79M |   if (entropy->ct == -1) return TRUE;   /* if error do nothing */ | 
| 453 |  |  | 
| 454 |  |   /* There is always only one block per MCU */ | 
| 455 | 8.22M |   block = MCU_data[0]; | 
| 456 | 8.22M |   tbl = cinfo->cur_comp_info[0]->ac_tbl_no; | 
| 457 |  |  | 
| 458 | 8.22M |   p1 = 1 << cinfo->Al;          /* 1 in the bit position being coded */ | 
| 459 | 8.22M |   m1 = (NEG_1) << cinfo->Al;    /* -1 in the bit position being coded */ | 
| 460 |  |  | 
| 461 |  |   /* Establish EOBx (previous stage end-of-block) index */ | 
| 462 | 58.3M |   for (kex = cinfo->Se; kex > 0; kex--) | 
| 463 | 57.1M |     if ((*block)[jpeg_natural_order[kex]]) break; | 
| 464 |  |  | 
| 465 | 71.7M |   for (k = cinfo->Ss; k <= cinfo->Se; k++) { | 
| 466 | 71.1M |     st = entropy->ac_stats[tbl] + 3 * (k - 1); | 
| 467 | 71.1M |     if (k > kex) | 
| 468 | 8.30M |       if (arith_decode(cinfo, st)) break;       /* EOB flag */ | 
| 469 | 70.9M |     for (;;) { | 
| 470 | 70.9M |       thiscoef = *block + jpeg_natural_order[k]; | 
| 471 | 70.9M |       if (*thiscoef) {                          /* previously nonzero coef */ | 
| 472 | 61.5M |         if (arith_decode(cinfo, st + 2)) { | 
| 473 | 42.6M |           if (*thiscoef < 0) | 
| 474 | 25.2M |             *thiscoef += (JCOEF)m1; | 
| 475 | 17.4M |           else | 
| 476 | 17.4M |             *thiscoef += (JCOEF)p1; | 
| 477 | 42.6M |         } | 
| 478 | 61.5M |         break; | 
| 479 | 61.5M |       } | 
| 480 | 9.34M |       if (arith_decode(cinfo, st + 1)) {        /* newly nonzero coef */ | 
| 481 | 1.98M |         if (arith_decode(cinfo, entropy->fixed_bin)) | 
| 482 | 1.24M |           *thiscoef = (JCOEF)m1; | 
| 483 | 732k |         else | 
| 484 | 732k |           *thiscoef = (JCOEF)p1; | 
| 485 | 1.98M |         break; | 
| 486 | 1.98M |       } | 
| 487 | 7.36M |       st += 3;  k++; | 
| 488 | 7.36M |       if (k > cinfo->Se) { | 
| 489 | 4.83M |         WARNMS(cinfo, JWRN_ARITH_BAD_CODE); | 
| 490 | 4.83M |         entropy->ct = -1;                       /* spectral overflow */ | 
| 491 | 4.83M |         return TRUE; | 
| 492 | 4.83M |       } | 
| 493 | 7.36M |     } | 
| 494 | 68.3M |   } | 
| 495 |  |  | 
| 496 | 3.39M |   return TRUE; | 
| 497 | 8.22M | } | 
| 498 |  |  | 
| 499 |  |  | 
| 500 |  | /* | 
| 501 |  |  * Decode one MCU's worth of arithmetic-compressed coefficients. | 
| 502 |  |  */ | 
| 503 |  |  | 
| 504 |  | METHODDEF(boolean) | 
| 505 |  | decode_mcu(j_decompress_ptr cinfo, JBLOCKROW *MCU_data) | 
| 506 | 3.86M | { | 
| 507 | 3.86M |   arith_entropy_ptr entropy = (arith_entropy_ptr)cinfo->entropy; | 
| 508 | 3.86M |   jpeg_component_info *compptr; | 
| 509 | 3.86M |   JBLOCKROW block; | 
| 510 | 3.86M |   unsigned char *st; | 
| 511 | 3.86M |   int blkn, ci, tbl, sign, k; | 
| 512 | 3.86M |   int v, m; | 
| 513 |  |  | 
| 514 |  |   /* Process restart marker if needed */ | 
| 515 | 3.86M |   if (cinfo->restart_interval) { | 
| 516 | 272k |     if (entropy->restarts_to_go == 0) | 
| 517 | 45.3k |       process_restart(cinfo); | 
| 518 | 272k |     entropy->restarts_to_go--; | 
| 519 | 272k |   } | 
| 520 |  |  | 
| 521 | 3.86M |   if (entropy->ct == -1) return TRUE;   /* if error do nothing */ | 
| 522 |  |  | 
| 523 |  |   /* Outer loop handles each block in the MCU */ | 
| 524 |  |  | 
| 525 | 6.30M |   for (blkn = 0; blkn < cinfo->blocks_in_MCU; blkn++) { | 
| 526 | 3.40M |     block = MCU_data ? MCU_data[blkn] : NULL; | 
| 527 | 3.40M |     ci = cinfo->MCU_membership[blkn]; | 
| 528 | 3.40M |     compptr = cinfo->cur_comp_info[ci]; | 
| 529 |  |  | 
| 530 |  |     /* Sections F.2.4.1 & F.1.4.4.1: Decoding of DC coefficients */ | 
| 531 |  |  | 
| 532 | 3.40M |     tbl = compptr->dc_tbl_no; | 
| 533 |  |  | 
| 534 |  |     /* Table F.4: Point to statistics bin S0 for DC coefficient coding */ | 
| 535 | 3.40M |     st = entropy->dc_stats[tbl] + entropy->dc_context[ci]; | 
| 536 |  |  | 
| 537 |  |     /* Figure F.19: Decode_DC_DIFF */ | 
| 538 | 3.40M |     if (arith_decode(cinfo, st) == 0) | 
| 539 | 482k |       entropy->dc_context[ci] = 0; | 
| 540 | 2.91M |     else { | 
| 541 |  |       /* Figure F.21: Decoding nonzero value v */ | 
| 542 |  |       /* Figure F.22: Decoding the sign of v */ | 
| 543 | 2.91M |       sign = arith_decode(cinfo, st + 1); | 
| 544 | 2.91M |       st += 2;  st += sign; | 
| 545 |  |       /* Figure F.23: Decoding the magnitude category of v */ | 
| 546 | 2.91M |       if ((m = arith_decode(cinfo, st)) != 0) { | 
| 547 | 2.71M |         st = entropy->dc_stats[tbl] + 20;       /* Table F.4: X1 = 20 */ | 
| 548 | 13.0M |         while (arith_decode(cinfo, st)) { | 
| 549 | 10.3M |           if ((m <<= 1) == 0x8000) { | 
| 550 | 198 |             WARNMS(cinfo, JWRN_ARITH_BAD_CODE); | 
| 551 | 198 |             entropy->ct = -1;                   /* magnitude overflow */ | 
| 552 | 198 |             return TRUE; | 
| 553 | 198 |           } | 
| 554 | 10.3M |           st += 1; | 
| 555 | 10.3M |         } | 
| 556 | 2.71M |       } | 
| 557 |  |       /* Section F.1.4.4.1.2: Establish dc_context conditioning category */ | 
| 558 | 2.91M |       if (m < (int)((1L << cinfo->arith_dc_L[tbl]) >> 1)) | 
| 559 | 9.55k |         entropy->dc_context[ci] = 0;               /* zero diff category */ | 
| 560 | 2.90M |       else if (m > (int)((1L << cinfo->arith_dc_U[tbl]) >> 1)) | 
| 561 | 2.64M |         entropy->dc_context[ci] = 12 + (sign * 4); /* large diff category */ | 
| 562 | 264k |       else | 
| 563 | 264k |         entropy->dc_context[ci] = 4 + (sign * 4);  /* small diff category */ | 
| 564 | 2.91M |       v = m; | 
| 565 |  |       /* Figure F.24: Decoding the magnitude bit pattern of v */ | 
| 566 | 2.91M |       st += 14; | 
| 567 | 13.2M |       while (m >>= 1) | 
| 568 | 10.3M |         if (arith_decode(cinfo, st)) v |= m; | 
| 569 | 2.91M |       v += 1;  if (sign) v = -v; | 
| 570 | 2.91M |       entropy->last_dc_val[ci] = (entropy->last_dc_val[ci] + v) & 0xffff; | 
| 571 | 2.91M |     } | 
| 572 |  |  | 
| 573 | 3.40M |     if (block) | 
| 574 | 3.40M |       (*block)[0] = (JCOEF)entropy->last_dc_val[ci]; | 
| 575 |  |  | 
| 576 |  |     /* Sections F.2.4.2 & F.1.4.4.2: Decoding of AC coefficients */ | 
| 577 |  |  | 
| 578 | 3.40M |     tbl = compptr->ac_tbl_no; | 
| 579 |  |  | 
| 580 |  |     /* Figure F.20: Decode_AC_coefficients */ | 
| 581 | 4.86M |     for (k = 1; k <= DCTSIZE2 - 1; k++) { | 
| 582 | 4.84M |       st = entropy->ac_stats[tbl] + 3 * (k - 1); | 
| 583 | 4.84M |       if (arith_decode(cinfo, st)) break;       /* EOB flag */ | 
| 584 | 3.54M |       while (arith_decode(cinfo, st + 1) == 0) { | 
| 585 | 2.07M |         st += 3;  k++; | 
| 586 | 2.07M |         if (k > DCTSIZE2 - 1) { | 
| 587 | 194 |           WARNMS(cinfo, JWRN_ARITH_BAD_CODE); | 
| 588 | 194 |           entropy->ct = -1;                     /* spectral overflow */ | 
| 589 | 194 |           return TRUE; | 
| 590 | 194 |         } | 
| 591 | 2.07M |       } | 
| 592 |  |       /* Figure F.21: Decoding nonzero value v */ | 
| 593 |  |       /* Figure F.22: Decoding the sign of v */ | 
| 594 | 1.46M |       sign = arith_decode(cinfo, entropy->fixed_bin); | 
| 595 | 1.46M |       st += 2; | 
| 596 |  |       /* Figure F.23: Decoding the magnitude category of v */ | 
| 597 | 1.46M |       if ((m = arith_decode(cinfo, st)) != 0) { | 
| 598 | 755k |         if (arith_decode(cinfo, st)) { | 
| 599 | 686k |           m <<= 1; | 
| 600 | 686k |           st = entropy->ac_stats[tbl] + | 
| 601 | 686k |                (k <= cinfo->arith_ac_K[tbl] ? 189 : 217); | 
| 602 | 1.81M |           while (arith_decode(cinfo, st)) { | 
| 603 | 1.13M |             if ((m <<= 1) == 0x8000) { | 
| 604 | 811 |               WARNMS(cinfo, JWRN_ARITH_BAD_CODE); | 
| 605 | 811 |               entropy->ct = -1;                 /* magnitude overflow */ | 
| 606 | 811 |               return TRUE; | 
| 607 | 811 |             } | 
| 608 | 1.13M |             st += 1; | 
| 609 | 1.13M |           } | 
| 610 | 686k |         } | 
| 611 | 755k |       } | 
| 612 | 1.46M |       v = m; | 
| 613 |  |       /* Figure F.24: Decoding the magnitude bit pattern of v */ | 
| 614 | 1.46M |       st += 14; | 
| 615 | 3.27M |       while (m >>= 1) | 
| 616 | 1.80M |         if (arith_decode(cinfo, st)) v |= m; | 
| 617 | 1.46M |       v += 1;  if (sign) v = -v; | 
| 618 | 1.46M |       if (block) | 
| 619 | 1.46M |         (*block)[jpeg_natural_order[k]] = (JCOEF)v; | 
| 620 | 1.46M |     } | 
| 621 | 3.40M |   } | 
| 622 |  |  | 
| 623 | 2.90M |   return TRUE; | 
| 624 | 2.91M | } | 
| 625 |  |  | 
| 626 |  |  | 
| 627 |  | /* | 
| 628 |  |  * Initialize for an arithmetic-compressed scan. | 
| 629 |  |  */ | 
| 630 |  |  | 
| 631 |  | METHODDEF(void) | 
| 632 |  | start_pass(j_decompress_ptr cinfo) | 
| 633 | 9.52k | { | 
| 634 | 9.52k |   arith_entropy_ptr entropy = (arith_entropy_ptr)cinfo->entropy; | 
| 635 | 9.52k |   int ci, tbl; | 
| 636 | 9.52k |   jpeg_component_info *compptr; | 
| 637 |  |  | 
| 638 | 9.52k |   if (cinfo->progressive_mode) { | 
| 639 |  |     /* Validate progressive scan parameters */ | 
| 640 | 6.24k |     if (cinfo->Ss == 0) { | 
| 641 | 4.08k |       if (cinfo->Se != 0) | 
| 642 | 2 |         goto bad; | 
| 643 | 4.08k |     } else { | 
| 644 |  |       /* need not check Ss/Se < 0 since they came from unsigned bytes */ | 
| 645 | 2.15k |       if (cinfo->Se < cinfo->Ss || cinfo->Se > DCTSIZE2 - 1) | 
| 646 | 15 |         goto bad; | 
| 647 |  |       /* AC scans may have only one component */ | 
| 648 | 2.14k |       if (cinfo->comps_in_scan != 1) | 
| 649 | 1 |         goto bad; | 
| 650 | 2.14k |     } | 
| 651 | 6.22k |     if (cinfo->Ah != 0) { | 
| 652 |  |       /* Successive approximation refinement scan: must have Al = Ah-1. */ | 
| 653 | 1.29k |       if (cinfo->Ah - 1 != cinfo->Al) | 
| 654 | 8 |         goto bad; | 
| 655 | 1.29k |     } | 
| 656 | 6.21k |     if (cinfo->Al > 13) {       /* need not check for < 0 */ | 
| 657 | 27 | bad: | 
| 658 | 27 |       ERREXIT4(cinfo, JERR_BAD_PROGRESSION, | 
| 659 | 27 |                cinfo->Ss, cinfo->Se, cinfo->Ah, cinfo->Al); | 
| 660 | 27 |     } | 
| 661 |  |     /* Update progression status, and verify that scan order is legal. | 
| 662 |  |      * Note that inter-scan inconsistencies are treated as warnings | 
| 663 |  |      * not fatal errors ... not clear if this is right way to behave. | 
| 664 |  |      */ | 
| 665 | 14.5k |     for (ci = 0; ci < cinfo->comps_in_scan; ci++) { | 
| 666 | 8.34k |       int coefi, cindex = cinfo->cur_comp_info[ci]->component_index; | 
| 667 | 8.34k |       int *coef_bit_ptr = &cinfo->coef_bits[cindex][0]; | 
| 668 | 8.34k |       int *prev_coef_bit_ptr = | 
| 669 | 8.34k |         &cinfo->coef_bits[cindex + cinfo->num_components][0]; | 
| 670 | 8.34k |       if (cinfo->Ss && coef_bit_ptr[0] < 0) /* AC without prior DC scan */ | 
| 671 | 1.37k |         WARNMS2(cinfo, JWRN_BOGUS_PROGRESSION, cindex, 0); | 
| 672 | 146k |       for (coefi = MIN(cinfo->Ss, 1); coefi <= MAX(cinfo->Se, 9); coefi++) { | 
| 673 | 137k |         if (cinfo->input_scan_number > 1) | 
| 674 | 116k |           prev_coef_bit_ptr[coefi] = coef_bit_ptr[coefi]; | 
| 675 | 21.6k |         else | 
| 676 | 21.6k |           prev_coef_bit_ptr[coefi] = 0; | 
| 677 | 137k |       } | 
| 678 | 50.7k |       for (coefi = cinfo->Ss; coefi <= cinfo->Se; coefi++) { | 
| 679 | 42.4k |         int expected = (coef_bit_ptr[coefi] < 0) ? 0 : coef_bit_ptr[coefi]; | 
| 680 | 42.4k |         if (cinfo->Ah != expected) | 
| 681 | 18.3k |           WARNMS2(cinfo, JWRN_BOGUS_PROGRESSION, cindex, coefi); | 
| 682 | 42.4k |         coef_bit_ptr[coefi] = cinfo->Al; | 
| 683 | 42.4k |       } | 
| 684 | 8.34k |     } | 
| 685 |  |     /* Select MCU decoding routine */ | 
| 686 | 6.24k |     if (cinfo->Ah == 0) { | 
| 687 | 4.93k |       if (cinfo->Ss == 0) | 
| 688 | 3.59k |         entropy->pub.decode_mcu = decode_mcu_DC_first; | 
| 689 | 1.33k |       else | 
| 690 | 1.33k |         entropy->pub.decode_mcu = decode_mcu_AC_first; | 
| 691 | 4.93k |     } else { | 
| 692 | 1.31k |       if (cinfo->Ss == 0) | 
| 693 | 485 |         entropy->pub.decode_mcu = decode_mcu_DC_refine; | 
| 694 | 826 |       else | 
| 695 | 826 |         entropy->pub.decode_mcu = decode_mcu_AC_refine; | 
| 696 | 1.31k |     } | 
| 697 | 6.24k |   } else { | 
| 698 |  |     /* Check that the scan parameters Ss, Se, Ah/Al are OK for sequential JPEG. | 
| 699 |  |      * This ought to be an error condition, but we make it a warning. | 
| 700 |  |      */ | 
| 701 | 3.28k |     if (cinfo->Ss != 0 || cinfo->Se != DCTSIZE2 - 1 || | 
| 702 | 3.28k |         cinfo->Ah != 0 || cinfo->Al != 0) | 
| 703 | 2.28k |       WARNMS(cinfo, JWRN_NOT_SEQUENTIAL); | 
| 704 |  |     /* Select MCU decoding routine */ | 
| 705 | 3.28k |     entropy->pub.decode_mcu = decode_mcu; | 
| 706 | 3.28k |   } | 
| 707 |  |  | 
| 708 |  |   /* Allocate & initialize requested statistics areas */ | 
| 709 | 23.8k |   for (ci = 0; ci < cinfo->comps_in_scan; ci++) { | 
| 710 | 14.3k |     compptr = cinfo->cur_comp_info[ci]; | 
| 711 | 14.3k |     if (!cinfo->progressive_mode || (cinfo->Ss == 0 && cinfo->Ah == 0)) { | 
| 712 | 11.4k |       tbl = compptr->dc_tbl_no; | 
| 713 | 11.4k |       if (tbl < 0 || tbl >= NUM_ARITH_TBLS) | 
| 714 | 0 |         ERREXIT1(cinfo, JERR_NO_ARITH_TABLE, tbl); | 
| 715 | 11.4k |       if (entropy->dc_stats[tbl] == NULL) | 
| 716 | 2.71k |         entropy->dc_stats[tbl] = (unsigned char *)(*cinfo->mem->alloc_small) | 
| 717 | 2.71k |           ((j_common_ptr)cinfo, JPOOL_IMAGE, DC_STAT_BINS); | 
| 718 | 11.4k |       memset(entropy->dc_stats[tbl], 0, DC_STAT_BINS); | 
| 719 |  |       /* Initialize DC predictions to 0 */ | 
| 720 | 11.4k |       entropy->last_dc_val[ci] = 0; | 
| 721 | 11.4k |       entropy->dc_context[ci] = 0; | 
| 722 | 11.4k |     } | 
| 723 | 14.3k |     if (!cinfo->progressive_mode || cinfo->Ss) { | 
| 724 | 8.11k |       tbl = compptr->ac_tbl_no; | 
| 725 | 8.11k |       if (tbl < 0 || tbl >= NUM_ARITH_TBLS) | 
| 726 | 0 |         ERREXIT1(cinfo, JERR_NO_ARITH_TABLE, tbl); | 
| 727 | 8.11k |       if (entropy->ac_stats[tbl] == NULL) | 
| 728 | 1.92k |         entropy->ac_stats[tbl] = (unsigned char *)(*cinfo->mem->alloc_small) | 
| 729 | 1.92k |           ((j_common_ptr)cinfo, JPOOL_IMAGE, AC_STAT_BINS); | 
| 730 | 8.11k |       memset(entropy->ac_stats[tbl], 0, AC_STAT_BINS); | 
| 731 | 8.11k |     } | 
| 732 | 14.3k |   } | 
| 733 |  |  | 
| 734 |  |   /* Initialize arithmetic decoding variables */ | 
| 735 | 9.52k |   entropy->c = 0; | 
| 736 | 9.52k |   entropy->a = 0; | 
| 737 | 9.52k |   entropy->ct = -16;    /* force reading 2 initial bytes to fill C */ | 
| 738 | 9.52k |   entropy->pub.insufficient_data = FALSE; | 
| 739 |  |  | 
| 740 |  |   /* Initialize restart counter */ | 
| 741 | 9.52k |   entropy->restarts_to_go = cinfo->restart_interval; | 
| 742 | 9.52k | } | 
| 743 |  |  | 
| 744 |  |  | 
| 745 |  | /* | 
| 746 |  |  * Module initialization routine for arithmetic entropy decoding. | 
| 747 |  |  */ | 
| 748 |  |  | 
| 749 |  | GLOBAL(void) | 
| 750 |  | jinit_arith_decoder(j_decompress_ptr cinfo) | 
| 751 | 2.31k | { | 
| 752 | 2.31k |   arith_entropy_ptr entropy; | 
| 753 | 2.31k |   int i; | 
| 754 |  |  | 
| 755 | 2.31k |   entropy = (arith_entropy_ptr) | 
| 756 | 2.31k |     (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE, | 
| 757 | 2.31k |                                 sizeof(arith_entropy_decoder)); | 
| 758 | 2.31k |   cinfo->entropy = (struct jpeg_entropy_decoder *)entropy; | 
| 759 | 2.31k |   entropy->pub.start_pass = start_pass; | 
| 760 |  |  | 
| 761 |  |   /* Mark tables unallocated */ | 
| 762 | 39.3k |   for (i = 0; i < NUM_ARITH_TBLS; i++) { | 
| 763 | 37.0k |     entropy->dc_stats[i] = NULL; | 
| 764 | 37.0k |     entropy->ac_stats[i] = NULL; | 
| 765 | 37.0k |   } | 
| 766 |  |  | 
| 767 |  |   /* Initialize index for fixed probability estimation */ | 
| 768 | 2.31k |   entropy->fixed_bin[0] = 113; | 
| 769 |  |  | 
| 770 | 2.31k |   if (cinfo->progressive_mode) { | 
| 771 |  |     /* Create progression status table */ | 
| 772 | 1.40k |     int *coef_bit_ptr, ci; | 
| 773 | 1.40k |     cinfo->coef_bits = (int (*)[DCTSIZE2]) | 
| 774 | 1.40k |       (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE, | 
| 775 | 1.40k |                                   cinfo->num_components * 2 * DCTSIZE2 * | 
| 776 | 1.40k |                                   sizeof(int)); | 
| 777 | 1.40k |     coef_bit_ptr = &cinfo->coef_bits[0][0]; | 
| 778 | 3.55k |     for (ci = 0; ci < cinfo->num_components; ci++) | 
| 779 | 139k |       for (i = 0; i < DCTSIZE2; i++) | 
| 780 | 137k |         *coef_bit_ptr++ = -1; | 
| 781 | 1.40k |   } | 
| 782 | 2.31k | } |