Coverage Report

Created: 2026-04-12 06:04

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libjpeg-turbo.main/src/jddctmgr.c
Line
Count
Source
1
/*
2
 * jddctmgr.c
3
 *
4
 * This file was part of the Independent JPEG Group's software:
5
 * Copyright (C) 1994-1996, Thomas G. Lane.
6
 * Modified 2002-2010 by Guido Vollbeding.
7
 * libjpeg-turbo Modifications:
8
 * Copyright 2009 Pierre Ossman <ossman@cendio.se> for Cendio AB
9
 * Copyright (C) 2010, 2015, 2022, 2025-2026, D. R. Commander.
10
 * For conditions of distribution and use, see the accompanying README.ijg
11
 * file.
12
 *
13
 * This file contains the inverse-DCT management logic.
14
 * This code selects a particular IDCT implementation to be used,
15
 * and it performs related housekeeping chores.  No code in this file
16
 * is executed per IDCT step, only during output pass setup.
17
 *
18
 * Note that the IDCT routines are responsible for performing coefficient
19
 * dequantization as well as the IDCT proper.  This module sets up the
20
 * dequantization multiplier table needed by the IDCT routine.
21
 */
22
23
#define JPEG_INTERNALS
24
#include "jinclude.h"
25
#include "jpeglib.h"
26
#include "jdct.h"               /* Private declarations for DCT subsystem */
27
#ifdef WITH_SIMD
28
#include "../simd/jsimddct.h"
29
#endif
30
#include "jpegapicomp.h"
31
32
33
#if defined(DCT_ISLOW_SUPPORTED) || defined(DCT_IFAST_SUPPORTED) || \
34
    defined(DCT_FLOAT_SUPPORTED)
35
36
/*
37
 * The decompressor input side (jdinput.c) saves away the appropriate
38
 * quantization table for each component at the start of the first scan
39
 * involving that component.  (This is necessary in order to correctly
40
 * decode files that reuse Q-table slots.)
41
 * When we are ready to make an output pass, the saved Q-table is converted
42
 * to a multiplier table that will actually be used by the IDCT routine.
43
 * The multiplier table contents are IDCT-method-dependent.  To support
44
 * application changes in IDCT method between scans, we can remake the
45
 * multiplier tables if necessary.
46
 * In buffered-image mode, the first output pass may occur before any data
47
 * has been seen for some components, and thus before their Q-tables have
48
 * been saved away.  To handle this case, multiplier tables are preset
49
 * to zeroes; the result of the IDCT will be a neutral gray level.
50
 */
51
52
53
/* Private subobject for this module */
54
55
typedef struct {
56
  struct jpeg_inverse_dct pub;  /* public fields */
57
58
  /* This array contains the IDCT method code that each multiplier table
59
   * is currently set up for, or -1 if it's not yet set up.
60
   * The actual multiplier tables are pointed to by dct_table in the
61
   * per-component comp_info structures.
62
   */
63
  int cur_method[MAX_COMPONENTS];
64
} my_idct_controller;
65
66
typedef my_idct_controller *my_idct_ptr;
67
68
69
/* Allocated multiplier tables: big enough for any supported variant */
70
71
typedef union {
72
  ISLOW_MULT_TYPE islow_array[DCTSIZE2];
73
#ifdef DCT_IFAST_SUPPORTED
74
  IFAST_MULT_TYPE ifast_array[DCTSIZE2];
75
#endif
76
#ifdef DCT_FLOAT_SUPPORTED
77
  FLOAT_MULT_TYPE float_array[DCTSIZE2];
78
#endif
79
} multiplier_table;
80
81
82
/* The current scaled-IDCT routines require ISLOW-style multiplier tables,
83
 * so be sure to compile that code if either ISLOW or SCALING is requested.
84
 */
85
#ifdef DCT_ISLOW_SUPPORTED
86
#define PROVIDE_ISLOW_TABLES
87
#else
88
#ifdef IDCT_SCALING_SUPPORTED
89
#define PROVIDE_ISLOW_TABLES
90
#endif
91
#endif
92
93
94
/*
95
 * Prepare for an output pass.
96
 * Here we select the proper IDCT routine for each component and build
97
 * a matching multiplier table.
98
 */
