Coverage Report

Created: 2026-05-11 07:55

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libjpeg-turbo.3.0.x/jdcoefct.c
Line
Count
Source
1
/*
2
 * jdcoefct.c
3
 *
4
 * This file was part of the Independent JPEG Group's software:
5
 * Copyright (C) 1994-1997, Thomas G. Lane.
6
 * libjpeg-turbo Modifications:
7
 * Copyright 2009 Pierre Ossman <ossman@cendio.se> for Cendio AB
8
 * Copyright (C) 2010, 2015-2016, 2019-2020, 2022-2024, D. R. Commander.
9
 * Copyright (C) 2015, 2020, Google, Inc.
10
 * For conditions of distribution and use, see the accompanying README.ijg
11
 * file.
12
 *
13
 * This file contains the coefficient buffer controller for decompression.
14
 * This controller is the top level of the lossy JPEG decompressor proper.
15
 * The coefficient buffer lies between entropy decoding and inverse-DCT steps.
16
 *
17
 * In buffered-image mode, this controller is the interface between
18
 * input-oriented processing and output-oriented processing.
19
 * Also, the input side (only) is used when reading a file for transcoding.
20
 */
21
22
#include "jinclude.h"
23
#include "jdcoefct.h"
24
#include "jpegapicomp.h"
25
#include "jsamplecomp.h"
26
27
28
/* Forward declarations */
29
METHODDEF(int) decompress_onepass(j_decompress_ptr cinfo,
30
                                  _JSAMPIMAGE output_buf);
31
#ifdef D_MULTISCAN_FILES_SUPPORTED
32
METHODDEF(int) decompress_data(j_decompress_ptr cinfo, _JSAMPIMAGE output_buf);
33
#endif
34
#ifdef BLOCK_SMOOTHING_SUPPORTED
35
LOCAL(boolean) smoothing_ok(j_decompress_ptr cinfo);
36
METHODDEF(int) decompress_smooth_data(j_decompress_ptr cinfo,
37
                                      _JSAMPIMAGE output_buf);
38
#endif
39
40
41
/*
42
 * Initialize for an input processing pass.
43
 */
44
45
METHODDEF(void)
46
start_input_pass(j_decompress_ptr cinfo)
47
180k
{
48
180k
  cinfo->input_iMCU_row = 0;
49
180k
  start_iMCU_row(cinfo);
50
180k
}
51
52
53
/*
54
 * Initialize for an output processing pass.
55
 */
56
57
METHODDEF(void)
58
start_output_pass(j_decompress_ptr cinfo)
59
16.3k
{
60
16.3k
#ifdef BLOCK_SMOOTHING_SUPPORTED
61
16.3k
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
62
63
  /* If multipass, check to see whether to use block smoothing on this pass */
64
16.3k
  if (coef->pub.coef_arrays != NULL) {
65
12.6k
    if (cinfo->do_block_smoothing && smoothing_ok(cinfo))
66
5.28k
      coef->pub._decompress_data = decompress_smooth_data;
67
7.36k
    else
68
7.36k
      coef->pub._decompress_data = decompress_data;
69
12.6k
  }
70
16.3k
#endif
71
16.3k
  cinfo->output_iMCU_row = 0;
72
16.3k
}
73
74
75
/*
76
 * Decompress and return some data in the single-pass case.
77
 * Always attempts to emit one fully interleaved MCU row ("iMCU" row).
78
 * Input and output must run in lockstep since we have only a one-MCU buffer.
79
 * Return value is JPEG_ROW_COMPLETED, JPEG_SCAN_COMPLETED, or JPEG_SUSPENDED.
80
 *
81
 * NB: output_buf contains a plane for each component in image,
82
 * which we index according to the component's SOF position.
83
 */
84
85
METHODDEF(int)
86
decompress_onepass(j_decompress_ptr cinfo, _JSAMPIMAGE output_buf)
87
1.43M
{
88
1.43M
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
89
1.43M
  JDIMENSION MCU_col_num;       /* index of current MCU within row */
90
1.43M
  JDIMENSION last_MCU_col = cinfo->MCUs_per_row - 1;
91
1.43M
  JDIMENSION last_iMCU_row = cinfo->total_iMCU_rows - 1;
92
1.43M
  int blkn, ci, xindex, yindex, yoffset, useful_width;
93
1.43M
  _JSAMPARRAY output_ptr;
94
1.43M
  JDIMENSION start_col, output_col;
95
1.43M
  jpeg_component_info *compptr;
96
1.43M
  _inverse_DCT_method_ptr inverse_DCT;
97
98
  /* Loop to process as much as one whole iMCU row */
99
4.30M
  for (yoffset = coef->MCU_vert_offset; yoffset < coef->MCU_rows_per_iMCU_row;
100
2.87M
       yoffset++) {
101
16.2M
    for (MCU_col_num = coef->MCU_ctr; MCU_col_num <= last_MCU_col;
102
13.4M
         MCU_col_num++) {
103
      /* Try to fetch an MCU.  Entropy decoder expects buffer to be zeroed. */
104
13.4M
      jzero_far((void *)coef->MCU_buffer[0],
105
13.4M
                (size_t)(cinfo->blocks_in_MCU * sizeof(JBLOCK)));
106
13.4M
      if (!cinfo->entropy->insufficient_data)
107
5.86M
        cinfo->master->last_good_iMCU_row = cinfo->input_iMCU_row;
108
13.4M
      if (!(*cinfo->entropy->decode_mcu) (cinfo, coef->MCU_buffer)) {
109
        /* Suspension forced; update state counters and exit */
110
0
        coef->MCU_vert_offset = yoffset;
111
0
        coef->MCU_ctr = MCU_col_num;
112
0
        return JPEG_SUSPENDED;
113
0
      }
114
115
      /* Only perform the IDCT on blocks that are contained within the desired
116
       * cropping region.
117
       */
118
13.4M
      if (MCU_col_num >= cinfo->master->first_iMCU_col &&
119
13.4M
          MCU_col_num <= cinfo->master->last_iMCU_col) {
120
        /* Determine where data should go in output_buf and do the IDCT thing.
121
         * We skip dummy blocks at the right and bottom edges (but blkn gets
122
         * incremented past them!).  Note the inner loop relies on having
123
         * allocated the MCU_buffer[] blocks sequentially.
124
         */
125
13.4M
        blkn = 0;               /* index of current DCT block within MCU */
126
27.4M
        for (ci = 0; ci < cinfo->comps_in_scan; ci++) {
127
14.0M
          compptr = cinfo->cur_comp_info[ci];
128
          /* Don't bother to IDCT an uninteresting component. */
129
14.0M
          if (!compptr->component_needed) {
130
83.5k
            blkn += compptr->MCU_blocks;
131
83.5k
            continue;
132
83.5k
          }
133
13.9M
          inverse_DCT = cinfo->idct->_inverse_DCT[compptr->component_index];
134
13.9M
          useful_width = (MCU_col_num < last_MCU_col) ?
135
10.9M
                         compptr->MCU_width : compptr->last_col_width;
136
13.9M
          output_ptr = output_buf[compptr->component_index] +
137
13.9M
                       yoffset * compptr->_DCT_scaled_size;
138
13.9M
          start_col = (MCU_col_num - cinfo->master->first_iMCU_col) *
139
13.9M
                      compptr->MCU_sample_width;
140
28.2M
          for (yindex = 0; yindex < compptr->MCU_height; yindex++) {
141
14.3M
            if (cinfo->input_iMCU_row < last_iMCU_row ||
142
14.2M
                yoffset + yindex < compptr->last_row_height) {
143
14.2M
              output_col = start_col;
144
28.8M
              for (xindex = 0; xindex < useful_width; xindex++) {
145
14.6M
                (*inverse_DCT) (cinfo, compptr,
146
14.6M
                                (JCOEFPTR)coef->MCU_buffer[blkn + xindex],
147
14.6M
                                output_ptr, output_col);
148
14.6M
                output_col += compptr->_DCT_scaled_size;
149
14.6M
              }
150
14.2M
            }
151
14.3M
            blkn += compptr->MCU_width;
152
14.3M
            output_ptr += compptr->_DCT_scaled_size;
153
14.3M
          }
154
13.9M
        }
155
13.4M
      }
156
13.4M
    }
157
    /* Completed an MCU row, but perhaps not an iMCU row */
158
2.87M
    coef->MCU_ctr = 0;
159
2.87M
  }
160
  /* Completed the iMCU row, advance counters for next one */
161
1.43M
  cinfo->output_iMCU_row++;
162
1.43M
  if (++(cinfo->input_iMCU_row) < cinfo->total_iMCU_rows) {
163
1.42M
    start_iMCU_row(cinfo);
164
1.42M
    return JPEG_ROW_COMPLETED;
165
1.42M
  }
166
  /* Completed the scan */
167
3.64k
  (*cinfo->inputctl->finish_input_pass) (cinfo);
168
3.64k
  return JPEG_SCAN_COMPLETED;
169
1.43M
}
170
171
172
/*
173
 * Dummy consume-input routine for single-pass operation.
174
 */
