Coverage Report

Created: 2024-01-17 16:58

/src/libjpeg-turbo.main/jdcoefct.c
Line
Count
Source (jump to first uncovered line)
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, 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
209k
{
48
209k
  cinfo->input_iMCU_row = 0;
49
209k
  start_iMCU_row(cinfo);
50
209k
}
51
52
53
/*
54
 * Initialize for an output processing pass.
55
 */
56
57
METHODDEF(void)
58
start_output_pass(j_decompress_ptr cinfo)
59
28.7k
{
60
28.7k
#ifdef BLOCK_SMOOTHING_SUPPORTED
61
28.7k
  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
28.7k
  if (coef->pub.coef_arrays != NULL) {
65
12.1k
    if (cinfo->do_block_smoothing && smoothing_ok(cinfo))
66
5.13k
      coef->pub._decompress_data = decompress_smooth_data;
67
6.97k
    else
68
6.97k
      coef->pub._decompress_data = decompress_data;
69
12.1k
  }
70
28.7k
#endif
71
28.7k
  cinfo->output_iMCU_row = 0;
72
28.7k
}
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
417k
{
88
417k
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
89
417k
  JDIMENSION MCU_col_num;       /* index of current MCU within row */
90
417k
  JDIMENSION last_MCU_col = cinfo->MCUs_per_row - 1;
91
417k
  JDIMENSION last_iMCU_row = cinfo->total_iMCU_rows - 1;
92
417k
  int blkn, ci, xindex, yindex, yoffset, useful_width;
93
417k
  _JSAMPARRAY output_ptr;
94
417k
  JDIMENSION start_col, output_col;
95
417k
  jpeg_component_info *compptr;
96
417k
  _inverse_DCT_method_ptr inverse_DCT;
97
98
  /* Loop to process as much as one whole iMCU row */
99
899k
  for (yoffset = coef->MCU_vert_offset; yoffset < coef->MCU_rows_per_iMCU_row;
100
482k
       yoffset++) {
101
3.08M
    for (MCU_col_num = coef->MCU_ctr; MCU_col_num <= last_MCU_col;
102
2.60M
         MCU_col_num++) {
103
      /* Try to fetch an MCU.  Entropy decoder expects buffer to be zeroed. */
104
2.60M
      jzero_far((void *)coef->MCU_buffer[0],
105
2.60M
                (size_t)(cinfo->blocks_in_MCU * sizeof(JBLOCK)));
106
2.60M
      if (!cinfo->entropy->insufficient_data)
107
987k
        cinfo->master->last_good_iMCU_row = cinfo->input_iMCU_row;
108
2.60M
      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
2.60M
      if (MCU_col_num >= cinfo->master->first_iMCU_col &&
119
2.60M
          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
2.60M
        blkn = 0;               /* index of current DCT block within MCU */
126
8.40M
        for (ci = 0; ci < cinfo->comps_in_scan; ci++) {
127
5.80M
          compptr = cinfo->cur_comp_info[ci];
128
          /* Don't bother to IDCT an uninteresting component. */
129
5.80M
          if (!compptr->component_needed) {
130
162k
            blkn += compptr->MCU_blocks;
131
162k
            continue;
132
162k
          }
133
5.63M
          inverse_DCT = cinfo->idct->_inverse_DCT[compptr->component_index];
134
5.63M
          useful_width = (MCU_col_num < last_MCU_col) ?
135
4.65M
                         compptr->MCU_width : compptr->last_col_width;
136
5.63M
          output_ptr = output_buf[compptr->component_index] +
137
5.63M
                       yoffset * compptr->_DCT_scaled_size;
138
5.63M
          start_col = (MCU_col_num - cinfo->master->first_iMCU_col) *
139
5.63M
                      compptr->MCU_sample_width;
140
13.1M
          for (yindex = 0; yindex < compptr->MCU_height; yindex++) {
141
7.49M
            if (cinfo->input_iMCU_row < last_iMCU_row ||
142
7.49M
                yoffset + yindex < compptr->last_row_height) {
143
7.32M
              output_col = start_col;
144
18.3M
              for (xindex = 0; xindex < useful_width; xindex++) {
145
11.0M
                (*inverse_DCT) (cinfo, compptr,
146
11.0M
                                (JCOEFPTR)coef->MCU_buffer[blkn + xindex],
147
11.0M
                                output_ptr, output_col);
148
11.0M
                output_col += compptr->_DCT_scaled_size;
149
11.0M
              }
150
7.32M
            }
151
7.49M
            blkn += compptr->MCU_width;
152
7.49M
            output_ptr += compptr->_DCT_scaled_size;
153
7.49M
          }
154
5.63M
        }
155
2.60M
      }
156
2.60M
    }
157
    /* Completed an MCU row, but perhaps not an iMCU row */
158
482k
    coef->MCU_ctr = 0;
159
482k
  }
160
  /* Completed the iMCU row, advance counters for next one */
161
417k
  cinfo->output_iMCU_row++;
162
417k
  if (++(cinfo->input_iMCU_row) < cinfo->total_iMCU_rows) {
163
400k
    start_iMCU_row(cinfo);
164
400k
    return JPEG_ROW_COMPLETED;
165
400k
  }
166
  /* Completed the scan */
167
16.6k
  (*cinfo->inputctl->finish_input_pass) (cinfo);
168
16.6k
  return JPEG_SCAN_COMPLETED;
169
417k
}
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
6.11M
{
195
6.11M
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
196
6.11M
  JDIMENSION MCU_col_num;       /* index of current MCU within row */
197
6.11M
  int blkn, ci, xindex, yindex, yoffset;
198
6.11M
  JDIMENSION start_col;
199
6.11M
  JBLOCKARRAY buffer[MAX_COMPS_IN_SCAN];
200
6.11M
  JBLOCKROW buffer_ptr;
201
6.11M
  jpeg_component_info *compptr;
202
203
  /* Align the virtual buffers for the components used in this scan. */
204
16.2M
  for (ci = 0; ci < cinfo->comps_in_scan; ci++) {
205
10.1M
    compptr = cinfo->cur_comp_info[ci];
206
10.1M
    buffer[ci] = (*cinfo->mem->access_virt_barray)
207
10.1M
      ((j_common_ptr)cinfo, coef->whole_image[compptr->component_index],
208
10.1M
       cinfo->input_iMCU_row * compptr->v_samp_factor,
209
10.1M
       (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
10.1M
  }
215
216
  /* Loop to process one whole iMCU row */
217
14.8M
  for (yoffset = coef->MCU_vert_offset; yoffset < coef->MCU_rows_per_iMCU_row;
218
8.73M
       yoffset++) {
219
49.5M
    for (MCU_col_num = coef->MCU_ctr; MCU_col_num < cinfo->MCUs_per_row;
220
40.7M
         MCU_col_num++) {
221
      /* Construct list of pointers to DCT blocks belonging to this MCU */
222
40.7M
      blkn = 0;                 /* index of current DCT block within MCU */
223
96.7M
      for (ci = 0; ci < cinfo->comps_in_scan; ci++) {
224
55.9M
        compptr = cinfo->cur_comp_info[ci];
225
55.9M
        start_col = MCU_col_num * compptr->MCU_width;
226
123M
        for (yindex = 0; yindex < compptr->MCU_height; yindex++) {
227
67.3M
          buffer_ptr = buffer[ci][yindex + yoffset] + start_col;
228
147M
          for (xindex = 0; xindex < compptr->MCU_width; xindex++) {
229
80.6M
            coef->MCU_buffer[blkn++] = buffer_ptr++;
230
80.6M
          }
231
67.3M
        }
232
55.9M
      }
233
40.7M
      if (!cinfo->entropy->insufficient_data)
234
21.8M
        cinfo->master->last_good_iMCU_row = cinfo->input_iMCU_row;
235
      /* Try to fetch the MCU. */
236
40.7M
      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
40.7M
    }
243
    /* Completed an MCU row, but perhaps not an iMCU row */
244
8.73M
    coef->MCU_ctr = 0;
245
8.73M
  }
246
  /* Completed the iMCU row, advance counters for next one */
247
6.11M
  if (++(cinfo->input_iMCU_row) < cinfo->total_iMCU_rows) {
248
5.92M
    start_iMCU_row(cinfo);
249
5.92M
    return JPEG_ROW_COMPLETED;
250
5.92M
  }
251
  /* Completed the scan */
252
192k
  (*cinfo->inputctl->finish_input_pass) (cinfo);
253
192k
  return JPEG_SCAN_COMPLETED;
254
6.11M
}
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
503k
{
268
503k
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
269
503k
  JDIMENSION last_iMCU_row = cinfo->total_iMCU_rows - 1;
270
503k
  JDIMENSION block_num;
271
503k
  int ci, block_row, block_rows;
272
503k
  JBLOCKARRAY buffer;
273
503k
  JBLOCKROW buffer_ptr;
274
503k
  _JSAMPARRAY output_ptr;
275
503k
  JDIMENSION output_col;
276
503k
  jpeg_component_info *compptr;
277
503k
  _inverse_DCT_method_ptr inverse_DCT;
278
279
  /* Force some input to be done if we are getting ahead of the input. */
280
503k
  while (cinfo->input_scan_number < cinfo->output_scan_number ||
281
503k
         (cinfo->input_scan_number == cinfo->output_scan_number &&
282
503k
          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
2.01M
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
289
1.51M
       ci++, compptr++) {
290
    /* Don't bother to IDCT an uninteresting component. */
291
1.51M
    if (!compptr->component_needed)
292
195k
      continue;
293
    /* Align the virtual buffer for this component. */
294
1.31M
    buffer = (*cinfo->mem->access_virt_barray)
295
1.31M
      ((j_common_ptr)cinfo, coef->whole_image[ci],
296
1.31M
       cinfo->output_iMCU_row * compptr->v_samp_factor,
297
1.31M
       (JDIMENSION)compptr->v_samp_factor, FALSE);
298
    /* Count non-dummy DCT block rows in this iMCU row. */
299
1.31M
    if (cinfo->output_iMCU_row < last_iMCU_row)
300
1.29M
      block_rows = compptr->v_samp_factor;
301
18.2k
    else {
302
      /* NB: can't use last_row_height here; it is input-side-dependent! */
303
18.2k
      block_rows = (int)(compptr->height_in_blocks % compptr->v_samp_factor);
304
18.2k
      if (block_rows == 0) block_rows = compptr->v_samp_factor;
305
18.2k
    }
306
1.31M
    inverse_DCT = cinfo->idct->_inverse_DCT[ci];
307
1.31M
    output_ptr = output_buf[ci];
308
    /* Loop over all DCT blocks to be processed. */
309
3.48M
    for (block_row = 0; block_row < block_rows; block_row++) {
310
2.16M
      buffer_ptr = buffer[block_row] + cinfo->master->first_MCU_col[ci];
311
2.16M
      output_col = 0;
312
2.16M
      for (block_num = cinfo->master->first_MCU_col[ci];
313
10.3M
           block_num <= cinfo->master->last_MCU_col[ci]; block_num++) {
314
8.22M
        (*inverse_DCT) (cinfo, compptr, (JCOEFPTR)buffer_ptr, output_ptr,
315
8.22M
                        output_col);
316
8.22M
        buffer_ptr++;
317
8.22M
        output_col += compptr->_DCT_scaled_size;
318
8.22M
      }
319
2.16M
      output_ptr += compptr->_DCT_scaled_size;
320
2.16M
    }
321
1.31M
  }
322
323
503k
  if (++(cinfo->output_iMCU_row) < cinfo->total_iMCU_rows)
324
496k
    return JPEG_ROW_COMPLETED;
325
6.97k
  return JPEG_SCAN_COMPLETED;
326
503k
}
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
2.10M
#define Q01_POS  1
342
2.10M
#define Q10_POS  8
343
2.10M
#define Q20_POS  16
344
2.10M
#define Q11_POS  9
345
2.10M
#define Q02_POS  2
346
1.45M
#define Q03_POS  3
347
1.45M
#define Q12_POS  10
348
1.45M
#define Q21_POS  17
349
1.45M
#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.1k
{
362
12.1k
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
363
12.1k
  boolean smoothing_useful = FALSE;
364
12.1k
  int ci, coefi;
365
12.1k
  jpeg_component_info *compptr;
366
12.1k
  JQUANT_TBL *qtable;
367
12.1k
  int *coef_bits, *prev_coef_bits;
368
12.1k
  int *coef_bits_latch, *prev_coef_bits_latch;
369
370
12.1k
  if (!cinfo->progressive_mode || cinfo->coef_bits == NULL)
371
569
    return FALSE;
372
373
  /* Allocate latch area if not already done */
374
11.5k
  if (coef->coef_bits_latch == NULL)
375
11.5k
    coef->coef_bits_latch = (int *)
376
11.5k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
377
11.5k
                                  cinfo->num_components * 2 *
378
11.5k
                                  (SAVED_COEFS * sizeof(int)));
379
11.5k
  coef_bits_latch = coef->coef_bits_latch;
380
11.5k
  prev_coef_bits_latch =
381
11.5k
    &coef->coef_bits_latch[cinfo->num_components * SAVED_COEFS];
382
383
28.3k
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
384
23.1k
       ci++, compptr++) {
385
    /* All components' quantization values must already be latched. */
386
23.1k
    if ((qtable = compptr->quant_table) == NULL)
387
2.24k
      return FALSE;
388
    /* Verify DC & first 9 AC quantizers are nonzero to avoid zero-divide. */
389
20.9k
    if (qtable->quantval[0] == 0 ||
390
20.9k
        qtable->quantval[Q01_POS] == 0 ||
391
20.9k
        qtable->quantval[Q10_POS] == 0 ||
392
20.9k
        qtable->quantval[Q20_POS] == 0 ||
393
20.9k
        qtable->quantval[Q11_POS] == 0 ||
394
20.9k
        qtable->quantval[Q02_POS] == 0 ||
395
20.9k
        qtable->quantval[Q03_POS] == 0 ||
396
20.9k
        qtable->quantval[Q12_POS] == 0 ||
397
20.9k
        qtable->quantval[Q21_POS] == 0 ||
398
20.9k
        qtable->quantval[Q30_POS] == 0)
399
4.09k
      return FALSE;
400
    /* DC values must be at least partly known for all components. */
401
16.8k
    coef_bits = cinfo->coef_bits[ci];
402
16.8k
    prev_coef_bits = cinfo->coef_bits[ci + cinfo->num_components];
403
16.8k
    if (coef_bits[0] < 0)
404
57
      return FALSE;
405
16.7k
    coef_bits_latch[0] = coef_bits[0];
406
    /* Block smoothing is helpful if some AC coefficients remain inaccurate. */
407
167k
    for (coefi = 1; coefi < SAVED_COEFS; coefi++) {
408
151k
      if (cinfo->input_scan_number > 1)
409
74.3k
        prev_coef_bits_latch[coefi] = prev_coef_bits[coefi];
410
76.8k
      else
411
76.8k
        prev_coef_bits_latch[coefi] = -1;
412
151k
      coef_bits_latch[coefi] = coef_bits[coefi];
413
151k
      if (coef_bits[coefi] != 0)
414
147k
        smoothing_useful = TRUE;
415
151k
    }
416
16.7k
    coef_bits_latch += SAVED_COEFS;
417
16.7k
    prev_coef_bits_latch += SAVED_COEFS;
418
16.7k
  }
419
420
5.13k
  return smoothing_useful;
421
11.5k
}
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
721k
{
431
721k
  my_coef_ptr coef = (my_coef_ptr)cinfo->coef;
432
721k
  JDIMENSION last_iMCU_row = cinfo->total_iMCU_rows - 1;
433
721k
  JDIMENSION block_num, last_block_column;
434
721k
  int ci, block_row, block_rows, access_rows;
435
721k
  JBLOCKARRAY buffer;
436
721k
  JBLOCKROW buffer_ptr, prev_prev_block_row, prev_block_row;
437
721k
  JBLOCKROW next_block_row, next_next_block_row;
438
721k
  _JSAMPARRAY output_ptr;
439
721k
  JDIMENSION output_col;
440
721k
  jpeg_component_info *compptr;
441
721k
  _inverse_DCT_method_ptr inverse_DCT;
442
721k
  boolean change_dc;
443
721k
  JCOEF *workspace;
444
721k
  int *coef_bits;
445
721k
  JQUANT_TBL *quanttbl;
446
721k
  JLONG Q00, Q01, Q02, Q03 = 0, Q10, Q11, Q12 = 0, Q20, Q21 = 0, Q30 = 0, num;
447
721k
  int DC01, DC02, DC03, DC04, DC05, DC06, DC07, DC08, DC09, DC10, DC11, DC12,
448
721k
      DC13, DC14, DC15, DC16, DC17, DC18, DC19, DC20, DC21, DC22, DC23, DC24,
449
721k
      DC25;
450
721k
  int Al, pred;
451
452
  /* Keep a local variable to avoid looking it up more than once */
453
721k
  workspace = coef->workspace;
454
455
  /* Force some input to be done if we are getting ahead of the input. */
456
721k
  while (cinfo->input_scan_number <= cinfo->output_scan_number &&
457
721k
         !cinfo->inputctl->eoi_reached) {
458
0
    if (cinfo->input_scan_number == cinfo->output_scan_number) {
459
      /* If input is working on current scan, we ordinarily want it to
460
       * have completed the current row.  But if input scan is DC,
461
       * we want it to keep two rows ahead so that next two block rows' DC
462
       * values are up to date.
463
       */
464
0
      JDIMENSION delta = (cinfo->Ss == 0) ? 2 : 0;
465
0
      if (cinfo->input_iMCU_row > cinfo->output_iMCU_row + delta)
466
0
        break;
467
0
    }
468
0
    if ((*cinfo->inputctl->consume_input) (cinfo) == JPEG_SUSPENDED)
469
0
      return JPEG_SUSPENDED;
470
0
  }
471
472
  /* OK, output from the virtual arrays. */
473
2.88M
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
474
2.16M
       ci++, compptr++) {
475
    /* Don't bother to IDCT an uninteresting component. */
476
2.16M
    if (!compptr->component_needed)
477
74.8k
      continue;
478
    /* Count non-dummy DCT block rows in this iMCU row. */
479
2.08M
    if (cinfo->output_iMCU_row + 1 < last_iMCU_row) {
480
2.06M
      block_rows = compptr->v_samp_factor;
481
2.06M
      access_rows = block_rows * 3; /* this and next two iMCU rows */
482
2.06M
    } else if (cinfo->output_iMCU_row < last_iMCU_row) {
483
11.2k
      block_rows = compptr->v_samp_factor;
484
11.2k
      access_rows = block_rows * 2; /* this and next iMCU row */
485
14.6k
    } else {
486
      /* NB: can't use last_row_height here; it is input-side-dependent! */
487
14.6k
      block_rows = (int)(compptr->height_in_blocks % compptr->v_samp_factor);
488
14.6k
      if (block_rows == 0) block_rows = compptr->v_samp_factor;
489
14.6k
      access_rows = block_rows; /* this iMCU row only */
490
14.6k
    }
491
    /* Align the virtual buffer for this component. */
492
2.08M
    if (cinfo->output_iMCU_row > 1) {
493
2.06M
      access_rows += 2 * compptr->v_samp_factor; /* prior two iMCU rows too */
494
2.06M
      buffer = (*cinfo->mem->access_virt_barray)
495
2.06M
        ((j_common_ptr)cinfo, coef->whole_image[ci],
496
2.06M
         (cinfo->output_iMCU_row - 2) * compptr->v_samp_factor,
497
2.06M
         (JDIMENSION)access_rows, FALSE);
498
2.06M
      buffer += 2 * compptr->v_samp_factor; /* point to current iMCU row */
499
2.06M
    } else if (cinfo->output_iMCU_row > 0) {
500
11.2k
      buffer = (*cinfo->mem->access_virt_barray)
501
11.2k
        ((j_common_ptr)cinfo, coef->whole_image[ci],
502
11.2k
         (cinfo->output_iMCU_row - 1) * compptr->v_samp_factor,
503
11.2k
         (JDIMENSION)access_rows, FALSE);
504
11.2k
      buffer += compptr->v_samp_factor; /* point to current iMCU row */
505
14.6k
    } else {
506
14.6k
      buffer = (*cinfo->mem->access_virt_barray)
507
14.6k
        ((j_common_ptr)cinfo, coef->whole_image[ci],
508
14.6k
         (JDIMENSION)0, (JDIMENSION)access_rows, FALSE);
509
14.6k
    }
510
    /* Fetch component-dependent info.
511
     * If the current scan is incomplete, then we use the component-dependent
512
     * info from the previous scan.
513
     */
514
2.08M
    if (cinfo->output_iMCU_row > cinfo->master->last_good_iMCU_row)
515
1.10M
      coef_bits =
516
1.10M
        coef->coef_bits_latch + ((ci + cinfo->num_components) * SAVED_COEFS);
517
984k
    else
518
984k
      coef_bits = coef->coef_bits_latch + (ci * SAVED_COEFS);
519
520
    /* We only do DC interpolation if no AC coefficient data is available. */
521
2.08M
    change_dc =
522
2.08M
      coef_bits[1] == -1 && coef_bits[2] == -1 && coef_bits[3] == -1 &&
523
2.08M
      coef_bits[4] == -1 && coef_bits[5] == -1 && coef_bits[6] == -1 &&
524
2.08M
      coef_bits[7] == -1 && coef_bits[8] == -1 && coef_bits[9] == -1;
525
526
2.08M
    quanttbl = compptr->quant_table;
527
2.08M
    Q00 = quanttbl->quantval[0];
528
2.08M
    Q01 = quanttbl->quantval[Q01_POS];
529
2.08M
    Q10 = quanttbl->quantval[Q10_POS];
530
2.08M
    Q20 = quanttbl->quantval[Q20_POS];
531
2.08M
    Q11 = quanttbl->quantval[Q11_POS];
532
2.08M
    Q02 = quanttbl->quantval[Q02_POS];
533
2.08M
    if (change_dc) {
534
1.43M
      Q03 = quanttbl->quantval[Q03_POS];
535
1.43M
      Q12 = quanttbl->quantval[Q12_POS];
536
1.43M
      Q21 = quanttbl->quantval[Q21_POS];
537
1.43M
      Q30 = quanttbl->quantval[Q30_POS];
538
1.43M
    }
539
2.08M
    inverse_DCT = cinfo->idct->_inverse_DCT[ci];
540
2.08M
    output_ptr = output_buf[ci];
541
    /* Loop over all DCT blocks to be processed. */
542
4.81M
    for (block_row = 0; block_row < block_rows; block_row++) {
543
2.73M
      buffer_ptr = buffer[block_row] + cinfo->master->first_MCU_col[ci];
544
545
2.73M
      if (block_row > 0 || cinfo->output_iMCU_row > 0)
546
2.71M
        prev_block_row =
547
2.71M
          buffer[block_row - 1] + cinfo->master->first_MCU_col[ci];
548
14.6k
      else
549
14.6k
        prev_block_row = buffer_ptr;
550
551
2.73M
      if (block_row > 1 || cinfo->output_iMCU_row > 1)
552
2.69M
        prev_prev_block_row =
553
2.69M
          buffer[block_row - 2] + cinfo->master->first_MCU_col[ci];
554
33.2k
      else
555
33.2k
        prev_prev_block_row = prev_block_row;
556
557
2.73M
      if (block_row < block_rows - 1 || cinfo->output_iMCU_row < last_iMCU_row)
558
2.71M
        next_block_row =
559
2.71M
          buffer[block_row + 1] + cinfo->master->first_MCU_col[ci];
560
14.6k
      else
561
14.6k
        next_block_row = buffer_ptr;
562
563
2.73M
      if (block_row < block_rows - 2 ||
564
2.73M
          cinfo->output_iMCU_row + 1 < last_iMCU_row)
565
2.69M
        next_next_block_row =
566
2.69M
          buffer[block_row + 2] + cinfo->master->first_MCU_col[ci];
567
32.3k
      else
568
32.3k
        next_next_block_row = next_block_row;
569
570
      /* We fetch the surrounding DC values using a sliding-register approach.
571
       * Initialize all 25 here so as to do the right thing on narrow pics.
572
       */
573
2.73M
      DC01 = DC02 = DC03 = DC04 = DC05 = (int)prev_prev_block_row[0][0];
574
2.73M
      DC06 = DC07 = DC08 = DC09 = DC10 = (int)prev_block_row[0][0];
575
2.73M
      DC11 = DC12 = DC13 = DC14 = DC15 = (int)buffer_ptr[0][0];
576
2.73M
      DC16 = DC17 = DC18 = DC19 = DC20 = (int)next_block_row[0][0];
577
2.73M
      DC21 = DC22 = DC23 = DC24 = DC25 = (int)next_next_block_row[0][0];
578
2.73M
      output_col = 0;
579
2.73M
      last_block_column = compptr->width_in_blocks - 1;
580
2.73M
      for (block_num = cinfo->master->first_MCU_col[ci];
581
12.2M
           block_num <= cinfo->master->last_MCU_col[ci]; block_num++) {
582
        /* Fetch current DCT block into workspace so we can modify it. */
583
9.48M
        jcopy_block_row(buffer_ptr, (JBLOCKROW)workspace, (JDIMENSION)1);
584
        /* Update DC values */
585
9.48M
        if (block_num == cinfo->master->first_MCU_col[ci] &&
586
9.48M
            block_num < last_block_column) {
587
1.63M
          DC04 = (int)prev_prev_block_row[1][0];
588
1.63M
          DC09 = (int)prev_block_row[1][0];
589
1.63M
          DC14 = (int)buffer_ptr[1][0];
590
1.63M
          DC19 = (int)next_block_row[1][0];
591
1.63M
          DC24 = (int)next_next_block_row[1][0];
592
1.63M
        }
593
9.48M
        if (block_num + 1 < last_block_column) {
594
5.11M
          DC05 = (int)prev_prev_block_row[2][0];
595
5.11M
          DC10 = (int)prev_block_row[2][0];
596
5.11M
          DC15 = (int)buffer_ptr[2][0];
597
5.11M
          DC20 = (int)next_block_row[2][0];
598
5.11M
          DC25 = (int)next_next_block_row[2][0];
599
5.11M
        }
600
        /* If DC interpolation is enabled, compute coefficient estimates using
601
         * a Gaussian-like kernel, keeping the averages of the DC values.
602
         *
603
         * If DC interpolation is disabled, compute coefficient estimates using
604
         * an algorithm similar to the one described in Section K.8 of the JPEG
605
         * standard, except applied to a 5x5 window rather than a 3x3 window.
606
         *
607
         * An estimate is applied only if the coefficient is still zero and is
608
         * not known to be fully accurate.
609
         */
610
        /* AC01 */
611
9.48M
        if ((Al = coef_bits[1]) != 0 && workspace[1] == 0) {
612
8.39M
          num = Q00 * (change_dc ?
613
7.61M
                (-DC01 - DC02 + DC04 + DC05 - 3 * DC06 + 13 * DC07 -
614
7.61M
                 13 * DC09 + 3 * DC10 - 3 * DC11 + 38 * DC12 - 38 * DC14 +
615
7.61M
                 3 * DC15 - 3 * DC16 + 13 * DC17 - 13 * DC19 + 3 * DC20 -
616
7.61M
                 DC21 - DC22 + DC24 + DC25) :
617
8.39M
                (-7 * DC11 + 50 * DC12 - 50 * DC14 + 7 * DC15));
618
8.39M
          if (num >= 0) {
619
6.59M
            pred = (int)(((Q01 << 7) + num) / (Q01 << 8));
620
6.59M
            if (Al > 0 && pred >= (1 << Al))
621
4.47k
              pred = (1 << Al) - 1;
622
6.59M
          } else {
623
1.79M
            pred = (int)(((Q01 << 7) - num) / (Q01 << 8));
624
1.79M
            if (Al > 0 && pred >= (1 << Al))
625
15.3k
              pred = (1 << Al) - 1;
626
1.79M
            pred = -pred;
627
1.79M
          }
628
8.39M
          workspace[1] = (JCOEF)pred;
629
8.39M
        }
630
        /* AC10 */
631
9.48M
        if ((Al = coef_bits[2]) != 0 && workspace[8] == 0) {
632
8.30M
          num = Q00 * (change_dc ?
633
7.59M
                (-DC01 - 3 * DC02 - 3 * DC03 - 3 * DC04 - DC05 - DC06 +
634
7.59M
                 13 * DC07 + 38 * DC08 + 13 * DC09 - DC10 + DC16 -
635
7.59M
                 13 * DC17 - 38 * DC18 - 13 * DC19 + DC20 + DC21 +
636
7.59M
                 3 * DC22 + 3 * DC23 + 3 * DC24 + DC25) :
637
8.30M
                (-7 * DC03 + 50 * DC08 - 50 * DC18 + 7 * DC23));
638
8.30M
          if (num >= 0) {
639
6.45M
            pred = (int)(((Q10 << 7) + num) / (Q10 << 8));
640
6.45M
            if (Al > 0 && pred >= (1 << Al))
641
10.8k
              pred = (1 << Al) - 1;
642
6.45M
          } else {
643
1.84M
            pred = (int)(((Q10 << 7) - num) / (Q10 << 8));
644
1.84M
            if (Al > 0 && pred >= (1 << Al))
645
13.2k
              pred = (1 << Al) - 1;
646
1.84M
            pred = -pred;
647
1.84M
          }
648
8.30M
          workspace[8] = (JCOEF)pred;
649
8.30M
        }
650
        /* AC20 */
651
9.48M
        if ((Al = coef_bits[3]) != 0 && workspace[16] == 0) {
652
8.37M
          num = Q00 * (change_dc ?
653
7.59M
                (DC03 + 2 * DC07 + 7 * DC08 + 2 * DC09 - 5 * DC12 - 14 * DC13 -
654
7.59M
                 5 * DC14 + 2 * DC17 + 7 * DC18 + 2 * DC19 + DC23) :
655
8.37M
                (-DC03 + 13 * DC08 - 24 * DC13 + 13 * DC18 - DC23));
656
8.37M
          if (num >= 0) {
657
6.07M
            pred = (int)(((Q20 << 7) + num) / (Q20 << 8));
658
6.07M
            if (Al > 0 && pred >= (1 << Al))
659
8.91k
              pred = (1 << Al) - 1;
660
6.07M
          } else {
661
2.29M
            pred = (int)(((Q20 << 7) - num) / (Q20 << 8));
662
2.29M
            if (Al > 0 && pred >= (1 << Al))
663
8.70k
              pred = (1 << Al) - 1;
664
2.29M
            pred = -pred;
665
2.29M
          }
666
8.37M
          workspace[16] = (JCOEF)pred;
667
8.37M
        }
668
        /* AC11 */
669
9.48M
        if ((Al = coef_bits[4]) != 0 && workspace[9] == 0) {
670
8.37M
          num = Q00 * (change_dc ?
671
7.60M
                (-DC01 + DC05 + 9 * DC07 - 9 * DC09 - 9 * DC17 +
672
7.60M
                 9 * DC19 + DC21 - DC25) :
673
8.37M
                (DC10 + DC16 - 10 * DC17 + 10 * DC19 - DC02 - DC20 + DC22 -
674
770k
                 DC24 + DC04 - DC06 + 10 * DC07 - 10 * DC09));
675
8.37M
          if (num >= 0) {
676
7.05M
            pred = (int)(((Q11 << 7) + num) / (Q11 << 8));
677
7.05M
            if (Al > 0 && pred >= (1 << Al))
678
1.00k
              pred = (1 << Al) - 1;
679
7.05M
          } else {
680
1.31M
            pred = (int)(((Q11 << 7) - num) / (Q11 << 8));
681
1.31M
            if (Al > 0 && pred >= (1 << Al))
682
833
              pred = (1 << Al) - 1;
683
1.31M
            pred = -pred;
684
1.31M
          }
685
8.37M
          workspace[9] = (JCOEF)pred;
686
8.37M
        }
687
        /* AC02 */
688
9.48M
        if ((Al = coef_bits[5]) != 0 && workspace[2] == 0) {
689
8.36M
          num = Q00 * (change_dc ?
690
7.60M
                (2 * DC07 - 5 * DC08 + 2 * DC09 + DC11 + 7 * DC12 - 14 * DC13 +
691
7.60M
                 7 * DC14 + DC15 + 2 * DC17 - 5 * DC18 + 2 * DC19) :
692
8.36M
                (-DC11 + 13 * DC12 - 24 * DC13 + 13 * DC14 - DC15));
693
8.36M
          if (num >= 0) {
694
6.10M
            pred = (int)(((Q02 << 7) + num) / (Q02 << 8));
695
6.10M
            if (Al > 0 && pred >= (1 << Al))
696
1.45k
              pred = (1 << Al) - 1;
697
6.10M
          } else {
698
2.26M
            pred = (int)(((Q02 << 7) - num) / (Q02 << 8));
699
2.26M
            if (Al > 0 && pred >= (1 << Al))
700
1.36k
              pred = (1 << Al) - 1;
701
2.26M
            pred = -pred;
702
2.26M
          }
703
8.36M
          workspace[2] = (JCOEF)pred;
704
8.36M
        }
705
9.48M
        if (change_dc) {
706
          /* AC03 */
707
7.61M
          if ((Al = coef_bits[6]) != 0 && workspace[3] == 0) {
708
7.60M
            num = Q00 * (DC07 - DC09 + 2 * DC12 - 2 * DC14 + DC17 - DC19);
709
7.60M
            if (num >= 0) {
710
6.16M
              pred = (int)(((Q03 << 7) + num) / (Q03 << 8));
711
6.16M
              if (Al > 0 && pred >= (1 << Al))
712
0
                pred = (1 << Al) - 1;
713
6.16M
            } else {
714
1.43M
              pred = (int)(((Q03 << 7) - num) / (Q03 << 8));
715
1.43M
              if (Al > 0 && pred >= (1 << Al))
716
0
                pred = (1 << Al) - 1;
717
1.43M
              pred = -pred;
718
1.43M
            }
719
7.60M
            workspace[3] = (JCOEF)pred;
720
7.60M
          }
721
          /* AC12 */
722
7.61M
          if ((Al = coef_bits[7]) != 0 && workspace[10] == 0) {
723
7.60M
            num = Q00 * (DC07 - 3 * DC08 + DC09 - DC17 + 3 * DC18 - DC19);
724
7.60M
            if (num >= 0) {
725
5.49M
              pred = (int)(((Q12 << 7) + num) / (Q12 << 8));
726
5.49M
              if (Al > 0 && pred >= (1 << Al))
727
0
                pred = (1 << Al) - 1;
728
5.49M
            } else {
729
2.11M
              pred = (int)(((Q12 << 7) - num) / (Q12 << 8));
730
2.11M
              if (Al > 0 && pred >= (1 << Al))
731
0
                pred = (1 << Al) - 1;
732
2.11M
              pred = -pred;
733
2.11M
            }
734
7.60M
            workspace[10] = (JCOEF)pred;
735
7.60M
          }
736
          /* AC21 */
737
7.61M
          if ((Al = coef_bits[8]) != 0 && workspace[17] == 0) {
738
7.60M
            num = Q00 * (DC07 - DC09 - 3 * DC12 + 3 * DC14 + DC17 - DC19);
739
7.60M
            if (num >= 0) {
740
5.75M
              pred = (int)(((Q21 << 7) + num) / (Q21 << 8));
741
5.75M
              if (Al > 0 && pred >= (1 << Al))
742
0
                pred = (1 << Al) - 1;
743
5.75M
            } else {
744
1.84M
              pred = (int)(((Q21 << 7) - num) / (Q21 << 8));
745
1.84M
              if (Al > 0 && pred >= (1 << Al))
746
0
                pred = (1 << Al) - 1;
747
1.84M
              pred = -pred;
748
1.84M
            }
749
7.60M
            workspace[17] = (JCOEF)pred;
750
7.60M
          }
751
          /* AC30 */
752
7.61M
          if ((Al = coef_bits[9]) != 0 && workspace[24] == 0) {
753
7.60M
            num = Q00 * (DC07 + 2 * DC08 + DC09 - DC17 - 2 * DC18 - DC19);
754
7.60M
            if (num >= 0) {
755
6.13M
              pred = (int)(((Q30 << 7) + num) / (Q30 << 8));
756
6.13M
              if (Al > 0 && pred >= (1 << Al))
757
0
                pred = (1 << Al) - 1;
758
6.13M
            } else {
759
1.47M
              pred = (int)(((Q30 << 7) - num) / (Q30 << 8));
760
1.47M
              if (Al > 0 && pred >= (1 << Al))
761
0
                pred = (1 << Al) - 1;
762
1.47M
              pred = -pred;
763
1.47M
            }
764
7.60M
            workspace[24] = (JCOEF)pred;
765
7.60M
          }
766
          /* coef_bits[0] is non-negative.  Otherwise this function would not
767
           * be called.
768
           */
769
7.61M
          num = Q00 *
770
7.61M
                (-2 * DC01 - 6 * DC02 - 8 * DC03 - 6 * DC04 - 2 * DC05 -
771
7.61M
                 6 * DC06 + 6 * DC07 + 42 * DC08 + 6 * DC09 - 6 * DC10 -
772
7.61M
                 8 * DC11 + 42 * DC12 + 152 * DC13 + 42 * DC14 - 8 * DC15 -
773
7.61M
                 6 * DC16 + 6 * DC17 + 42 * DC18 + 6 * DC19 - 6 * DC20 -
774
7.61M
                 2 * DC21 - 6 * DC22 - 8 * DC23 - 6 * DC24 - 2 * DC25);
775
7.61M
          if (num >= 0) {
776
5.28M
            pred = (int)(((Q00 << 7) + num) / (Q00 << 8));
777
5.28M
          } else {
778
2.32M
            pred = (int)(((Q00 << 7) - num) / (Q00 << 8));
779
2.32M
            pred = -pred;
780
2.32M
          }
781
7.61M
          workspace[0] = (JCOEF)pred;
782
7.61M
        }  /* change_dc */
783
784
        /* OK, do the IDCT */
785
9.48M
        (*inverse_DCT) (cinfo, compptr, (JCOEFPTR)workspace, output_ptr,
786
9.48M
                        output_col);
787
        /* Advance for next column */
788
9.48M
        DC01 = DC02;  DC02 = DC03;  DC03 = DC04;  DC04 = DC05;
789
9.48M
        DC06 = DC07;  DC07 = DC08;  DC08 = DC09;  DC09 = DC10;
790
9.48M
        DC11 = DC12;  DC12 = DC13;  DC13 = DC14;  DC14 = DC15;
791
9.48M
        DC16 = DC17;  DC17 = DC18;  DC18 = DC19;  DC19 = DC20;
792
9.48M
        DC21 = DC22;  DC22 = DC23;  DC23 = DC24;  DC24 = DC25;
793
9.48M
        buffer_ptr++, prev_block_row++, next_block_row++,
794
9.48M
          prev_prev_block_row++, next_next_block_row++;
795
9.48M
        output_col += compptr->_DCT_scaled_size;
796
9.48M
      }
797
2.73M
      output_ptr += compptr->_DCT_scaled_size;
798
2.73M
    }
799
2.08M
  }
800
801
721k
  if (++(cinfo->output_iMCU_row) < cinfo->total_iMCU_rows)
802
715k
    return JPEG_ROW_COMPLETED;
803
5.13k
  return JPEG_SCAN_COMPLETED;
804
721k
}
805
806
#endif /* BLOCK_SMOOTHING_SUPPORTED */
807
808
809
/*
810
 * Initialize coefficient buffer controller.
811
 */