99
100
METHODDEF(void)
101
start_pass(j_decompress_ptr cinfo)
102
11.6k
{
103
11.6k
  my_idct_ptr idct = (my_idct_ptr)cinfo->idct;
104
11.6k
  int ci, i;
105
11.6k
  jpeg_component_info *compptr;
106
11.6k
  int method = 0;
107
11.6k
  _inverse_DCT_method_ptr method_ptr = NULL;
108
11.6k
  JQUANT_TBL *qtbl;
109
110
30.5k
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
111
18.8k
       ci++, compptr++) {
112
    /* Select the proper IDCT routine for this component's scaling */
113
18.8k
    switch (compptr->_DCT_scaled_size) {
114
0
#ifdef IDCT_SCALING_SUPPORTED
115
3.62k
    case 1:
116
3.62k
      method_ptr = _jpeg_idct_1x1;
117
3.62k
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
118
3.62k
      break;
119
623
    case 2:
120
#ifdef WITH_SIMD
121
193
      if (jsimd_set_idct_2x2(cinfo))
122
193
        method_ptr = jsimd_idct_2x2;
123
0
      else
124
0
#endif
125
430
        method_ptr = _jpeg_idct_2x2;
126
623
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
127
623
      break;
128
0
    case 3:
129
0
      method_ptr = _jpeg_idct_3x3;
130
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
131
0
      break;
132
3.65k
    case 4:
133
#ifdef WITH_SIMD
134
1.84k
      if (jsimd_set_idct_4x4(cinfo))
135
1.84k
        method_ptr = jsimd_idct_4x4;
136
0
      else
137
0
#endif
138
1.80k
        method_ptr = _jpeg_idct_4x4;
139
3.65k
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
140
3.65k
      break;
141
0
    case 5:
142
0
      method_ptr = _jpeg_idct_5x5;
143
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
144
0
      break;
145
0
    case 6:
146
0
      method_ptr = _jpeg_idct_6x6;
147
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
148
0
      break;
149
0
    case 7:
150
0
      method_ptr = _jpeg_idct_7x7;
151
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
152
0
      break;
153
0
#endif
154
10.9k
    case DCTSIZE:
155
10.9k
      switch (cinfo->dct_method) {
156
0
#ifdef DCT_ISLOW_SUPPORTED
157
6.68k
      case JDCT_ISLOW:
158
#ifdef WITH_SIMD
159
3.38k
        if (jsimd_set_idct_islow(cinfo))
160
3.38k
          method_ptr = jsimd_idct_islow;
161
0
        else
162
0
#endif
163
3.29k
          method_ptr = _jpeg_idct_islow;
164
6.68k
        method = JDCT_ISLOW;
165
6.68k
        break;
166
0
#endif
167
0
#ifdef DCT_IFAST_SUPPORTED
168
4.30k
      case JDCT_IFAST:
169
#ifdef WITH_SIMD
170
2.06k
        if (jsimd_set_idct_ifast(cinfo))
171
2.06k
          method_ptr = jsimd_idct_ifast;
172
0
        else
173
0
#endif
174
2.24k
          method_ptr = _jpeg_idct_ifast;
175
4.30k
        method = JDCT_IFAST;
176
4.30k
        break;
177
0
#endif
178
0
#ifdef DCT_FLOAT_SUPPORTED
179
0
      case JDCT_FLOAT:
180
#ifdef WITH_SIMD
181
0
        if (jsimd_set_idct_float(cinfo))
182
0
          method_ptr = jsimd_idct_float;
183
0
        else
184
0
#endif
185
0
          method_ptr = _jpeg_idct_float;
186
0
        method = JDCT_FLOAT;
187
0
        break;
188
0
#endif
189
0
      default:
190
0
        ERREXIT(cinfo, JERR_NOT_COMPILED);
191
0
        break;
192
10.9k
      }
193
10.9k
      break;
194
10.9k
#ifdef IDCT_SCALING_SUPPORTED
195
10.9k
    case 9:
196
0
      method_ptr = _jpeg_idct_9x9;
197
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
198
0
      break;
199
0
    case 10:
200
0
      method_ptr = _jpeg_idct_10x10;
201
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
202
0
      break;
203
0
    case 11:
204
0
      method_ptr = _jpeg_idct_11x11;
205
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
206
0
      break;
207
0
    case 12:
208
0
      method_ptr = _jpeg_idct_12x12;
209
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
210
0
      break;
211
0
    case 13:
212
0
      method_ptr = _jpeg_idct_13x13;
213
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
214
0
      break;
215
0
    case 14:
216
0
      method_ptr = _jpeg_idct_14x14;
217
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
218
0
      break;
219
0
    case 15:
220
0
      method_ptr = _jpeg_idct_15x15;
221
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
222
0
      break;
223
0
    case 16:
224
0
      method_ptr = _jpeg_idct_16x16;
225
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
226
0
      break;
227
0
#endif
228
0
    default:
229
0
      ERREXIT1(cinfo, JERR_BAD_DCTSIZE, compptr->_DCT_scaled_size);
230
0
      break;
231
18.8k
    }
232
18.8k
    idct->pub._inverse_DCT[ci] = method_ptr;
233
    /* Create multiplier table from quant table.
234
     * However, we can skip this if the component is uninteresting
235
     * or if we already built the table.  Also, if no quant table
236
     * has yet been saved for the component, we leave the
237
     * multiplier table all-zero; we'll be reading zeroes from the
238
     * coefficient controller's buffer anyway.
239
     */
240
18.8k
    if (!compptr->component_needed || idct->cur_method[ci] == method)
241
2.08k
      continue;
242
16.8k
    qtbl = compptr->quant_table;
243
16.8k
    if (qtbl == NULL)           /* happens if no data yet for component */
244
3.84k
      continue;
245
12.9k
    idct->cur_method[ci] = method;
246
12.9k
    switch (method) {
247
0
#ifdef PROVIDE_ISLOW_TABLES
248
9.58k
    case JDCT_ISLOW:
249
9.58k
      {
250
        /* For LL&M IDCT method, multipliers are equal to raw quantization
251
         * coefficients, but are stored as ints to ensure access efficiency.
252
         */
253
9.58k
        ISLOW_MULT_TYPE *ismtbl = (ISLOW_MULT_TYPE *)compptr->dct_table;
254
622k
        for (i = 0; i < DCTSIZE2; i++) {
255
613k
          ismtbl[i] = (ISLOW_MULT_TYPE)qtbl->quantval[i];
256
613k
        }
257
9.58k
      }
258
9.58k
      break;
259
0
#endif
260
0
#ifdef DCT_IFAST_SUPPORTED
261
3.37k
    case JDCT_IFAST:
262
3.37k
      {
263
        /* For AA&N IDCT method, multipliers are equal to quantization
264
         * coefficients scaled by scalefactor[row]*scalefactor[col], where
265
         *   scalefactor[0] = 1
266
         *   scalefactor[k] = cos(k*PI/16) * sqrt(2)    for k=1..7
267
         * For integer operation, the multiplier table is to be scaled by
268
         * IFAST_SCALE_BITS.
269
         */
270
3.37k
        IFAST_MULT_TYPE *ifmtbl = (IFAST_MULT_TYPE *)compptr->dct_table;
271
3.37k
#define CONST_BITS  14
272
3.37k
        static const INT16 aanscales[DCTSIZE2] = {
273
          /* precomputed values scaled up by 14 bits */
274
3.37k
          16384, 22725, 21407, 19266, 16384, 12873,  8867,  4520,
275
3.37k
          22725, 31521, 29692, 26722, 22725, 17855, 12299,  6270,
276
3.37k
          21407, 29692, 27969, 25172, 21407, 16819, 11585,  5906,
277
3.37k
          19266, 26722, 25172, 22654, 19266, 15137, 10426,  5315,
278
3.37k
          16384, 22725, 21407, 19266, 16384, 12873,  8867,  4520,
279
3.37k
          12873, 17855, 16819, 15137, 12873, 10114,  6967,  3552,
280
3.37k
           8867, 12299, 11585, 10426,  8867,  6967,  4799,  2446,
281
3.37k
           4520,  6270,  5906,  5315,  4520,  3552,  2446,  1247
282
3.37k
        };
283
3.37k
        SHIFT_TEMPS
284
285
219k
        for (i = 0; i < DCTSIZE2; i++) {
286
216k
          ifmtbl[i] = (IFAST_MULT_TYPE)
287
216k
            DESCALE(MULTIPLY16V16((JLONG)qtbl->quantval[i],
288
216k
                                  (JLONG)aanscales[i]),
289
216k
                    CONST_BITS - IFAST_SCALE_BITS);
290
216k
        }
291
3.37k
      }
292
3.37k
      break;
293
0
#endif
294
0
#ifdef DCT_FLOAT_SUPPORTED
295
0
    case JDCT_FLOAT:
296
0
      {
297
        /* For float AA&N IDCT method, multipliers are equal to quantization
298
         * coefficients scaled by scalefactor[row]*scalefactor[col], where
299
         *   scalefactor[0] = 1
300
         *   scalefactor[k] = cos(k*PI/16) * sqrt(2)    for k=1..7
301
         */
302
0
        FLOAT_MULT_TYPE *fmtbl = (FLOAT_MULT_TYPE *)compptr->dct_table;
303
0
        int row, col;
304
0
        static const double aanscalefactor[DCTSIZE] = {
305
0
          1.0, 1.387039845, 1.306562965, 1.175875602,
306
0
          1.0, 0.785694958, 0.541196100, 0.275899379
307
0
        };
308
309
0
        i = 0;
310
0
        for (row = 0; row < DCTSIZE; row++) {
311
0
          for (col = 0; col < DCTSIZE; col++) {
312
0
            fmtbl[i] = (FLOAT_MULT_TYPE)
313
0
              ((double)qtbl->quantval[i] *
314
0
               aanscalefactor[row] * aanscalefactor[col]);
315
0
            i++;
316
0
          }
317
0
        }
318
0
      }
319
0
      break;
320
0
#endif
321
0
    default:
322
0
      ERREXIT(cinfo, JERR_NOT_COMPILED);
323
0
      break;
324
12.9k
    }
325
12.9k
  }