175
176
METHODDEF(int)
177
dummy_consume_data(j_decompress_ptr cinfo)
178
0
{
179
0
  return JPEG_SUSPENDED;        /* Always indicate nothing was done */
180
0
}
181
182
183
#ifdef D_MULTISCAN_FILES_SUPPORTED
184
185
/*
186
 * Consume input data and store it in the full-image coefficient buffer.
187
 * We read as much as one fully interleaved MCU row ("iMCU" row) per call,
188
 * ie, v_samp_factor block rows for each component in the scan.
189
 * Return value is JPEG_ROW_COMPLETED, JPEG_SCAN_COMPLETED, or JPEG_SUSPENDED.
190
 */
191
192
METHODDEF(int)
193
consume_data(j_decompress_ptr cinfo)
194
51.4M
{
195
51.4M
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
196
51.4M
  JDIMENSION MCU_col_num;       /* index of current MCU within row */
197
51.4M
  int blkn, ci, xindex, yindex, yoffset;
198
51.4M
  JDIMENSION start_col;
199
51.4M
  JBLOCKARRAY buffer[MAX_COMPS_IN_SCAN];
200
51.4M
  JBLOCKROW buffer_ptr;
201
51.4M
  jpeg_component_info *compptr;
202
203
  /* Align the virtual buffers for the components used in this scan. */
204
118M
  for (ci = 0; ci < cinfo->comps_in_scan; ci++) {
205
67.3M
    compptr = cinfo->cur_comp_info[ci];
206
67.3M
    buffer[ci] = (*cinfo->mem->access_virt_barray)
207
67.3M
      ((j_common_ptr)cinfo, coef->whole_image[compptr->component_index],
208
67.3M
       cinfo->input_iMCU_row * compptr->v_samp_factor,
209
67.3M
       (JDIMENSION)compptr->v_samp_factor, TRUE);
210
    /* Note: entropy decoder expects buffer to be zeroed,
211
     * but this is handled automatically by the memory manager
212
     * because we requested a pre-zeroed array.
213
     */
214
67.3M
  }
215
216
  /* Loop to process one whole iMCU row */
217
124M
  for (yoffset = coef->MCU_vert_offset; yoffset < coef->MCU_rows_per_iMCU_row;
218
73.3M
       yoffset++) {
219
584M
    for (MCU_col_num = coef->MCU_ctr; MCU_col_num < cinfo->MCUs_per_row;
220
511M
         MCU_col_num++) {
221
      /* Construct list of pointers to DCT blocks belonging to this MCU */
222
511M
      blkn = 0;                 /* index of current DCT block within MCU */
223
1.10G
      for (ci = 0; ci < cinfo->comps_in_scan; ci++) {
224
597M
        compptr = cinfo->cur_comp_info[ci];
225
597M
        start_col = MCU_col_num * compptr->MCU_width;
226
1.26G
        for (yindex = 0; yindex < compptr->MCU_height; yindex++) {
227
666M
          buffer_ptr = buffer[ci][yindex + yoffset] + start_col;
228
1.49G
          for (xindex = 0; xindex < compptr->MCU_width; xindex++) {
229
825M
            coef->MCU_buffer[blkn++] = buffer_ptr++;
230
825M
          }
231
666M
        }
232
597M
      }
233
511M
      if (!cinfo->entropy->insufficient_data)
234
330M
        cinfo->master->last_good_iMCU_row = cinfo->input_iMCU_row;
235
      /* Try to fetch the MCU. */
236
511M
      if (!(*cinfo->entropy->decode_mcu) (cinfo, coef->MCU_buffer)) {
237
        /* Suspension forced; update state counters and exit */
238
0
        coef->MCU_vert_offset = yoffset;
239
0
        coef->MCU_ctr = MCU_col_num;
240
0
        return JPEG_SUSPENDED;
241
0
      }
242
511M
    }
243
    /* Completed an MCU row, but perhaps not an iMCU row */
244
73.3M
    coef->MCU_ctr = 0;
245
73.3M
  }
246
  /* Completed the iMCU row, advance counters for next one */
247
51.4M
  if (++(cinfo->input_iMCU_row) < cinfo->total_iMCU_rows) {
248
51.2M
    start_iMCU_row(cinfo);
249
51.2M
    return JPEG_ROW_COMPLETED;
250
51.2M
  }
251
  /* Completed the scan */
252
175k
  (*cinfo->inputctl->finish_input_pass) (cinfo);
253
175k
  return JPEG_SCAN_COMPLETED;
254
51.4M
}
255
256
257
/*
258
 * Decompress and return some data in the multi-pass case.
259
 * Always attempts to emit one fully interleaved MCU row ("iMCU" row).
260
 * Return value is JPEG_ROW_COMPLETED, JPEG_SCAN_COMPLETED, or JPEG_SUSPENDED.
261
 *
262
 * NB: output_buf contains a plane for each component in image.
263
 */