812
813
GLOBAL(void)
814
_jinit_d_coef_controller(j_decompress_ptr cinfo, boolean need_full_buffer)
815
35.3k
{
816
35.3k
  my_coef_ptr coef;
817
818
35.3k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
819
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
820
821
35.3k
  coef = (my_coef_ptr)
822
35.3k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
823
35.3k
                                sizeof(my_coef_controller));
824
35.3k
  cinfo->coef = (struct jpeg_d_coef_controller *)coef;
825
35.3k
  coef->pub.start_input_pass = start_input_pass;
826
35.3k
  coef->pub.start_output_pass = start_output_pass;
827
35.3k
#ifdef BLOCK_SMOOTHING_SUPPORTED
828
35.3k
  coef->coef_bits_latch = NULL;
829
35.3k
#endif
830
831
  /* Create the coefficient buffer. */
832
35.3k
  if (need_full_buffer) {
833
18.2k
#ifdef D_MULTISCAN_FILES_SUPPORTED
834
    /* Allocate a full-image virtual array for each component, */
835
    /* padded to a multiple of samp_factor DCT blocks in each direction. */
836
    /* Note we ask for a pre-zeroed array. */
837
18.2k
    int ci, access_rows;
838
18.2k
    jpeg_component_info *compptr;
839
840
72.8k
    for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
841
54.6k
         ci++, compptr++) {
842
54.6k
      access_rows = compptr->v_samp_factor;
843
54.6k
#ifdef BLOCK_SMOOTHING_SUPPORTED
844
      /* If block smoothing could be used, need a bigger window */
845
54.6k
      if (cinfo->progressive_mode)
846
48.4k
        access_rows *= 5;
847
54.6k
#endif
848
54.6k
      coef->whole_image[ci] = (*cinfo->mem->request_virt_barray)
849
54.6k
        ((j_common_ptr)cinfo, JPOOL_IMAGE, TRUE,
850
54.6k
         (JDIMENSION)jround_up((long)compptr->width_in_blocks,
851
54.6k
                               (long)compptr->h_samp_factor),
852
54.6k
         (JDIMENSION)jround_up((long)compptr->height_in_blocks,
853
54.6k
                               (long)compptr->v_samp_factor),
854
54.6k
         (JDIMENSION)access_rows);
855
54.6k
    }