326
11.6k
}
jddctmgr-8.c:start_pass
Line
Count
Source
102
6.16k
{
103
6.16k
  my_idct_ptr idct = (my_idct_ptr)cinfo->idct;
104
6.16k
  int ci, i;
105
6.16k
  jpeg_component_info *compptr;
106
6.16k
  int method = 0;
107
6.16k
  _inverse_DCT_method_ptr method_ptr = NULL;
108
6.16k
  JQUANT_TBL *qtbl;
109
110
15.4k
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
111
9.33k
       ci++, compptr++) {
112
    /* Select the proper IDCT routine for this component's scaling */
113
9.33k
    switch (compptr->_DCT_scaled_size) {
114
0
#ifdef IDCT_SCALING_SUPPORTED
115
1.83k
    case 1:
116
1.83k
      method_ptr = _jpeg_idct_1x1;
117
1.83k
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
118
1.83k
      break;
119
193
    case 2:
120
193
#ifdef WITH_SIMD
121
193
      if (jsimd_set_idct_2x2(cinfo))
122
193
        method_ptr = jsimd_idct_2x2;
123
0
      else
124
0
#endif
125
0
        method_ptr = _jpeg_idct_2x2;
126
193
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
127
193
      break;
128
0
    case 3:
129
0
      method_ptr = _jpeg_idct_3x3;
130
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
131
0
      break;
132
1.84k
    case 4:
133
1.84k
#ifdef WITH_SIMD
134
1.84k
      if (jsimd_set_idct_4x4(cinfo))
135
1.84k
        method_ptr = jsimd_idct_4x4;
136
0
      else
137
0
#endif
138
0
        method_ptr = _jpeg_idct_4x4;
139
1.84k
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
140
1.84k
      break;
141
0
    case 5:
142
0
      method_ptr = _jpeg_idct_5x5;
143
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
144
0
      break;
145
0
    case 6:
146
0
      method_ptr = _jpeg_idct_6x6;
147
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
148
0
      break;
149
0
    case 7:
150
0
      method_ptr = _jpeg_idct_7x7;
151
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
152
0
      break;
153
0
#endif
154
5.45k
    case DCTSIZE:
155
5.45k
      switch (cinfo->dct_method) {
156
0
#ifdef DCT_ISLOW_SUPPORTED
157
3.38k
      case JDCT_ISLOW:
158
3.38k
#ifdef WITH_SIMD
159
3.38k
        if (jsimd_set_idct_islow(cinfo))
160
3.38k
          method_ptr = jsimd_idct_islow;
161
0
        else
162
0
#endif
163
0
          method_ptr = _jpeg_idct_islow;
164
3.38k
        method = JDCT_ISLOW;
165
3.38k
        break;
166
0
#endif
167
0
#ifdef DCT_IFAST_SUPPORTED
168
2.06k
      case JDCT_IFAST:
169
2.06k
#ifdef WITH_SIMD
170
2.06k
        if (jsimd_set_idct_ifast(cinfo))
171
2.06k
          method_ptr = jsimd_idct_ifast;
172
0
        else
173
0
#endif
174
0
          method_ptr = _jpeg_idct_ifast;
175
2.06k
        method = JDCT_IFAST;
176
2.06k
        break;
177
0
#endif
178
0
#ifdef DCT_FLOAT_SUPPORTED
179
0
      case JDCT_FLOAT:
180
0
#ifdef WITH_SIMD
181
0
        if (jsimd_set_idct_float(cinfo))
182
0
          method_ptr = jsimd_idct_float;
183
0
        else
184
0
#endif
185
0
          method_ptr = _jpeg_idct_float;
186
0
        method = JDCT_FLOAT;
187
0
        break;
188
0
#endif
189
0
      default:
190
0
        ERREXIT(cinfo, JERR_NOT_COMPILED);
191
0
        break;
192
5.45k
      }
193
5.45k
      break;
194
5.45k
#ifdef IDCT_SCALING_SUPPORTED
195
5.45k
    case 9:
196
0
      method_ptr = _jpeg_idct_9x9;
197
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
198
0
      break;
199
0
    case 10:
200
0
      method_ptr = _jpeg_idct_10x10;
201
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
202
0
      break;
203
0
    case 11:
204
0
      method_ptr = _jpeg_idct_11x11;
205
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
206
0
      break;
207
0
    case 12:
208
0
      method_ptr = _jpeg_idct_12x12;
209
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
210
0
      break;
211
0
    case 13:
212
0
      method_ptr = _jpeg_idct_13x13;
213
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
214
0
      break;
215
0
    case 14:
216
0
      method_ptr = _jpeg_idct_14x14;
217
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
218
0
      break;
219
0
    case 15:
220
0
      method_ptr = _jpeg_idct_15x15;
221
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
222
0
      break;
223
0
    case 16:
224
0
      method_ptr = _jpeg_idct_16x16;
225
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
226
0
      break;
227
0
#endif
228
0
    default:
229
0
      ERREXIT1(cinfo, JERR_BAD_DCTSIZE, compptr->_DCT_scaled_size);
230
0
      break;
231
9.33k
    }
232
9.33k
    idct->pub._inverse_DCT[ci] = method_ptr;
233
    /* Create multiplier table from quant table.
234
     * However, we can skip this if the component is uninteresting
235
     * or if we already built the table.  Also, if no quant table
236
     * has yet been saved for the component, we leave the
237
     * multiplier table all-zero; we'll be reading zeroes from the
238
     * coefficient controller's buffer anyway.
239
     */
240
9.33k
    if (!compptr->component_needed || idct->cur_method[ci] == method)
241
1.05k
      continue;
242
8.27k
    qtbl = compptr->quant_table;
243
8.27k
    if (qtbl == NULL)           /* happens if no data yet for component */
244
1.53k
      continue;
245
6.73k
    idct->cur_method[ci] = method;
246
6.73k
    switch (method) {
247
0
#ifdef PROVIDE_ISLOW_TABLES
248
5.00k
    case JDCT_ISLOW:
249
5.00k
      {
250
        /* For LL&M IDCT method, multipliers are equal to raw quantization
251
         * coefficients, but are stored as ints to ensure access efficiency.
252
         */
253
5.00k
        ISLOW_MULT_TYPE *ismtbl = (ISLOW_MULT_TYPE *)compptr->dct_table;
254
325k
        for (i = 0; i < DCTSIZE2; i++) {
255
320k
          ismtbl[i] = (ISLOW_MULT_TYPE)qtbl->quantval[i];
256
320k
        }
257
5.00k
      }
258
5.00k
      break;
259
0
#endif
260
0
#ifdef DCT_IFAST_SUPPORTED
261
1.73k
    case JDCT_IFAST:
262
1.73k
      {
263
        /* For AA&N IDCT method, multipliers are equal to quantization
264
         * coefficients scaled by scalefactor[row]*scalefactor[col], where
265
         *   scalefactor[0] = 1
266
         *   scalefactor[k] = cos(k*PI/16) * sqrt(2)    for k=1..7
267
         * For integer operation, the multiplier table is to be scaled by
268
         * IFAST_SCALE_BITS.
269
         */
270
1.73k
        IFAST_MULT_TYPE *ifmtbl = (IFAST_MULT_TYPE *)compptr->dct_table;
271
1.73k
#define CONST_BITS  14
272
1.73k
        static const INT16 aanscales[DCTSIZE2] = {
273
          /* precomputed values scaled up by 14 bits */
274
1.73k
          16384, 22725, 21407, 19266, 16384, 12873,  8867,  4520,
275
1.73k
          22725, 31521, 29692, 26722, 22725, 17855, 12299,  6270,
276
1.73k
          21407, 29692, 27969, 25172, 21407, 16819, 11585,  5906,
277
1.73k
          19266, 26722, 25172, 22654, 19266, 15137, 10426,  5315,
278
1.73k
          16384, 22725, 21407, 19266, 16384, 12873,  8867,  4520,
279
1.73k
          12873, 17855, 16819, 15137, 12873, 10114,  6967,  3552,
280
1.73k
           8867, 12299, 11585, 10426,  8867,  6967,  4799,  2446,
281
1.73k
           4520,  6270,  5906,  5315,  4520,  3552,  2446,  1247
282
1.73k
        };
283
1.73k
        SHIFT_TEMPS
284
285
112k
        for (i = 0; i < DCTSIZE2; i++) {
286
111k
          ifmtbl[i] = (IFAST_MULT_TYPE)
287
111k
            DESCALE(MULTIPLY16V16((JLONG)qtbl->quantval[i],
288
111k
                                  (JLONG)aanscales[i]),
289
111k
                    CONST_BITS - IFAST_SCALE_BITS);
290
111k
        }
291
1.73k
      }
292
1.73k
      break;
293
0
#endif
294
0
#ifdef DCT_FLOAT_SUPPORTED
295
0
    case JDCT_FLOAT:
296
0
      {
297
        /* For float AA&N IDCT method, multipliers are equal to quantization
298
         * coefficients scaled by scalefactor[row]*scalefactor[col], where
299
         *   scalefactor[0] = 1
300
         *   scalefactor[k] = cos(k*PI/16) * sqrt(2)    for k=1..7
301
         */
302
0
        FLOAT_MULT_TYPE *fmtbl = (FLOAT_MULT_TYPE *)compptr->dct_table;
303
0
        int row, col;
304
0
        static const double aanscalefactor[DCTSIZE] = {
305
0
          1.0, 1.387039845, 1.306562965, 1.175875602,
306
0
          1.0, 0.785694958, 0.541196100, 0.275899379
307
0
        };
308
309
0
        i = 0;
310
0
        for (row = 0; row < DCTSIZE; row++) {
311
0
          for (col = 0; col < DCTSIZE; col++) {
312
0
            fmtbl[i] = (FLOAT_MULT_TYPE)
313
0
              ((double)qtbl->quantval[i] *
314
0
               aanscalefactor[row] * aanscalefactor[col]);
315
0
            i++;
316
0
          }
317
0
        }
318
0
      }
319
0
      break;
320
0
#endif
321
0
    default:
322
0
      ERREXIT(cinfo, JERR_NOT_COMPILED);
323
0
      break;
324
6.73k
    }
325
6.73k
  }