264
265
METHODDEF(int)
266
decompress_data(j_decompress_ptr cinfo, _JSAMPIMAGE output_buf)
267
2.13M
{
268
2.13M
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
269
2.13M
  JDIMENSION last_iMCU_row = cinfo->total_iMCU_rows - 1;
270
2.13M
  JDIMENSION block_num;
271
2.13M
  int ci, block_row, block_rows;
272
2.13M
  JBLOCKARRAY buffer;
273
2.13M
  JBLOCKROW buffer_ptr;
274
2.13M
  _JSAMPARRAY output_ptr;
275
2.13M
  JDIMENSION output_col;
276
2.13M
  jpeg_component_info *compptr;
277
2.13M
  _inverse_DCT_method_ptr inverse_DCT;
278
279
  /* Force some input to be done if we are getting ahead of the input. */
280
2.13M
  while (cinfo->input_scan_number < cinfo->output_scan_number ||
281
2.13M
         (cinfo->input_scan_number == cinfo->output_scan_number &&
282
2.13M
          cinfo->input_iMCU_row <= cinfo->output_iMCU_row)) {
283
0
    if ((*cinfo->inputctl->consume_input) (cinfo) == JPEG_SUSPENDED)
284
0
      return JPEG_SUSPENDED;
285
0
  }
286
287
  /* OK, output from the virtual arrays. */
288
6.00M
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
289
3.86M
       ci++, compptr++) {
290
    /* Don't bother to IDCT an uninteresting component. */
291
3.86M
    if (!compptr->component_needed)
292
306k
      continue;
293
    /* Align the virtual buffer for this component. */
294
3.56M
    buffer = (*cinfo->mem->access_virt_barray)
295
3.56M
      ((j_common_ptr)cinfo, coef->whole_image[ci],
296
3.56M
       cinfo->output_iMCU_row * compptr->v_samp_factor,
297
3.56M
       (JDIMENSION)compptr->v_samp_factor, FALSE);
298
    /* Count non-dummy DCT block rows in this iMCU row. */
299
3.56M
    if (cinfo->output_iMCU_row < last_iMCU_row)
300
3.55M
      block_rows = compptr->v_samp_factor;
301
12.3k
    else {
302
      /* NB: can't use last_row_height here; it is input-side-dependent! */
303
12.3k
      block_rows = (int)(compptr->height_in_blocks % compptr->v_samp_factor);
304
12.3k
      if (block_rows == 0) block_rows = compptr->v_samp_factor;
305
12.3k
    }
306
3.56M
    inverse_DCT = cinfo->idct->_inverse_DCT[ci];
307
3.56M
    output_ptr = output_buf[ci];
308
    /* Loop over all DCT blocks to be processed. */
309
8.44M
    for (block_row = 0; block_row < block_rows; block_row++) {
310
4.88M
      buffer_ptr = buffer[block_row] + cinfo->master->first_MCU_col[ci];
311
4.88M
      output_col = 0;
312
4.88M
      for (block_num = cinfo->master->first_MCU_col[ci];
313
45.9M
           block_num <= cinfo->master->last_MCU_col[ci]; block_num++) {
314
41.0M
        (*inverse_DCT) (cinfo, compptr, (JCOEFPTR)buffer_ptr, output_ptr,
315
41.0M
                        output_col);
316
41.0M
        buffer_ptr++;
317
41.0M
        output_col += compptr->_DCT_scaled_size;
318
41.0M
      }
319
4.88M
      output_ptr += compptr->_DCT_scaled_size;
320
4.88M
    }
321
3.56M
  }
322
323
2.13M
  if (++(cinfo->output_iMCU_row) < cinfo->total_iMCU_rows)
324
2.12M
    return JPEG_ROW_COMPLETED;
325
6.54k
  return JPEG_SCAN_COMPLETED;
326
2.13M
}
327
328
#endif /* D_MULTISCAN_FILES_SUPPORTED */
329
330
331
#ifdef BLOCK_SMOOTHING_SUPPORTED
332
333
/*
334
 * This code applies interblock smoothing; the first 9 AC coefficients are
335
 * estimated from the DC values of a DCT block and its 24 neighboring blocks.
336
 * We apply smoothing only for progressive JPEG decoding, and only if
337
 * the coefficients it can estimate are not yet known to full precision.
338
 */
339
340
/* Natural-order array positions of the first 9 zigzag-order coefficients */
341
3.53M
#define Q01_POS  1
342
3.53M
#define Q10_POS  8
343
3.53M
#define Q20_POS  16
344
3.53M
#define Q11_POS  9
345
3.53M
#define Q02_POS  2
346
2.43M
#define Q03_POS  3
347
2.43M
#define Q12_POS  10
348
2.43M
#define Q21_POS  17
349
2.43M
#define Q30_POS  24
350
351
/*
352
 * Determine whether block smoothing is applicable and safe.
353
 * We also latch the current states of the coef_bits[] entries for the
354
 * AC coefficients; otherwise, if the input side of the decompressor
355
 * advances into a new scan, we might think the coefficients are known
356
 * more accurately than they really are.
357
 */
358
359
LOCAL(boolean)
360
smoothing_ok(j_decompress_ptr cinfo)
361
12.6k
{
362
12.6k
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
363
12.6k
  boolean smoothing_useful = FALSE;
364
12.6k
  int ci, coefi;
365
12.6k
  jpeg_component_info *compptr;
366
12.6k
  JQUANT_TBL *qtable;
367
12.6k
  int *coef_bits, *prev_coef_bits;
368
12.6k
  int *coef_bits_latch, *prev_coef_bits_latch;
369
370
12.6k
  if (!cinfo->progressive_mode || cinfo->coef_bits == NULL)
371
1.97k
    return FALSE;
372
373
  /* Allocate latch area if not already done */
374
10.6k
  if (coef->coef_bits_latch == NULL)
375
10.6k
    coef->coef_bits_latch = (int *)
376
10.6k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
377
10.6k
                                  cinfo->num_components * 2 *
378
10.6k
                                  (SAVED_COEFS * sizeof(int)));
379
10.6k
  coef_bits_latch = coef->coef_bits_latch;
380
10.6k
  prev_coef_bits_latch =
381
10.6k
    &coef->coef_bits_latch[cinfo->num_components * SAVED_COEFS];
382
383
17.7k
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
384
12.4k
       ci++, compptr++) {
385
    /* All components' quantization values must already be latched. */
386
12.4k
    if ((qtable = compptr->quant_table) == NULL)
387
1.33k
      return FALSE;
388
    /* Verify DC & first 9 AC quantizers are nonzero to avoid zero-divide. */
389
11.0k
    if (qtable->quantval[0] == 0 ||
390
10.5k
        qtable->quantval[Q01_POS] == 0 ||
391
10.1k
        qtable->quantval[Q10_POS] == 0 ||
392
9.94k
        qtable->quantval[Q20_POS] == 0 ||
393
9.67k
        qtable->quantval[Q11_POS] == 0 ||
394
9.35k
        qtable->quantval[Q02_POS] == 0 ||
395
9.09k
        qtable->quantval[Q03_POS] == 0 ||
396
8.80k
        qtable->quantval[Q12_POS] == 0 ||
397
8.54k
        qtable->quantval[Q21_POS] == 0 ||
398
8.18k
        qtable->quantval[Q30_POS] == 0)
399
3.16k
      return FALSE;
400
    /* DC values must be at least partly known for all components. */
401
7.90k
    coef_bits = cinfo->coef_bits[ci];
402
7.90k
    prev_coef_bits = cinfo->coef_bits[ci + cinfo->num_components];
403
7.90k
    if (coef_bits[0] < 0)
404
881
      return FALSE;
405
7.02k
    coef_bits_latch[0] = coef_bits[0];
406
    /* Block smoothing is helpful if some AC coefficients remain inaccurate. */
407
70.2k
    for (coefi = 1; coefi < SAVED_COEFS; coefi++) {
408
63.2k
      if (cinfo->input_scan_number > 1)
409
34.0k
        prev_coef_bits_latch[coefi] = prev_coef_bits[coefi];
410
29.1k
      else
411
29.1k
        prev_coef_bits_latch[coefi] = -1;
412
63.2k
      coef_bits_latch[coefi] = coef_bits[coefi];
413
63.2k
      if (coef_bits[coefi] != 0)
414
60.6k
        smoothing_useful = TRUE;
415
63.2k
    }
416
7.02k
    coef_bits_latch += SAVED_COEFS;
417
7.02k
    prev_coef_bits_latch += SAVED_COEFS;
418
7.02k
  }