856
18.2k
    coef->pub.consume_data = consume_data;
857
18.2k
    coef->pub._decompress_data = decompress_data;
858
18.2k
    coef->pub.coef_arrays = coef->whole_image; /* link to virtual arrays */
859
#else
860
    ERREXIT(cinfo, JERR_NOT_COMPILED);
861
#endif
862
18.2k
  } else {
863
    /* We only need a single-MCU buffer. */
864
17.1k
    JBLOCKROW buffer;
865
17.1k
    int i;
866
867
17.1k
    buffer = (JBLOCKROW)
868
17.1k
      (*cinfo->mem->alloc_large) ((j_common_ptr)cinfo, JPOOL_IMAGE,
869
17.1k
                                  D_MAX_BLOCKS_IN_MCU * sizeof(JBLOCK));
870
188k
    for (i = 0; i < D_MAX_BLOCKS_IN_MCU; i++) {
871
171k
      coef->MCU_buffer[i] = buffer + i;
872
171k
    }
873
17.1k
    coef->pub.consume_data = dummy_consume_data;
874
17.1k
    coef->pub._decompress_data = decompress_onepass;
875
17.1k
    coef->pub.coef_arrays = NULL; /* flag for no virtual arrays */
876
17.1k
  }
877
878
  /* Allocate the workspace buffer */