326
6.16k
}
jddctmgr-12.c:start_pass
Line
Count
Source
102
5.49k
{
103
5.49k
  my_idct_ptr idct = (my_idct_ptr)cinfo->idct;
104
5.49k
  int ci, i;
105
5.49k
  jpeg_component_info *compptr;
106
5.49k
  int method = 0;
107
5.49k
  _inverse_DCT_method_ptr method_ptr = NULL;
108
5.49k
  JQUANT_TBL *qtbl;
109
110
15.0k
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
111
9.55k
       ci++, compptr++) {
112
    /* Select the proper IDCT routine for this component's scaling */
113
9.55k
    switch (compptr->_DCT_scaled_size) {
114
0
#ifdef IDCT_SCALING_SUPPORTED
115
1.79k
    case 1:
116
1.79k
      method_ptr = _jpeg_idct_1x1;
117
1.79k
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
118
1.79k
      break;
119
430
    case 2:
120
#ifdef WITH_SIMD
121
      if (jsimd_set_idct_2x2(cinfo))
122
        method_ptr = jsimd_idct_2x2;
123
      else
124
#endif
125
430
        method_ptr = _jpeg_idct_2x2;
126
430
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
127
430
      break;
128
0
    case 3:
129
0
      method_ptr = _jpeg_idct_3x3;
130
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
131
0
      break;
132
1.80k
    case 4:
133
#ifdef WITH_SIMD
134
      if (jsimd_set_idct_4x4(cinfo))
135
        method_ptr = jsimd_idct_4x4;
136
      else
137
#endif
138
1.80k
        method_ptr = _jpeg_idct_4x4;
139
1.80k
      method = JDCT_ISLOW;      /* jidctred uses islow-style table */
140
1.80k
      break;
141
0
    case 5:
142
0
      method_ptr = _jpeg_idct_5x5;
143
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
144
0
      break;
145
0
    case 6:
146
0
      method_ptr = _jpeg_idct_6x6;
147
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
148
0
      break;
149
0
    case 7:
150
0
      method_ptr = _jpeg_idct_7x7;
151
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
152
0
      break;
153
0
#endif
154
5.53k
    case DCTSIZE:
155
5.53k
      switch (cinfo->dct_method) {
156
0
#ifdef DCT_ISLOW_SUPPORTED
157
3.29k
      case JDCT_ISLOW:
158
#ifdef WITH_SIMD
159
        if (jsimd_set_idct_islow(cinfo))
160
          method_ptr = jsimd_idct_islow;
161
        else
162
#endif
163
3.29k
          method_ptr = _jpeg_idct_islow;
164
3.29k
        method = JDCT_ISLOW;
165
3.29k
        break;
166
0
#endif
167
0
#ifdef DCT_IFAST_SUPPORTED
168
2.24k
      case JDCT_IFAST:
169
#ifdef WITH_SIMD
170
        if (jsimd_set_idct_ifast(cinfo))
171
          method_ptr = jsimd_idct_ifast;
172
        else
173
#endif
174
2.24k
          method_ptr = _jpeg_idct_ifast;
175
2.24k
        method = JDCT_IFAST;
176
2.24k
        break;
177
0
#endif
178
0
#ifdef DCT_FLOAT_SUPPORTED
179
0
      case JDCT_FLOAT:
180
#ifdef WITH_SIMD
181
        if (jsimd_set_idct_float(cinfo))
182
          method_ptr = jsimd_idct_float;
183
        else
184
#endif
185
0
          method_ptr = _jpeg_idct_float;
186
0
        method = JDCT_FLOAT;
187
0
        break;
188
0
#endif
189
0
      default:
190
0
        ERREXIT(cinfo, JERR_NOT_COMPILED);
191
0
        break;
192
5.53k
      }
193
5.53k
      break;
194
5.53k
#ifdef IDCT_SCALING_SUPPORTED
195
5.53k
    case 9:
196
0
      method_ptr = _jpeg_idct_9x9;
197
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
198
0
      break;
199
0
    case 10:
200
0
      method_ptr = _jpeg_idct_10x10;
201
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
202
0
      break;
203
0
    case 11:
204
0
      method_ptr = _jpeg_idct_11x11;
205
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
206
0
      break;
207
0
    case 12:
208
0
      method_ptr = _jpeg_idct_12x12;
209
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
210
0
      break;
211
0
    case 13:
212
0
      method_ptr = _jpeg_idct_13x13;
213
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
214
0
      break;
215
0
    case 14:
216
0
      method_ptr = _jpeg_idct_14x14;
217
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
218
0
      break;
219
0
    case 15:
220
0
      method_ptr = _jpeg_idct_15x15;
221
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
222
0
      break;
223
0
    case 16:
224
0
      method_ptr = _jpeg_idct_16x16;
225
0
      method = JDCT_ISLOW;      /* jidctint uses islow-style table */
226
0
      break;
227
0
#endif
228
0
    default:
229
0
      ERREXIT1(cinfo, JERR_BAD_DCTSIZE, compptr->_DCT_scaled_size);
230
0
      break;
231
9.55k
    }
232
9.55k
    idct->pub._inverse_DCT[ci] = method_ptr;
233
    /* Create multiplier table from quant table.
234
     * However, we can skip this if the component is uninteresting
235
     * or if we already built the table.  Also, if no quant table
236
     * has yet been saved for the component, we leave the
237
     * multiplier table all-zero; we'll be reading zeroes from the
238
     * coefficient controller's buffer anyway.
239
     */
240
9.55k
    if (!compptr->component_needed || idct->cur_method[ci] == method)
241
1.02k
      continue;
242
8.53k
    qtbl = compptr->quant_table;
243
8.53k
    if (qtbl == NULL)           /* happens if no data yet for component */
244
2.31k
      continue;
245
6.22k
    idct->cur_method[ci] = method;
246
6.22k
    switch (method) {
247
0
#ifdef PROVIDE_ISLOW_TABLES
248
4.58k
    case JDCT_ISLOW:
249
4.58k
      {
250
        /* For LL&M IDCT method, multipliers are equal to raw quantization
251
         * coefficients, but are stored as ints to ensure access efficiency.
252
         */
253
4.58k
        ISLOW_MULT_TYPE *ismtbl = (ISLOW_MULT_TYPE *)compptr->dct_table;
254
297k
        for (i = 0; i < DCTSIZE2; i++) {
255
293k
          ismtbl[i] = (ISLOW_MULT_TYPE)qtbl->quantval[i];
256
293k
        }
257
4.58k
      }
258
4.58k
      break;
259
0
#endif
260
0
#ifdef DCT_IFAST_SUPPORTED
261
1.64k
    case JDCT_IFAST:
262
1.64k
      {
263
        /* For AA&N IDCT method, multipliers are equal to quantization
264
         * coefficients scaled by scalefactor[row]*scalefactor[col], where
265
         *   scalefactor[0] = 1
266
         *   scalefactor[k] = cos(k*PI/16) * sqrt(2)    for k=1..7
267
         * For integer operation, the multiplier table is to be scaled by
268
         * IFAST_SCALE_BITS.
269
         */
270
1.64k
        IFAST_MULT_TYPE *ifmtbl = (IFAST_MULT_TYPE *)compptr->dct_table;
271
1.64k
#define CONST_BITS  14
272
1.64k
        static const INT16 aanscales[DCTSIZE2] = {
273
          /* precomputed values scaled up by 14 bits */
274
1.64k
          16384, 22725, 21407, 19266, 16384, 12873,  8867,  4520,
275
1.64k
          22725, 31521, 29692, 26722, 22725, 17855, 12299,  6270,
276
1.64k
          21407, 29692, 27969, 25172, 21407, 16819, 11585,  5906,
277
1.64k
          19266, 26722, 25172, 22654, 19266, 15137, 10426,  5315,
278
1.64k
          16384, 22725, 21407, 19266, 16384, 12873,  8867,  4520,
279
1.64k
          12873, 17855, 16819, 15137, 12873, 10114,  6967,  3552,
280
1.64k
           8867, 12299, 11585, 10426,  8867,  6967,  4799,  2446,
281
1.64k
           4520,  6270,  5906,  5315,  4520,  3552,  2446,  1247
282
1.64k
        };
283
1.64k
        SHIFT_TEMPS
284
285
106k
        for (i = 0; i < DCTSIZE2; i++) {
286
105k
          ifmtbl[i] = (IFAST_MULT_TYPE)
287
105k
            DESCALE(MULTIPLY16V16((JLONG)qtbl->quantval[i],
288
105k
                                  (JLONG)aanscales[i]),
289
105k
                    CONST_BITS - IFAST_SCALE_BITS);
290
105k
        }
291
1.64k
      }
292
1.64k
      break;
293
0
#endif
294
0
#ifdef DCT_FLOAT_SUPPORTED
295
0
    case JDCT_FLOAT:
296
0
      {
297
        /* For float AA&N IDCT method, multipliers are equal to quantization
298
         * coefficients scaled by scalefactor[row]*scalefactor[col], where
299
         *   scalefactor[0] = 1
300
         *   scalefactor[k] = cos(k*PI/16) * sqrt(2)    for k=1..7
301
         */
302
0
        FLOAT_MULT_TYPE *fmtbl = (FLOAT_MULT_TYPE *)compptr->dct_table;
303
0
        int row, col;
304
0
        static const double aanscalefactor[DCTSIZE] = {
305
0
          1.0, 1.387039845, 1.306562965, 1.175875602,
306
0
          1.0, 0.785694958, 0.541196100, 0.275899379
307
0
        };
308
309
0
        i = 0;
310
0
        for (row = 0; row < DCTSIZE; row++) {
311
0
          for (col = 0; col < DCTSIZE; col++) {
312
0
            fmtbl[i] = (FLOAT_MULT_TYPE)
313
0
              ((double)qtbl->quantval[i] *
314
0
               aanscalefactor[row] * aanscalefactor[col]);
315
0
            i++;
316
0
          }
317
0
        }
318
0
      }
319
0
      break;
320
0
#endif
321
0
    default:
322
0
      ERREXIT(cinfo, JERR_NOT_COMPILED);
323
0
      break;
324
6.22k
    }
325
6.22k
  }