419
420
5.29k
  return smoothing_useful;
421
10.6k
}
422
423
424
/*
425
 * Variant of decompress_data for use when doing block smoothing.
426
 */
427
428
METHODDEF(int)
429
decompress_smooth_data(j_decompress_ptr cinfo, _JSAMPIMAGE output_buf)
430
2.32M
{
431
2.32M
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
432
2.32M
  JDIMENSION last_iMCU_row = cinfo->total_iMCU_rows - 1;
433
2.32M
  JDIMENSION block_num, last_block_column;
434
2.32M
  int ci, block_row, block_rows, access_rows, image_block_row,
435
2.32M
    image_block_rows;
436
2.32M
  JBLOCKARRAY buffer;
437
2.32M
  JBLOCKROW buffer_ptr, prev_prev_block_row, prev_block_row;
438
2.32M
  JBLOCKROW next_block_row, next_next_block_row;
439
2.32M
  _JSAMPARRAY output_ptr;
440
2.32M
  JDIMENSION output_col;
441
2.32M
  jpeg_component_info *compptr;
442
2.32M
  _inverse_DCT_method_ptr inverse_DCT;
443
2.32M
  boolean change_dc;
444
2.32M
  JCOEF *workspace;
445
2.32M
  int *coef_bits;
446
2.32M
  JQUANT_TBL *quanttbl;
447
2.32M
  JLONG Q00, Q01, Q02, Q03 = 0, Q10, Q11, Q12 = 0, Q20, Q21 = 0, Q30 = 0, num;
448
2.32M
  int DC01, DC02, DC03, DC04, DC05, DC06, DC07, DC08, DC09, DC10, DC11, DC12,
449
2.32M
      DC13, DC14, DC15, DC16, DC17, DC18, DC19, DC20, DC21, DC22, DC23, DC24,
450
2.32M
      DC25;
451
2.32M
  int Al, pred;
452
453
  /* Keep a local variable to avoid looking it up more than once */
454
2.32M
  workspace = coef->workspace;
455
456
  /* Force some input to be done if we are getting ahead of the input. */
457
2.32M
  while (cinfo->input_scan_number <= cinfo->output_scan_number &&
458
2.32M
         !cinfo->inputctl->eoi_reached) {
459
0
    if (cinfo->input_scan_number == cinfo->output_scan_number) {
460
      /* If input is working on current scan, we ordinarily want it to
461
       * have completed the current row.  But if input scan is DC,
462
       * we want it to keep two rows ahead so that next two block rows' DC
463
       * values are up to date.
464
       */
465
0
      JDIMENSION delta = (cinfo->Ss == 0) ? 2 : 0;
466
0
      if (cinfo->input_iMCU_row > cinfo->output_iMCU_row + delta)
467
0
        break;
468
0
    }
469
0
    if ((*cinfo->inputctl->consume_input) (cinfo) == JPEG_SUSPENDED)
470
0
      return JPEG_SUSPENDED;
471
0
  }
472
473
  /* OK, output from the virtual arrays. */
474
6.14M
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
475
3.82M
       ci++, compptr++) {
476
    /* Don't bother to IDCT an uninteresting component. */
477
3.82M
    if (!compptr->component_needed)
478
296k
      continue;
479
    /* Count non-dummy DCT block rows in this iMCU row. */
480
3.52M
    if (cinfo->output_iMCU_row + 1 < last_iMCU_row) {
481
3.51M
      block_rows = compptr->v_samp_factor;
482
3.51M
      access_rows = block_rows * 3; /* this and next two iMCU rows */
483
3.51M
    } else if (cinfo->output_iMCU_row < last_iMCU_row) {
484
5.63k
      block_rows = compptr->v_samp_factor;
485
5.63k
      access_rows = block_rows * 2; /* this and next iMCU row */
486
6.19k
    } else {
487
      /* NB: can't use last_row_height here; it is input-side-dependent! */
488
6.19k
      block_rows = (int)(compptr->height_in_blocks % compptr->v_samp_factor);
489
6.19k
      if (block_rows == 0) block_rows = compptr->v_samp_factor;
490
6.19k
      access_rows = block_rows; /* this iMCU row only */
491
6.19k
    }
492
    /* Align the virtual buffer for this component. */
493
3.52M
    if (cinfo->output_iMCU_row > 1) {
494
3.51M
      access_rows += 2 * compptr->v_samp_factor; /* prior two iMCU rows too */
495
3.51M
      buffer = (*cinfo->mem->access_virt_barray)
496
3.51M
        ((j_common_ptr)cinfo, coef->whole_image[ci],
497
3.51M
         (cinfo->output_iMCU_row - 2) * compptr->v_samp_factor,
498
3.51M
         (JDIMENSION)access_rows, FALSE);
499
3.51M
      buffer += 2 * compptr->v_samp_factor; /* point to current iMCU row */
500
3.51M
    } else if (cinfo->output_iMCU_row > 0) {
501
5.63k
      access_rows += compptr->v_samp_factor; /* prior iMCU row too */
502
5.63k
      buffer = (*cinfo->mem->access_virt_barray)
503
5.63k
        ((j_common_ptr)cinfo, coef->whole_image[ci],
504
5.63k
         (cinfo->output_iMCU_row - 1) * compptr->v_samp_factor,
505
5.63k
         (JDIMENSION)access_rows, FALSE);
506
5.63k
      buffer += compptr->v_samp_factor; /* point to current iMCU row */
507
6.19k
    } else {
508
6.19k
      buffer = (*cinfo->mem->access_virt_barray)
509
6.19k
        ((j_common_ptr)cinfo, coef->whole_image[ci],
510
6.19k
         (JDIMENSION)0, (JDIMENSION)access_rows, FALSE);
511
6.19k
    }
512
    /* Fetch component-dependent info.
513
     * If the current scan is incomplete, then we use the component-dependent
514
     * info from the previous scan.
515
     */
516
3.52M
    if (cinfo->output_iMCU_row > cinfo->master->last_good_iMCU_row)
517
1.88M
      coef_bits =
518
1.88M
        coef->coef_bits_latch + ((ci + cinfo->num_components) * SAVED_COEFS);
519
1.63M
    else
520
1.63M
      coef_bits = coef->coef_bits_latch + (ci * SAVED_COEFS);
521
522
    /* We only do DC interpolation if no AC coefficient data is available. */
523
3.52M
    change_dc =
524
3.52M
      coef_bits[1] == -1 && coef_bits[2] == -1 && coef_bits[3] == -1 &&
525
2.60M
      coef_bits[4] == -1 && coef_bits[5] == -1 && coef_bits[6] == -1 &&
526
2.49M
      coef_bits[7] == -1 && coef_bits[8] == -1 && coef_bits[9] == -1;
527
528
3.52M
    quanttbl = compptr->quant_table;
529
3.52M
    Q00 = quanttbl->quantval[0];
530
3.52M
    Q01 = quanttbl->quantval[Q01_POS];
531
3.52M
    Q10 = quanttbl->quantval[Q10_POS];
532
3.52M
    Q20 = quanttbl->quantval[Q20_POS];
533
3.52M
    Q11 = quanttbl->quantval[Q11_POS];
534
3.52M
    Q02 = quanttbl->quantval[Q02_POS];
535
3.52M
    if (change_dc) {
536
2.42M
      Q03 = quanttbl->quantval[Q03_POS];
537
2.42M
      Q12 = quanttbl->quantval[Q12_POS];
538
2.42M
      Q21 = quanttbl->quantval[Q21_POS];
539
2.42M
      Q30 = quanttbl->quantval[Q30_POS];
540
2.42M
    }
541
3.52M
    inverse_DCT = cinfo->idct->_inverse_DCT[ci];
542
3.52M
    output_ptr = output_buf[ci];
543
    /* Loop over all DCT blocks to be processed. */
544
3.52M
    image_block_rows = block_rows * cinfo->total_iMCU_rows;
545
9.03M
    for (block_row = 0; block_row < block_rows; block_row++) {
546
5.51M
      image_block_row = cinfo->output_iMCU_row * block_rows + block_row;
547
5.51M
      buffer_ptr = buffer[block_row] + cinfo->master->first_MCU_col[ci];
548
549
5.51M
      if (image_block_row > 0)
550
5.50M
        prev_block_row =
551
5.50M
          buffer[block_row - 1] + cinfo->master->first_MCU_col[ci];
552
6.19k
      else
553
6.19k
        prev_block_row = buffer_ptr;
554
555
5.51M
      if (image_block_row > 1)
556
5.49M
        prev_prev_block_row =
557
5.49M
          buffer[block_row - 2] + cinfo->master->first_MCU_col[ci];
558
12.2k
      else
559
12.2k
        prev_prev_block_row = prev_block_row;
560
561
5.51M
      if (image_block_row < image_block_rows - 1)
562
5.50M
        next_block_row =
563
5.50M
          buffer[block_row + 1] + cinfo->master->first_MCU_col[ci];
564
6.19k
      else
565
6.19k
        next_block_row = buffer_ptr;
566
567
5.51M
      if (image_block_row < image_block_rows - 2)
568
5.50M
        next_next_block_row =
569
5.50M
          buffer[block_row + 2] + cinfo->master->first_MCU_col[ci];
570
10.6k
      else
571
10.6k
        next_next_block_row = next_block_row;
572
573
      /* We fetch the surrounding DC values using a sliding-register approach.
574
       * Initialize all 25 here so as to do the right thing on narrow pics.
575
       */
576
5.51M
      DC01 = DC02 = DC03 = DC04 = DC05 = (int)prev_prev_block_row[0][0];
577
5.51M
      DC06 = DC07 = DC08 = DC09 = DC10 = (int)prev_block_row[0][0];
578
5.51M
      DC11 = DC12 = DC13 = DC14 = DC15 = (int)buffer_ptr[0][0];
579
5.51M
      DC16 = DC17 = DC18 = DC19 = DC20 = (int)next_block_row[0][0];
580
5.51M
      DC21 = DC22 = DC23 = DC24 = DC25 = (int)next_next_block_row[0][0];
581
5.51M
      output_col = 0;
582
5.51M
      last_block_column = compptr->width_in_blocks - 1;
583
5.51M
      for (block_num = cinfo->master->first_MCU_col[ci];
584
45.1M
           block_num <= cinfo->master->last_MCU_col[ci]; block_num++) {
585
        /* Fetch current DCT block into workspace so we can modify it. */
586
39.6M
        jcopy_block_row(buffer_ptr, (JBLOCKROW)workspace, (JDIMENSION)1);
587
        /* Update DC values */
588
39.6M
        if (block_num == cinfo->master->first_MCU_col[ci] &&
589
5.51M
            block_num < last_block_column) {
590
3.64M
          DC04 = DC05 = (int)prev_prev_block_row[1][0];
591
3.64M
          DC09 = DC10 = (int)prev_block_row[1][0];
592
3.64M
          DC14 = DC15 = (int)buffer_ptr[1][0];
593
3.64M
          DC19 = DC20 = (int)next_block_row[1][0];
594
3.64M
          DC24 = DC25 = (int)next_next_block_row[1][0];
595
3.64M
        }
596
39.6M
        if (block_num + 1 < last_block_column) {
597
30.4M
          DC05 = (int)prev_prev_block_row[2][0];
598
30.4M
          DC10 = (int)prev_block_row[2][0];
599
30.4M
          DC15 = (int)buffer_ptr[2][0];
600
30.4M
          DC20 = (int)next_block_row[2][0];
601
30.4M
          DC25 = (int)next_next_block_row[2][0];
602
30.4M
        }
603
        /* If DC interpolation is enabled, compute coefficient estimates using
604
         * a Gaussian-like kernel, keeping the averages of the DC values.
605
         *
606
         * If DC interpolation is disabled, compute coefficient estimates using
607
         * an algorithm similar to the one described in Section K.8 of the JPEG
608
         * standard, except applied to a 5x5 window rather than a 3x3 window.
609
         *
610
         * An estimate is applied only if the coefficient is still zero and is
611
         * not known to be fully accurate.
612
         */
613
        /* AC01 */
614
39.6M
        if ((Al = coef_bits[1]) != 0 && workspace[1] == 0) {
615
37.0M
          num = Q00 * (change_dc ?
616
23.7M
                (-DC01 - DC02 + DC04 + DC05 - 3 * DC06 + 13 * DC07 -
617
23.7M
                 13 * DC09 + 3 * DC10 - 3 * DC11 + 38 * DC12 - 38 * DC14 +
618
23.7M
                 3 * DC15 - 3 * DC16 + 13 * DC17 - 13 * DC19 + 3 * DC20 -
619
23.7M
                 DC21 - DC22 + DC24 + DC25) :
620
37.0M
                (-7 * DC11 + 50 * DC12 - 50 * DC14 + 7 * DC15));
621
37.0M
          if (num >= 0) {
622
27.0M
            pred = (int)(((Q01 << 7) + num) / (Q01 << 8));
623
27.0M
            if (Al > 0 && pred >= (1 << Al))
624
2.51M
              pred = (1 << Al) - 1;
625
27.0M
          } else {
626
10.0M
            pred = (int)(((Q01 << 7) - num) / (Q01 << 8));
627
10.0M
            if (Al > 0 && pred >= (1 << Al))
628
1.82M
              pred = (1 << Al) - 1;
629
10.0M
            pred = -pred;
630
10.0M
          }
631
37.0M
          workspace[1] = (JCOEF)pred;
632
37.0M
        }
633
        /* AC10 */
634
39.6M
        if ((Al = coef_bits[2]) != 0 && workspace[8] == 0) {
635
37.0M
          num = Q00 * (change_dc ?
636
23.7M
                (-DC01 - 3 * DC02 - 3 * DC03 - 3 * DC04 - DC05 - DC06 +
637
23.7M
                 13 * DC07 + 38 * DC08 + 13 * DC09 - DC10 + DC16 -
638
23.7M
                 13 * DC17 - 38 * DC18 - 13 * DC19 + DC20 + DC21 +
639
23.7M
                 3 * DC22 + 3 * DC23 + 3 * DC24 + DC25) :
640
37.0M
                (-7 * DC03 + 50 * DC08 - 50 * DC18 + 7 * DC23));
641
37.0M
          if (num >= 0) {
642
25.1M
            pred = (int)(((Q10 << 7) + num) / (Q10 << 8));
643
25.1M
            if (Al > 0 && pred >= (1 << Al))
644
4.42M
              pred = (1 << Al) - 1;
645
25.1M
          } else {
646
11.9M
            pred = (int)(((Q10 << 7) - num) / (Q10 << 8));
647
11.9M
            if (Al > 0 && pred >= (1 << Al))
648
3.57M
              pred = (1 << Al) - 1;
649
11.9M
            pred = -pred;
650
11.9M
          }
651
37.0M
          workspace[8] = (JCOEF)pred;
652
37.0M
        }
653
        /* AC20 */
654
39.6M
        if ((Al = coef_bits[3]) != 0 && workspace[16] == 0) {
655
37.7M
          num = Q00 * (change_dc ?
656
23.7M
                (DC03 + 2 * DC07 + 7 * DC08 + 2 * DC09 - 5 * DC12 - 14 * DC13 -
657
23.7M
                 5 * DC14 + 2 * DC17 + 7 * DC18 + 2 * DC19 + DC23) :
658
37.7M
                (-DC03 + 13 * DC08 - 24 * DC13 + 13 * DC18 - DC23));
659
37.7M
          if (num >= 0) {
660
22.8M
            pred = (int)(((Q20 << 7) + num) / (Q20 << 8));
661
22.8M
            if (Al > 0 && pred >= (1 << Al))
662
3.28M
              pred = (1 << Al) - 1;
663
22.8M
          } else {
664
14.9M
            pred = (int)(((Q20 << 7) - num) / (Q20 << 8));
665
14.9M
            if (Al > 0 && pred >= (1 << Al))
666
3.30M
              pred = (1 << Al) - 1;
667
14.9M
            pred = -pred;
668
14.9M
          }
669
37.7M
          workspace[16] = (JCOEF)pred;
670
37.7M
        }
671
        /* AC11 */
672
39.6M
        if ((Al = coef_bits[4]) != 0 && workspace[9] == 0) {
673
37.8M
          num = Q00 * (change_dc ?
674
23.7M
                (-DC01 + DC05 + 9 * DC07 - 9 * DC09 - 9 * DC17 +
675
23.7M
                 9 * DC19 + DC21 - DC25) :
676
37.8M
                (DC10 + DC16 - 10 * DC17 + 10 * DC19 - DC02 - DC20 + DC22 -
677
14.1M
                 DC24 + DC04 - DC06 + 10 * DC07 - 10 * DC09));
678
37.8M
          if (num >= 0) {
679
28.0M
            pred = (int)(((Q11 << 7) + num) / (Q11 << 8));
680
28.0M
            if (Al > 0 && pred >= (1 << Al))
681
1.64M
              pred = (1 << Al) - 1;
682
28.0M
          } else {
683
9.76M
            pred = (int)(((Q11 << 7) - num) / (Q11 << 8));
684
9.76M
            if (Al > 0 && pred >= (1 << Al))
685
1.66M
              pred = (1 << Al) - 1;
686
9.76M
            pred = -pred;
687
9.76M
          }
688
37.8M
          workspace[9] = (JCOEF)pred;
689
37.8M
        }
690
        /* AC02 */
691
39.6M
        if ((Al = coef_bits[5]) != 0 && workspace[2] == 0) {
692
37.8M
          num = Q00 * (change_dc ?
693
23.7M
                (2 * DC07 - 5 * DC08 + 2 * DC09 + DC11 + 7 * DC12 - 14 * DC13 +
694
23.7M
                 7 * DC14 + DC15 + 2 * DC17 - 5 * DC18 + 2 * DC19) :
695
37.8M
                (-DC11 + 13 * DC12 - 24 * DC13 + 13 * DC14 - DC15));
696
37.8M
          if (num >= 0) {
697
23.0M
            pred = (int)(((Q02 << 7) + num) / (Q02 << 8));
698
23.0M
            if (Al > 0 && pred >= (1 << Al))
699
1.95M
              pred = (1 << Al) - 1;
700
23.0M
          } else {
701
14.8M
            pred = (int)(((Q02 << 7) - num) / (Q02 << 8));
702
14.8M
            if (Al > 0 && pred >= (1 << Al))
703
1.88M
              pred = (1 << Al) - 1;
704
14.8M
            pred = -pred;
705
14.8M
          }
706
37.8M
          workspace[2] = (JCOEF)pred;
707
37.8M
        }
708
39.6M
        if (change_dc) {
709
          /* AC03 */
710
23.7M
          if ((Al = coef_bits[6]) != 0 && workspace[3] == 0) {
711
23.7M
            num = Q00 * (DC07 - DC09 + 2 * DC12 - 2 * DC14 + DC17 - DC19);
712
23.7M
            if (num >= 0) {
713
18.7M
              pred = (int)(((Q03 << 7) + num) / (Q03 << 8));
714
18.7M
              if (Al > 0 && pred >= (1 << Al))
715
0
                pred = (1 << Al) - 1;
716
18.7M
            } else {
717
4.91M
              pred = (int)(((Q03 << 7) - num) / (Q03 << 8));
718
4.91M
              if (Al > 0 && pred >= (1 << Al))
719
0
                pred = (1 << Al) - 1;
720
4.91M
              pred = -pred;
721
4.91M
            }
722
23.7M
            workspace[3] = (JCOEF)pred;
723
23.7M
          }
724
          /* AC12 */
725
23.7M
          if ((Al = coef_bits[7]) != 0 && workspace[10] == 0) {
726
23.7M
            num = Q00 * (DC07 - 3 * DC08 + DC09 - DC17 + 3 * DC18 - DC19);
727
23.7M
            if (num >= 0) {
728
13.5M
              pred = (int)(((Q12 << 7) + num) / (Q12 << 8));
729
13.5M
              if (Al > 0 && pred >= (1 << Al))
730
0
                pred = (1 << Al) - 1;
731
13.5M
            } else {
732
10.1M
              pred = (int)(((Q12 << 7) - num) / (Q12 << 8));
733
10.1M
              if (Al > 0 && pred >= (1 << Al))
734
0
                pred = (1 << Al) - 1;
735
10.1M
              pred = -pred;
736
10.1M
            }
737
23.7M
            workspace[10] = (JCOEF)pred;
738
23.7M
          }
739
          /* AC21 */
740
23.7M
          if ((Al = coef_bits[8]) != 0 && workspace[17] == 0) {
741
23.7M
            num = Q00 * (DC07 - DC09 - 3 * DC12 + 3 * DC14 + DC17 - DC19);
742
23.7M
            if (num >= 0) {
743
13.1M
              pred = (int)(((Q21 << 7) + num) / (Q21 << 8));
744
13.1M
              if (Al > 0 && pred >= (1 << Al))
745
0
                pred = (1 << Al) - 1;
746
13.1M
            } else {
747
10.5M
              pred = (int)(((Q21 << 7) - num) / (Q21 << 8));
748
10.5M
              if (Al > 0 && pred >= (1 << Al))
749
0
                pred = (1 << Al) - 1;
750
10.5M
              pred = -pred;
751
10.5M
            }
752
23.7M
            workspace[17] = (JCOEF)pred;
753
23.7M
          }
754
          /* AC30 */
755
23.7M
          if ((Al = coef_bits[9]) != 0 && workspace[24] == 0) {
756
23.7M
            num = Q00 * (DC07 + 2 * DC08 + DC09 - DC17 - 2 * DC18 - DC19);
757
23.7M
            if (num >= 0) {
758
17.1M
              pred = (int)(((Q30 << 7) + num) / (Q30 << 8));
759
17.1M
              if (Al > 0 && pred >= (1 << Al))
760
0
                pred = (1 << Al) - 1;
761
17.1M
            } else {
762
6.51M
              pred = (int)(((Q30 << 7) - num) / (Q30 << 8));
763
6.51M
              if (Al > 0 && pred >= (1 << Al))
764
0
                pred = (1 << Al) - 1;
765
6.51M
              pred = -pred;
766
6.51M
            }
767
23.7M
            workspace[24] = (JCOEF)pred;
768
23.7M
          }
769
          /* coef_bits[0] is non-negative.  Otherwise this function would not
770
           * be called.
771
           */
772
23.7M
          num = Q00 *
773
23.7M
                (-2 * DC01 - 6 * DC02 - 8 * DC03 - 6 * DC04 - 2 * DC05 -
774
23.7M
                 6 * DC06 + 6 * DC07 + 42 * DC08 + 6 * DC09 - 6 * DC10 -
775
23.7M
                 8 * DC11 + 42 * DC12 + 152 * DC13 + 42 * DC14 - 8 * DC15 -
776
23.7M
                 6 * DC16 + 6 * DC17 + 42 * DC18 + 6 * DC19 - 6 * DC20 -
777
23.7M
                 2 * DC21 - 6 * DC22 - 8 * DC23 - 6 * DC24 - 2 * DC25);
778
23.7M
          if (num >= 0) {
779
14.2M
            pred = (int)(((Q00 << 7) + num) / (Q00 << 8));
780
14.2M
          } else {
781
9.47M
            pred = (int)(((Q00 << 7) - num) / (Q00 << 8));
782
9.47M
            pred = -pred;
783
9.47M
          }
784
23.7M
          workspace[0] = (JCOEF)pred;
785
23.7M
        }  /* change_dc */
786
787
        /* OK, do the IDCT */
788
39.6M
        (*inverse_DCT) (cinfo, compptr, (JCOEFPTR)workspace, output_ptr,
789
39.6M
                        output_col);
790
        /* Advance for next column */
791
39.6M
        DC01 = DC02;  DC02 = DC03;  DC03 = DC04;  DC04 = DC05;
792
39.6M
        DC06 = DC07;  DC07 = DC08;  DC08 = DC09;  DC09 = DC10;
793
39.6M
        DC11 = DC12;  DC12 = DC13;  DC13 = DC14;  DC14 = DC15;
794
39.6M
        DC16 = DC17;  DC17 = DC18;  DC18 = DC19;  DC19 = DC20;
795
39.6M
        DC21 = DC22;  DC22 = DC23;  DC23 = DC24;  DC24 = DC25;
796
39.6M
        buffer_ptr++, prev_block_row++, next_block_row++,
797
39.6M
          prev_prev_block_row++, next_next_block_row++;
798
39.6M
        output_col += compptr->_DCT_scaled_size;
799
39.6M
      }
800
5.51M
      output_ptr += compptr->_DCT_scaled_size;
801
5.51M
    }
802
3.52M
  }