879
35.3k
  coef->workspace = (JCOEF *)
880
35.3k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
881
35.3k
                                sizeof(JCOEF) * DCTSIZE2);
882
35.3k
}
j12init_d_coef_controller
Line
Count
Source
815
11.5k
{
816
11.5k
  my_coef_ptr coef;
817
818
11.5k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
819
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
820
821
11.5k
  coef = (my_coef_ptr)
822
11.5k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
823
11.5k
                                sizeof(my_coef_controller));
824
11.5k
  cinfo->coef = (struct jpeg_d_coef_controller *)coef;
825
11.5k
  coef->pub.start_input_pass = start_input_pass;
826
11.5k
  coef->pub.start_output_pass = start_output_pass;
827
11.5k
#ifdef BLOCK_SMOOTHING_SUPPORTED
828
11.5k
  coef->coef_bits_latch = NULL;
829
11.5k
#endif
830
831
  /* Create the coefficient buffer. */
832
11.5k
  if (need_full_buffer) {
833
5.70k
#ifdef D_MULTISCAN_FILES_SUPPORTED
834
    /* Allocate a full-image virtual array for each component, */
835
    /* padded to a multiple of samp_factor DCT blocks in each direction. */
836
    /* Note we ask for a pre-zeroed array. */
837
5.70k
    int ci, access_rows;
838
5.70k
    jpeg_component_info *compptr;
839
840
22.8k
    for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
841
17.1k
         ci++, compptr++) {
842
17.1k
      access_rows = compptr->v_samp_factor;
843
17.1k
#ifdef BLOCK_SMOOTHING_SUPPORTED
844
      /* If block smoothing could be used, need a bigger window */
845
17.1k
      if (cinfo->progressive_mode)
846
16.1k
        access_rows *= 5;
847
17.1k
#endif
848
17.1k
      coef->whole_image[ci] = (*cinfo->mem->request_virt_barray)
849
17.1k
        ((j_common_ptr)cinfo, JPOOL_IMAGE, TRUE,
850
17.1k
         (JDIMENSION)jround_up((long)compptr->width_in_blocks,
851
17.1k
                               (long)compptr->h_samp_factor),
852
17.1k
         (JDIMENSION)jround_up((long)compptr->height_in_blocks,
853
17.1k
                               (long)compptr->v_samp_factor),
854
17.1k
         (JDIMENSION)access_rows);
855
17.1k
    }