326
5.49k
}
327
328
329
/*
330
 * Initialize IDCT manager.
331
 */
332
333
GLOBAL(void)
334
_jinit_inverse_dct(j_decompress_ptr cinfo)
335
15.9k
{
336
15.9k
  my_idct_ptr idct;
337
15.9k
  int ci;
338
15.9k
  jpeg_component_info *compptr;
339
340
15.9k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
341
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
342
343
15.9k
  idct = (my_idct_ptr)
344
15.9k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
345
15.9k
                                sizeof(my_idct_controller));
346
15.9k
  cinfo->idct = (struct jpeg_inverse_dct *)idct;
347
15.9k
  idct->pub.start_pass = start_pass;
348
349
41.9k
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
350
26.0k
       ci++, compptr++) {
351
    /* Allocate and pre-zero a multiplier table for each component */
352
26.0k
    compptr->dct_table =
353
26.0k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
354
26.0k
                                  sizeof(multiplier_table));
355
26.0k
    memset(compptr->dct_table, 0, sizeof(multiplier_table));
356
    /* Mark multiplier table not yet set up for any method */
357
26.0k
    idct->cur_method[ci] = -1;
358
26.0k
  }
359
15.9k
}
jinit_inverse_dct
Line
Count
Source
335
9.29k
{
336
9.29k
  my_idct_ptr idct;
337
9.29k
  int ci;
338
9.29k
  jpeg_component_info *compptr;
339
340
9.29k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
341
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
342
343
9.29k
  idct = (my_idct_ptr)
344
9.29k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
345
9.29k
                                sizeof(my_idct_controller));