803
804
2.32M
  if (++(cinfo->output_iMCU_row) < cinfo->total_iMCU_rows)
805
2.31M
    return JPEG_ROW_COMPLETED;
806
5.16k
  return JPEG_SCAN_COMPLETED;
807
2.32M
}
808
809
#endif /* BLOCK_SMOOTHING_SUPPORTED */
810
811
812
/*
813
 * Initialize coefficient buffer controller.
814
 */
815
816
GLOBAL(void)
817
_jinit_d_coef_controller(j_decompress_ptr cinfo, boolean need_full_buffer)
818
146k
{
819
146k
  my_coef_ptr coef;
820
821
146k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
822
20
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
823
824
146k
  coef = (my_coef_ptr)
825
146k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
826
146k
                                sizeof(my_coef_controller));
827
146k
  memset(coef, 0, sizeof(my_coef_controller));
828
146k
  cinfo->coef = (struct jpeg_d_coef_controller *)coef;
829
146k
  coef->pub.start_input_pass = start_input_pass;
830
146k
  coef->pub.start_output_pass = start_output_pass;
831
146k
#ifdef BLOCK_SMOOTHING_SUPPORTED
832
146k
  coef->coef_bits_latch = NULL;
833
146k
#endif
834
835
  /* Create the coefficient buffer. */