856
5.70k
    coef->pub.consume_data = consume_data;
857
5.70k
    coef->pub._decompress_data = decompress_data;
858
5.70k
    coef->pub.coef_arrays = coef->whole_image; /* link to virtual arrays */
859
#else
860
    ERREXIT(cinfo, JERR_NOT_COMPILED);
861
#endif
862
5.79k
  } else {
863
    /* We only need a single-MCU buffer. */
864
5.79k
    JBLOCKROW buffer;
865
5.79k
    int i;
866
867
5.79k
    buffer = (JBLOCKROW)
868
5.79k
      (*cinfo->mem->alloc_large) ((j_common_ptr)cinfo, JPOOL_IMAGE,
869
5.79k
                                  D_MAX_BLOCKS_IN_MCU * sizeof(JBLOCK));
870
63.7k
    for (i = 0; i < D_MAX_BLOCKS_IN_MCU; i++) {
871
57.9k
      coef->MCU_buffer[i] = buffer + i;
872
57.9k
    }
873
5.79k
    coef->pub.consume_data = dummy_consume_data;
874
5.79k
    coef->pub._decompress_data = decompress_onepass;
875
5.79k
    coef->pub.coef_arrays = NULL; /* flag for no virtual arrays */
876
5.79k
  }
877
878
  /* Allocate the workspace buffer */