346
9.29k
  cinfo->idct = (struct jpeg_inverse_dct *)idct;
347
9.29k
  idct->pub.start_pass = start_pass;
348
349
23.4k
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
350
14.1k
       ci++, compptr++) {
351
    /* Allocate and pre-zero a multiplier table for each component */
352
14.1k
    compptr->dct_table =
353
14.1k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
354
14.1k
                                  sizeof(multiplier_table));
355
14.1k
    memset(compptr->dct_table, 0, sizeof(multiplier_table));
356
    /* Mark multiplier table not yet set up for any method */
357
14.1k
    idct->cur_method[ci] = -1;
358
14.1k
  }
359
9.29k
}
j12init_inverse_dct
Line
Count
Source
335
6.61k
{
336
6.61k
  my_idct_ptr idct;
337
6.61k
  int ci;
338
6.61k
  jpeg_component_info *compptr;
339
340
6.61k
  if (cinfo->data_precision != BITS_IN_JSAMPLE)
341
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
342
343
6.61k
  idct = (my_idct_ptr)
344
6.61k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
345
6.61k
                                sizeof(my_idct_controller));
346
6.61k
  cinfo->idct = (struct jpeg_inverse_dct *)idct;
347
6.61k
  idct->pub.start_pass = start_pass;
348
349
18.5k
  for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
350
11.8k
       ci++, compptr++) {
351
    /* Allocate and pre-zero a multiplier table for each component */
352
11.8k
    compptr->dct_table =
353
11.8k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
354
11.8k
                                  sizeof(multiplier_table));
355
11.8k
    memset(compptr->dct_table, 0, sizeof(multiplier_table));
356
    /* Mark multiplier table not yet set up for any method */
357
11.8k
    idct->cur_method[ci] = -1;
358
11.8k
  }
359
6.61k
}
360
361
#endif /* defined(DCT_ISLOW_SUPPORTED) || defined(DCT_IFAST_SUPPORTED) ||
362
          defined(DCT_FLOAT_SUPPORTED) */