836
146k
  if (need_full_buffer) {
837
117k
#ifdef D_MULTISCAN_FILES_SUPPORTED
838
    /* Allocate a full-image virtual array for each component, */
839
    /* padded to a multiple of samp_factor DCT blocks in each direction. */
840
    /* Note we ask for a pre-zeroed array. */
841
117k
    int ci, access_rows;
842
117k
    jpeg_component_info *compptr;
843
844
366k
    for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
845
248k
         ci++, compptr++) {
846
248k
      access_rows = compptr->v_samp_factor;
847
248k
#ifdef BLOCK_SMOOTHING_SUPPORTED
848
      /* If block smoothing could be used, need a bigger window */
849
248k
      if (cinfo->progressive_mode)
850
138k
        access_rows *= 5;
851
248k
#endif
852
248k
      coef->whole_image[ci] = (*cinfo->mem->request_virt_barray)
853
248k
        ((j_common_ptr)cinfo, JPOOL_IMAGE, TRUE,
854
248k
         (JDIMENSION)jround_up((long)compptr->width_in_blocks,
855
248k
                               (long)compptr->h_samp_factor),
856
248k
         (JDIMENSION)jround_up((long)compptr->height_in_blocks,
857
248k
                               (long)compptr->v_samp_factor),
858
248k
         (JDIMENSION)access_rows);
859
248k
    }