879
11.5k
  coef->workspace = (JCOEF *)
880
11.5k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
881
11.5k
                                sizeof(JCOEF) * DCTSIZE2);
882
11.5k
}
jinit_d_coef_controller
Line
Count
Source
815
23.8k
{
816
23.8k
  my_coef_ptr coef;
817
818
23.8k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
819
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
820
821
23.8k
  coef = (my_coef_ptr)
822
23.8k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
823
23.8k
                                sizeof(my_coef_controller));
824
23.8k
  cinfo->coef = (struct jpeg_d_coef_controller *)coef;
825
23.8k
  coef->pub.start_input_pass = start_input_pass;
826
23.8k
  coef->pub.start_output_pass = start_output_pass;
827
23.8k
#ifdef BLOCK_SMOOTHING_SUPPORTED
828
23.8k
  coef->coef_bits_latch = NULL;
829
23.8k
#endif
830
831
  /* Create the coefficient buffer. */
832
23.8k
  if (need_full_buffer) {
833
12.5k
#ifdef D_MULTISCAN_FILES_SUPPORTED
834
    /* Allocate a full-image virtual array for each component, */
835
    /* padded to a multiple of samp_factor DCT blocks in each direction. */
836
    /* Note we ask for a pre-zeroed array. */
837
12.5k
    int ci, access_rows;
838
12.5k
    jpeg_component_info *compptr;
839
840
50.0k
    for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
841
37.5k
         ci++, compptr++) {
842
37.5k
      access_rows = compptr->v_samp_factor;
843
37.5k
#ifdef BLOCK_SMOOTHING_SUPPORTED
844
      /* If block smoothing could be used, need a bigger window */
845
37.5k
      if (cinfo->progressive_mode)
846
32.3k
        access_rows *= 5;
847
37.5k
#endif
848
37.5k
      coef->whole_image[ci] = (*cinfo->mem->request_virt_barray)
849
37.5k
        ((j_common_ptr)cinfo, JPOOL_IMAGE, TRUE,
850
37.5k
         (JDIMENSION)jround_up((long)compptr->width_in_blocks,
851
37.5k
                               (long)compptr->h_samp_factor),
852
37.5k
         (JDIMENSION)jround_up((long)compptr->height_in_blocks,
853
37.5k
                               (long)compptr->v_samp_factor),
854
37.5k
         (JDIMENSION)access_rows);
855
37.5k
    }