860
117k
    coef->pub.consume_data = consume_data;
861
117k
    coef->pub._decompress_data = decompress_data;
862
117k
    coef->pub.coef_arrays = coef->whole_image; /* link to virtual arrays */
863
#else
864
    ERREXIT(cinfo, JERR_NOT_COMPILED);
865
#endif
866
117k
  } else {
867
    /* We only need a single-MCU buffer. */
868
29.1k
    JBLOCKROW buffer;
869
29.1k
    int i;
870
871
29.1k
    buffer = (JBLOCKROW)
872
29.1k
      (*cinfo->mem->alloc_large) ((j_common_ptr)cinfo, JPOOL_IMAGE,
873
29.1k
                                  D_MAX_BLOCKS_IN_MCU * sizeof(JBLOCK));
874
320k
    for (i = 0; i < D_MAX_BLOCKS_IN_MCU; i++) {
875
291k
      coef->MCU_buffer[i] = buffer + i;
876
291k
    }
877
29.1k
    coef->pub.consume_data = dummy_consume_data;
878
29.1k
    coef->pub._decompress_data = decompress_onepass;
879
29.1k
    coef->pub.coef_arrays = NULL; /* flag for no virtual arrays */
880
29.1k
  }
881
882
  /* Allocate the workspace buffer */
883
146k
  coef->workspace = (JCOEF *)
884
146k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
885
146k
                                sizeof(JCOEF) * DCTSIZE2);
886
146k
}
j12init_d_coef_controller
Line
Count
Source
818
29.3k
{
819
29.3k
  my_coef_ptr coef;
820
821
29.3k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
822
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
823
824
29.3k
  coef = (my_coef_ptr)
825
29.3k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
826
29.3k
                                sizeof(my_coef_controller));
827
29.3k
  memset(coef, 0, sizeof(my_coef_controller));
828
29.3k
  cinfo->coef = (struct jpeg_d_coef_controller *)coef;
829
29.3k
  coef->pub.start_input_pass = start_input_pass;
830
29.3k
  coef->pub.start_output_pass = start_output_pass;
831
29.3k
#ifdef BLOCK_SMOOTHING_SUPPORTED
832
29.3k
  coef->coef_bits_latch = NULL;
833
29.3k
#endif
834
835
  /* Create the coefficient buffer. */
836
29.3k
  if (need_full_buffer) {
837
23.8k
#ifdef D_MULTISCAN_FILES_SUPPORTED
838
    /* Allocate a full-image virtual array for each component, */
839
    /* padded to a multiple of samp_factor DCT blocks in each direction. */
840
    /* Note we ask for a pre-zeroed array. */
841
23.8k
    int ci, access_rows;
842
23.8k
    jpeg_component_info *compptr;
843
844
73.3k
    for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
845
49.4k
         ci++, compptr++) {
846
49.4k
      access_rows = compptr->v_samp_factor;
847
49.4k
#ifdef BLOCK_SMOOTHING_SUPPORTED
848
      /* If block smoothing could be used, need a bigger window */
849
49.4k
      if (cinfo->progressive_mode)
850
26.9k
        access_rows *= 5;
851
49.4k
#endif
852
49.4k
      coef->whole_image[ci] = (*cinfo->mem->request_virt_barray)
853
49.4k
        ((j_common_ptr)cinfo, JPOOL_IMAGE, TRUE,
854
49.4k
         (JDIMENSION)jround_up((long)compptr->width_in_blocks,
855
49.4k
                               (long)compptr->h_samp_factor),
856
49.4k
         (JDIMENSION)jround_up((long)compptr->height_in_blocks,
857
49.4k
                               (long)compptr->v_samp_factor),
858
49.4k
         (JDIMENSION)access_rows);
859
49.4k
    }
860
23.8k
    coef->pub.consume_data = consume_data;
861
23.8k
    coef->pub._decompress_data = decompress_data;
862
23.8k
    coef->pub.coef_arrays = coef->whole_image; /* link to virtual arrays */
863
#else
864
    ERREXIT(cinfo, JERR_NOT_COMPILED);
865
#endif
866
23.8k
  } else {
867
    /* We only need a single-MCU buffer. */
868
5.49k
    JBLOCKROW buffer;
869
5.49k
    int i;
870
871
5.49k
    buffer = (JBLOCKROW)
872
5.49k
      (*cinfo->mem->alloc_large) ((j_common_ptr)cinfo, JPOOL_IMAGE,
873
5.49k
                                  D_MAX_BLOCKS_IN_MCU * sizeof(JBLOCK));
874
60.4k
    for (i = 0; i < D_MAX_BLOCKS_IN_MCU; i++) {
875
54.9k
      coef->MCU_buffer[i] = buffer + i;
876
54.9k
    }
877
5.49k
    coef->pub.consume_data = dummy_consume_data;
878
5.49k
    coef->pub._decompress_data = decompress_onepass;
879
5.49k
    coef->pub.coef_arrays = NULL; /* flag for no virtual arrays */
880
5.49k
  }
881
882
  /* Allocate the workspace buffer */
883
29.3k
  coef->workspace = (JCOEF *)
884
29.3k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
885
29.3k
                                sizeof(JCOEF) * DCTSIZE2);
886
29.3k
}
jinit_d_coef_controller
Line
Count
Source
818
117k
{
819
117k
  my_coef_ptr coef;
820
821
117k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
822
20
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
823
824
117k
  coef = (my_coef_ptr)
825
117k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
826
117k
                                sizeof(my_coef_controller));
827
117k
  memset(coef, 0, sizeof(my_coef_controller));
828
117k
  cinfo->coef = (struct jpeg_d_coef_controller *)coef;
829
117k
  coef->pub.start_input_pass = start_input_pass;
830
117k
  coef->pub.start_output_pass = start_output_pass;
831
117k
#ifdef BLOCK_SMOOTHING_SUPPORTED
832
117k
  coef->coef_bits_latch = NULL;
833
117k
#endif
834
835
  /* Create the coefficient buffer. */
836
117k
  if (need_full_buffer) {
837
93.7k
#ifdef D_MULTISCAN_FILES_SUPPORTED
838
    /* Allocate a full-image virtual array for each component, */
839
    /* padded to a multiple of samp_factor DCT blocks in each direction. */
840
    /* Note we ask for a pre-zeroed array. */
841
93.7k
    int ci, access_rows;
842
93.7k
    jpeg_component_info *compptr;
843
844
292k
    for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
845
199k
         ci++, compptr++) {
846
199k
      access_rows = compptr->v_samp_factor;
847
199k
#ifdef BLOCK_SMOOTHING_SUPPORTED
848
      /* If block smoothing could be used, need a bigger window */
849
199k
      if (cinfo->progressive_mode)
850
111k
        access_rows *= 5;
851
199k
#endif
852
199k
      coef->whole_image[ci] = (*cinfo->mem->request_virt_barray)
853
199k
        ((j_common_ptr)cinfo, JPOOL_IMAGE, TRUE,
854
199k
         (JDIMENSION)jround_up((long)compptr->width_in_blocks,
855
199k
                               (long)compptr->h_samp_factor),
856
199k
         (JDIMENSION)jround_up((long)compptr->height_in_blocks,
857
199k
                               (long)compptr->v_samp_factor),
858
199k
         (JDIMENSION)access_rows);
859
199k
    }
860
93.7k
    coef->pub.consume_data = consume_data;
861
93.7k
    coef->pub._decompress_data = decompress_data;
862
93.7k
    coef->pub.coef_arrays = coef->whole_image; /* link to virtual arrays */
863
#else
864
    ERREXIT(cinfo, JERR_NOT_COMPILED);
865
#endif
866
93.7k
  } else {
867
    /* We only need a single-MCU buffer. */
868
23.6k
    JBLOCKROW buffer;
869
23.6k
    int i;
870
871
23.6k
    buffer = (JBLOCKROW)
872
23.6k
      (*cinfo->mem->alloc_large) ((j_common_ptr)cinfo, JPOOL_IMAGE,
873
23.6k
                                  D_MAX_BLOCKS_IN_MCU * sizeof(JBLOCK));
874
260k
    for (i = 0; i < D_MAX_BLOCKS_IN_MCU; i++) {
875
236k
      coef->MCU_buffer[i] = buffer + i;
876
236k
    }
877
23.6k
    coef->pub.consume_data = dummy_consume_data;
878
23.6k
    coef->pub._decompress_data = decompress_onepass;
879
23.6k
    coef->pub.coef_arrays = NULL; /* flag for no virtual arrays */
880
23.6k
  }
881
882
  /* Allocate the workspace buffer */
883
117k
  coef->workspace = (JCOEF *)
884
117k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
885
117k
                                sizeof(JCOEF) * DCTSIZE2);
886
117k
}