856
12.5k
    coef->pub.consume_data = consume_data;
857
12.5k
    coef->pub._decompress_data = decompress_data;
858
12.5k
    coef->pub.coef_arrays = coef->whole_image; /* link to virtual arrays */
859
#else
860
    ERREXIT(cinfo, JERR_NOT_COMPILED);
861
#endif
862
12.5k
  } else {
863
    /* We only need a single-MCU buffer. */
864
11.3k
    JBLOCKROW buffer;
865
11.3k
    int i;
866
867
11.3k
    buffer = (JBLOCKROW)
868
11.3k
      (*cinfo->mem->alloc_large) ((j_common_ptr)cinfo, JPOOL_IMAGE,
869
11.3k
                                  D_MAX_BLOCKS_IN_MCU * sizeof(JBLOCK));
870
124k
    for (i = 0; i < D_MAX_BLOCKS_IN_MCU; i++) {
871
113k
      coef->MCU_buffer[i] = buffer + i;
872
113k
    }
873
11.3k
    coef->pub.consume_data = dummy_consume_data;
874
11.3k
    coef->pub._decompress_data = decompress_onepass;
875
11.3k
    coef->pub.coef_arrays = NULL; /* flag for no virtual arrays */
876
11.3k
  }
877
878
  /* Allocate the workspace buffer */
879
23.8k
  coef->workspace = (JCOEF *)
880
23.8k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
881
23.8k
                                sizeof(JCOEF) * DCTSIZE2);
882
23.8k
}