1*dfc6aa5cSAndroid Build Coastguard Worker /*
2*dfc6aa5cSAndroid Build Coastguard Worker * jsimd_x86_64.c
3*dfc6aa5cSAndroid Build Coastguard Worker *
4*dfc6aa5cSAndroid Build Coastguard Worker * Copyright 2009 Pierre Ossman <[email protected]> for Cendio AB
5*dfc6aa5cSAndroid Build Coastguard Worker * Copyright (C) 2009-2011, 2014, 2016, 2018, 2022-2023, D. R. Commander.
6*dfc6aa5cSAndroid Build Coastguard Worker * Copyright (C) 2015-2016, 2018, 2022, Matthieu Darbois.
7*dfc6aa5cSAndroid Build Coastguard Worker *
8*dfc6aa5cSAndroid Build Coastguard Worker * Based on the x86 SIMD extension for IJG JPEG library,
9*dfc6aa5cSAndroid Build Coastguard Worker * Copyright (C) 1999-2006, MIYASAKA Masaru.
10*dfc6aa5cSAndroid Build Coastguard Worker * For conditions of distribution and use, see copyright notice in jsimdext.inc
11*dfc6aa5cSAndroid Build Coastguard Worker *
12*dfc6aa5cSAndroid Build Coastguard Worker * This file contains the interface between the "normal" portions
13*dfc6aa5cSAndroid Build Coastguard Worker * of the library and the SIMD implementations when running on a
14*dfc6aa5cSAndroid Build Coastguard Worker * 64-bit x86 architecture.
15*dfc6aa5cSAndroid Build Coastguard Worker */
16*dfc6aa5cSAndroid Build Coastguard Worker
17*dfc6aa5cSAndroid Build Coastguard Worker #define JPEG_INTERNALS
18*dfc6aa5cSAndroid Build Coastguard Worker #include "../../jinclude.h"
19*dfc6aa5cSAndroid Build Coastguard Worker #include "../../jpeglib.h"
20*dfc6aa5cSAndroid Build Coastguard Worker #include "../../jsimd.h"
21*dfc6aa5cSAndroid Build Coastguard Worker #include "../../jdct.h"
22*dfc6aa5cSAndroid Build Coastguard Worker #include "../../jsimddct.h"
23*dfc6aa5cSAndroid Build Coastguard Worker #include "../jsimd.h"
24*dfc6aa5cSAndroid Build Coastguard Worker
25*dfc6aa5cSAndroid Build Coastguard Worker /*
26*dfc6aa5cSAndroid Build Coastguard Worker * In the PIC cases, we have no guarantee that constants will keep
27*dfc6aa5cSAndroid Build Coastguard Worker * their alignment. This macro allows us to verify it at runtime.
28*dfc6aa5cSAndroid Build Coastguard Worker */
29*dfc6aa5cSAndroid Build Coastguard Worker #define IS_ALIGNED(ptr, order) (((size_t)ptr & ((1 << order) - 1)) == 0)
30*dfc6aa5cSAndroid Build Coastguard Worker
31*dfc6aa5cSAndroid Build Coastguard Worker #define IS_ALIGNED_SSE(ptr) (IS_ALIGNED(ptr, 4)) /* 16 byte alignment */
32*dfc6aa5cSAndroid Build Coastguard Worker #define IS_ALIGNED_AVX(ptr) (IS_ALIGNED(ptr, 5)) /* 32 byte alignment */
33*dfc6aa5cSAndroid Build Coastguard Worker
34*dfc6aa5cSAndroid Build Coastguard Worker static THREAD_LOCAL unsigned int simd_support = (unsigned int)(~0);
35*dfc6aa5cSAndroid Build Coastguard Worker static THREAD_LOCAL unsigned int simd_huffman = 1;
36*dfc6aa5cSAndroid Build Coastguard Worker
37*dfc6aa5cSAndroid Build Coastguard Worker /*
38*dfc6aa5cSAndroid Build Coastguard Worker * Check what SIMD accelerations are supported.
39*dfc6aa5cSAndroid Build Coastguard Worker */
40*dfc6aa5cSAndroid Build Coastguard Worker LOCAL(void)
init_simd(void)41*dfc6aa5cSAndroid Build Coastguard Worker init_simd(void)
42*dfc6aa5cSAndroid Build Coastguard Worker {
43*dfc6aa5cSAndroid Build Coastguard Worker #ifndef NO_GETENV
44*dfc6aa5cSAndroid Build Coastguard Worker char env[2] = { 0 };
45*dfc6aa5cSAndroid Build Coastguard Worker #endif
46*dfc6aa5cSAndroid Build Coastguard Worker
47*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support != ~0U)
48*dfc6aa5cSAndroid Build Coastguard Worker return;
49*dfc6aa5cSAndroid Build Coastguard Worker
50*dfc6aa5cSAndroid Build Coastguard Worker simd_support = jpeg_simd_cpu_support();
51*dfc6aa5cSAndroid Build Coastguard Worker
52*dfc6aa5cSAndroid Build Coastguard Worker #ifndef NO_GETENV
53*dfc6aa5cSAndroid Build Coastguard Worker /* Force different settings through environment variables */
54*dfc6aa5cSAndroid Build Coastguard Worker if (!GETENV_S(env, 2, "JSIMD_FORCESSE2") && !strcmp(env, "1"))
55*dfc6aa5cSAndroid Build Coastguard Worker simd_support &= JSIMD_SSE2;
56*dfc6aa5cSAndroid Build Coastguard Worker if (!GETENV_S(env, 2, "JSIMD_FORCEAVX2") && !strcmp(env, "1"))
57*dfc6aa5cSAndroid Build Coastguard Worker simd_support &= JSIMD_AVX2;
58*dfc6aa5cSAndroid Build Coastguard Worker if (!GETENV_S(env, 2, "JSIMD_FORCENONE") && !strcmp(env, "1"))
59*dfc6aa5cSAndroid Build Coastguard Worker simd_support = 0;
60*dfc6aa5cSAndroid Build Coastguard Worker if (!GETENV_S(env, 2, "JSIMD_NOHUFFENC") && !strcmp(env, "1"))
61*dfc6aa5cSAndroid Build Coastguard Worker simd_huffman = 0;
62*dfc6aa5cSAndroid Build Coastguard Worker #endif
63*dfc6aa5cSAndroid Build Coastguard Worker }
64*dfc6aa5cSAndroid Build Coastguard Worker
65*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_rgb_ycc(void)66*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_rgb_ycc(void)
67*dfc6aa5cSAndroid Build Coastguard Worker {
68*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
69*dfc6aa5cSAndroid Build Coastguard Worker
70*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
71*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
72*dfc6aa5cSAndroid Build Coastguard Worker return 0;
73*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
74*dfc6aa5cSAndroid Build Coastguard Worker return 0;
75*dfc6aa5cSAndroid Build Coastguard Worker if ((RGB_PIXELSIZE != 3) && (RGB_PIXELSIZE != 4))
76*dfc6aa5cSAndroid Build Coastguard Worker return 0;
77*dfc6aa5cSAndroid Build Coastguard Worker
78*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) &&
79*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_AVX(jconst_rgb_ycc_convert_avx2))
80*dfc6aa5cSAndroid Build Coastguard Worker return 1;
81*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) &&
82*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_SSE(jconst_rgb_ycc_convert_sse2))
83*dfc6aa5cSAndroid Build Coastguard Worker return 1;
84*dfc6aa5cSAndroid Build Coastguard Worker
85*dfc6aa5cSAndroid Build Coastguard Worker return 0;
86*dfc6aa5cSAndroid Build Coastguard Worker }
87*dfc6aa5cSAndroid Build Coastguard Worker
88*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_rgb_gray(void)89*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_rgb_gray(void)
90*dfc6aa5cSAndroid Build Coastguard Worker {
91*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
92*dfc6aa5cSAndroid Build Coastguard Worker
93*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
94*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
95*dfc6aa5cSAndroid Build Coastguard Worker return 0;
96*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
97*dfc6aa5cSAndroid Build Coastguard Worker return 0;
98*dfc6aa5cSAndroid Build Coastguard Worker if ((RGB_PIXELSIZE != 3) && (RGB_PIXELSIZE != 4))
99*dfc6aa5cSAndroid Build Coastguard Worker return 0;
100*dfc6aa5cSAndroid Build Coastguard Worker
101*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) &&
102*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_AVX(jconst_rgb_gray_convert_avx2))
103*dfc6aa5cSAndroid Build Coastguard Worker return 1;
104*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) &&
105*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_SSE(jconst_rgb_gray_convert_sse2))
106*dfc6aa5cSAndroid Build Coastguard Worker return 1;
107*dfc6aa5cSAndroid Build Coastguard Worker
108*dfc6aa5cSAndroid Build Coastguard Worker return 0;
109*dfc6aa5cSAndroid Build Coastguard Worker }
110*dfc6aa5cSAndroid Build Coastguard Worker
111*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_ycc_rgb(void)112*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_ycc_rgb(void)
113*dfc6aa5cSAndroid Build Coastguard Worker {
114*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
115*dfc6aa5cSAndroid Build Coastguard Worker
116*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
117*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
118*dfc6aa5cSAndroid Build Coastguard Worker return 0;
119*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
120*dfc6aa5cSAndroid Build Coastguard Worker return 0;
121*dfc6aa5cSAndroid Build Coastguard Worker if ((RGB_PIXELSIZE != 3) && (RGB_PIXELSIZE != 4))
122*dfc6aa5cSAndroid Build Coastguard Worker return 0;
123*dfc6aa5cSAndroid Build Coastguard Worker
124*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) &&
125*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_AVX(jconst_ycc_rgb_convert_avx2))
126*dfc6aa5cSAndroid Build Coastguard Worker return 1;
127*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) &&
128*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_SSE(jconst_ycc_rgb_convert_sse2))
129*dfc6aa5cSAndroid Build Coastguard Worker return 1;
130*dfc6aa5cSAndroid Build Coastguard Worker
131*dfc6aa5cSAndroid Build Coastguard Worker return 0;
132*dfc6aa5cSAndroid Build Coastguard Worker }
133*dfc6aa5cSAndroid Build Coastguard Worker
134*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_ycc_rgb565(void)135*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_ycc_rgb565(void)
136*dfc6aa5cSAndroid Build Coastguard Worker {
137*dfc6aa5cSAndroid Build Coastguard Worker return 0;
138*dfc6aa5cSAndroid Build Coastguard Worker }
139*dfc6aa5cSAndroid Build Coastguard Worker
140*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_rgb_ycc_convert(j_compress_ptr cinfo,JSAMPARRAY input_buf,JSAMPIMAGE output_buf,JDIMENSION output_row,int num_rows)141*dfc6aa5cSAndroid Build Coastguard Worker jsimd_rgb_ycc_convert(j_compress_ptr cinfo, JSAMPARRAY input_buf,
142*dfc6aa5cSAndroid Build Coastguard Worker JSAMPIMAGE output_buf, JDIMENSION output_row,
143*dfc6aa5cSAndroid Build Coastguard Worker int num_rows)
144*dfc6aa5cSAndroid Build Coastguard Worker {
145*dfc6aa5cSAndroid Build Coastguard Worker void (*avx2fct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
146*dfc6aa5cSAndroid Build Coastguard Worker void (*sse2fct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
147*dfc6aa5cSAndroid Build Coastguard Worker
148*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
149*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
150*dfc6aa5cSAndroid Build Coastguard Worker
151*dfc6aa5cSAndroid Build Coastguard Worker switch (cinfo->in_color_space) {
152*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGB:
153*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extrgb_ycc_convert_avx2;
154*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extrgb_ycc_convert_sse2;
155*dfc6aa5cSAndroid Build Coastguard Worker break;
156*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBX:
157*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBA:
158*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extrgbx_ycc_convert_avx2;
159*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extrgbx_ycc_convert_sse2;
160*dfc6aa5cSAndroid Build Coastguard Worker break;
161*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGR:
162*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extbgr_ycc_convert_avx2;
163*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extbgr_ycc_convert_sse2;
164*dfc6aa5cSAndroid Build Coastguard Worker break;
165*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRX:
166*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRA:
167*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extbgrx_ycc_convert_avx2;
168*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extbgrx_ycc_convert_sse2;
169*dfc6aa5cSAndroid Build Coastguard Worker break;
170*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XBGR:
171*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ABGR:
172*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extxbgr_ycc_convert_avx2;
173*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extxbgr_ycc_convert_sse2;
174*dfc6aa5cSAndroid Build Coastguard Worker break;
175*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XRGB:
176*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ARGB:
177*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extxrgb_ycc_convert_avx2;
178*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extxrgb_ycc_convert_sse2;
179*dfc6aa5cSAndroid Build Coastguard Worker break;
180*dfc6aa5cSAndroid Build Coastguard Worker default:
181*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_rgb_ycc_convert_avx2;
182*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_rgb_ycc_convert_sse2;
183*dfc6aa5cSAndroid Build Coastguard Worker break;
184*dfc6aa5cSAndroid Build Coastguard Worker }
185*dfc6aa5cSAndroid Build Coastguard Worker
186*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
187*dfc6aa5cSAndroid Build Coastguard Worker avx2fct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
188*dfc6aa5cSAndroid Build Coastguard Worker else
189*dfc6aa5cSAndroid Build Coastguard Worker sse2fct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
190*dfc6aa5cSAndroid Build Coastguard Worker }
191*dfc6aa5cSAndroid Build Coastguard Worker
192*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_rgb_gray_convert(j_compress_ptr cinfo,JSAMPARRAY input_buf,JSAMPIMAGE output_buf,JDIMENSION output_row,int num_rows)193*dfc6aa5cSAndroid Build Coastguard Worker jsimd_rgb_gray_convert(j_compress_ptr cinfo, JSAMPARRAY input_buf,
194*dfc6aa5cSAndroid Build Coastguard Worker JSAMPIMAGE output_buf, JDIMENSION output_row,
195*dfc6aa5cSAndroid Build Coastguard Worker int num_rows)
196*dfc6aa5cSAndroid Build Coastguard Worker {
197*dfc6aa5cSAndroid Build Coastguard Worker void (*avx2fct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
198*dfc6aa5cSAndroid Build Coastguard Worker void (*sse2fct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
199*dfc6aa5cSAndroid Build Coastguard Worker
200*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
201*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
202*dfc6aa5cSAndroid Build Coastguard Worker
203*dfc6aa5cSAndroid Build Coastguard Worker switch (cinfo->in_color_space) {
204*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGB:
205*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extrgb_gray_convert_avx2;
206*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extrgb_gray_convert_sse2;
207*dfc6aa5cSAndroid Build Coastguard Worker break;
208*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBX:
209*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBA:
210*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extrgbx_gray_convert_avx2;
211*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extrgbx_gray_convert_sse2;
212*dfc6aa5cSAndroid Build Coastguard Worker break;
213*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGR:
214*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extbgr_gray_convert_avx2;
215*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extbgr_gray_convert_sse2;
216*dfc6aa5cSAndroid Build Coastguard Worker break;
217*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRX:
218*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRA:
219*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extbgrx_gray_convert_avx2;
220*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extbgrx_gray_convert_sse2;
221*dfc6aa5cSAndroid Build Coastguard Worker break;
222*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XBGR:
223*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ABGR:
224*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extxbgr_gray_convert_avx2;
225*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extxbgr_gray_convert_sse2;
226*dfc6aa5cSAndroid Build Coastguard Worker break;
227*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XRGB:
228*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ARGB:
229*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_extxrgb_gray_convert_avx2;
230*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_extxrgb_gray_convert_sse2;
231*dfc6aa5cSAndroid Build Coastguard Worker break;
232*dfc6aa5cSAndroid Build Coastguard Worker default:
233*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_rgb_gray_convert_avx2;
234*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_rgb_gray_convert_sse2;
235*dfc6aa5cSAndroid Build Coastguard Worker break;
236*dfc6aa5cSAndroid Build Coastguard Worker }
237*dfc6aa5cSAndroid Build Coastguard Worker
238*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
239*dfc6aa5cSAndroid Build Coastguard Worker avx2fct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
240*dfc6aa5cSAndroid Build Coastguard Worker else
241*dfc6aa5cSAndroid Build Coastguard Worker sse2fct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
242*dfc6aa5cSAndroid Build Coastguard Worker }
243*dfc6aa5cSAndroid Build Coastguard Worker
244*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_ycc_rgb_convert(j_decompress_ptr cinfo,JSAMPIMAGE input_buf,JDIMENSION input_row,JSAMPARRAY output_buf,int num_rows)245*dfc6aa5cSAndroid Build Coastguard Worker jsimd_ycc_rgb_convert(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
246*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION input_row, JSAMPARRAY output_buf,
247*dfc6aa5cSAndroid Build Coastguard Worker int num_rows)
248*dfc6aa5cSAndroid Build Coastguard Worker {
249*dfc6aa5cSAndroid Build Coastguard Worker void (*avx2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY, int);
250*dfc6aa5cSAndroid Build Coastguard Worker void (*sse2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY, int);
251*dfc6aa5cSAndroid Build Coastguard Worker
252*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
253*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
254*dfc6aa5cSAndroid Build Coastguard Worker
255*dfc6aa5cSAndroid Build Coastguard Worker switch (cinfo->out_color_space) {
256*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGB:
257*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_ycc_extrgb_convert_avx2;
258*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_ycc_extrgb_convert_sse2;
259*dfc6aa5cSAndroid Build Coastguard Worker break;
260*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBX:
261*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBA:
262*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_ycc_extrgbx_convert_avx2;
263*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_ycc_extrgbx_convert_sse2;
264*dfc6aa5cSAndroid Build Coastguard Worker break;
265*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGR:
266*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_ycc_extbgr_convert_avx2;
267*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_ycc_extbgr_convert_sse2;
268*dfc6aa5cSAndroid Build Coastguard Worker break;
269*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRX:
270*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRA:
271*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_ycc_extbgrx_convert_avx2;
272*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_ycc_extbgrx_convert_sse2;
273*dfc6aa5cSAndroid Build Coastguard Worker break;
274*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XBGR:
275*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ABGR:
276*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_ycc_extxbgr_convert_avx2;
277*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_ycc_extxbgr_convert_sse2;
278*dfc6aa5cSAndroid Build Coastguard Worker break;
279*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XRGB:
280*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ARGB:
281*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_ycc_extxrgb_convert_avx2;
282*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_ycc_extxrgb_convert_sse2;
283*dfc6aa5cSAndroid Build Coastguard Worker break;
284*dfc6aa5cSAndroid Build Coastguard Worker default:
285*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_ycc_rgb_convert_avx2;
286*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_ycc_rgb_convert_sse2;
287*dfc6aa5cSAndroid Build Coastguard Worker break;
288*dfc6aa5cSAndroid Build Coastguard Worker }
289*dfc6aa5cSAndroid Build Coastguard Worker
290*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
291*dfc6aa5cSAndroid Build Coastguard Worker avx2fct(cinfo->output_width, input_buf, input_row, output_buf, num_rows);
292*dfc6aa5cSAndroid Build Coastguard Worker else
293*dfc6aa5cSAndroid Build Coastguard Worker sse2fct(cinfo->output_width, input_buf, input_row, output_buf, num_rows);
294*dfc6aa5cSAndroid Build Coastguard Worker }
295*dfc6aa5cSAndroid Build Coastguard Worker
296*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_ycc_rgb565_convert(j_decompress_ptr cinfo,JSAMPIMAGE input_buf,JDIMENSION input_row,JSAMPARRAY output_buf,int num_rows)297*dfc6aa5cSAndroid Build Coastguard Worker jsimd_ycc_rgb565_convert(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
298*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION input_row, JSAMPARRAY output_buf,
299*dfc6aa5cSAndroid Build Coastguard Worker int num_rows)
300*dfc6aa5cSAndroid Build Coastguard Worker {
301*dfc6aa5cSAndroid Build Coastguard Worker }
302*dfc6aa5cSAndroid Build Coastguard Worker
303*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_h2v2_downsample(void)304*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_h2v2_downsample(void)
305*dfc6aa5cSAndroid Build Coastguard Worker {
306*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
307*dfc6aa5cSAndroid Build Coastguard Worker
308*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
309*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
310*dfc6aa5cSAndroid Build Coastguard Worker return 0;
311*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
312*dfc6aa5cSAndroid Build Coastguard Worker return 0;
313*dfc6aa5cSAndroid Build Coastguard Worker
314*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
315*dfc6aa5cSAndroid Build Coastguard Worker return 1;
316*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
317*dfc6aa5cSAndroid Build Coastguard Worker return 1;
318*dfc6aa5cSAndroid Build Coastguard Worker
319*dfc6aa5cSAndroid Build Coastguard Worker return 0;
320*dfc6aa5cSAndroid Build Coastguard Worker }
321*dfc6aa5cSAndroid Build Coastguard Worker
322*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_h2v1_downsample(void)323*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_h2v1_downsample(void)
324*dfc6aa5cSAndroid Build Coastguard Worker {
325*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
326*dfc6aa5cSAndroid Build Coastguard Worker
327*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
328*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
329*dfc6aa5cSAndroid Build Coastguard Worker return 0;
330*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
331*dfc6aa5cSAndroid Build Coastguard Worker return 0;
332*dfc6aa5cSAndroid Build Coastguard Worker
333*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
334*dfc6aa5cSAndroid Build Coastguard Worker return 1;
335*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
336*dfc6aa5cSAndroid Build Coastguard Worker return 1;
337*dfc6aa5cSAndroid Build Coastguard Worker
338*dfc6aa5cSAndroid Build Coastguard Worker return 0;
339*dfc6aa5cSAndroid Build Coastguard Worker }
340*dfc6aa5cSAndroid Build Coastguard Worker
341*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_h2v2_downsample(j_compress_ptr cinfo,jpeg_component_info * compptr,JSAMPARRAY input_data,JSAMPARRAY output_data)342*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_downsample(j_compress_ptr cinfo, jpeg_component_info *compptr,
343*dfc6aa5cSAndroid Build Coastguard Worker JSAMPARRAY input_data, JSAMPARRAY output_data)
344*dfc6aa5cSAndroid Build Coastguard Worker {
345*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
346*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
347*dfc6aa5cSAndroid Build Coastguard Worker
348*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
349*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_downsample_avx2(cinfo->image_width, cinfo->max_v_samp_factor,
350*dfc6aa5cSAndroid Build Coastguard Worker compptr->v_samp_factor,
351*dfc6aa5cSAndroid Build Coastguard Worker compptr->width_in_blocks, input_data,
352*dfc6aa5cSAndroid Build Coastguard Worker output_data);
353*dfc6aa5cSAndroid Build Coastguard Worker else
354*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_downsample_sse2(cinfo->image_width, cinfo->max_v_samp_factor,
355*dfc6aa5cSAndroid Build Coastguard Worker compptr->v_samp_factor,
356*dfc6aa5cSAndroid Build Coastguard Worker compptr->width_in_blocks, input_data,
357*dfc6aa5cSAndroid Build Coastguard Worker output_data);
358*dfc6aa5cSAndroid Build Coastguard Worker }
359*dfc6aa5cSAndroid Build Coastguard Worker
360*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_h2v1_downsample(j_compress_ptr cinfo,jpeg_component_info * compptr,JSAMPARRAY input_data,JSAMPARRAY output_data)361*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_downsample(j_compress_ptr cinfo, jpeg_component_info *compptr,
362*dfc6aa5cSAndroid Build Coastguard Worker JSAMPARRAY input_data, JSAMPARRAY output_data)
363*dfc6aa5cSAndroid Build Coastguard Worker {
364*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
365*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
366*dfc6aa5cSAndroid Build Coastguard Worker
367*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
368*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_downsample_avx2(cinfo->image_width, cinfo->max_v_samp_factor,
369*dfc6aa5cSAndroid Build Coastguard Worker compptr->v_samp_factor,
370*dfc6aa5cSAndroid Build Coastguard Worker compptr->width_in_blocks, input_data,
371*dfc6aa5cSAndroid Build Coastguard Worker output_data);
372*dfc6aa5cSAndroid Build Coastguard Worker else
373*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_downsample_sse2(cinfo->image_width, cinfo->max_v_samp_factor,
374*dfc6aa5cSAndroid Build Coastguard Worker compptr->v_samp_factor,
375*dfc6aa5cSAndroid Build Coastguard Worker compptr->width_in_blocks, input_data,
376*dfc6aa5cSAndroid Build Coastguard Worker output_data);
377*dfc6aa5cSAndroid Build Coastguard Worker }
378*dfc6aa5cSAndroid Build Coastguard Worker
379*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_h2v2_upsample(void)380*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_h2v2_upsample(void)
381*dfc6aa5cSAndroid Build Coastguard Worker {
382*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
383*dfc6aa5cSAndroid Build Coastguard Worker
384*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
385*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
386*dfc6aa5cSAndroid Build Coastguard Worker return 0;
387*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
388*dfc6aa5cSAndroid Build Coastguard Worker return 0;
389*dfc6aa5cSAndroid Build Coastguard Worker
390*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
391*dfc6aa5cSAndroid Build Coastguard Worker return 1;
392*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
393*dfc6aa5cSAndroid Build Coastguard Worker return 1;
394*dfc6aa5cSAndroid Build Coastguard Worker
395*dfc6aa5cSAndroid Build Coastguard Worker return 0;
396*dfc6aa5cSAndroid Build Coastguard Worker }
397*dfc6aa5cSAndroid Build Coastguard Worker
398*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_h2v1_upsample(void)399*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_h2v1_upsample(void)
400*dfc6aa5cSAndroid Build Coastguard Worker {
401*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
402*dfc6aa5cSAndroid Build Coastguard Worker
403*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
404*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
405*dfc6aa5cSAndroid Build Coastguard Worker return 0;
406*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
407*dfc6aa5cSAndroid Build Coastguard Worker return 0;
408*dfc6aa5cSAndroid Build Coastguard Worker
409*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
410*dfc6aa5cSAndroid Build Coastguard Worker return 1;
411*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
412*dfc6aa5cSAndroid Build Coastguard Worker return 1;
413*dfc6aa5cSAndroid Build Coastguard Worker
414*dfc6aa5cSAndroid Build Coastguard Worker return 0;
415*dfc6aa5cSAndroid Build Coastguard Worker }
416*dfc6aa5cSAndroid Build Coastguard Worker
417*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_h2v2_upsample(j_decompress_ptr cinfo,jpeg_component_info * compptr,JSAMPARRAY input_data,JSAMPARRAY * output_data_ptr)418*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_upsample(j_decompress_ptr cinfo, jpeg_component_info *compptr,
419*dfc6aa5cSAndroid Build Coastguard Worker JSAMPARRAY input_data, JSAMPARRAY *output_data_ptr)
420*dfc6aa5cSAndroid Build Coastguard Worker {
421*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
422*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
423*dfc6aa5cSAndroid Build Coastguard Worker
424*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
425*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_upsample_avx2(cinfo->max_v_samp_factor, cinfo->output_width,
426*dfc6aa5cSAndroid Build Coastguard Worker input_data, output_data_ptr);
427*dfc6aa5cSAndroid Build Coastguard Worker else
428*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_upsample_sse2(cinfo->max_v_samp_factor, cinfo->output_width,
429*dfc6aa5cSAndroid Build Coastguard Worker input_data, output_data_ptr);
430*dfc6aa5cSAndroid Build Coastguard Worker }
431*dfc6aa5cSAndroid Build Coastguard Worker
432*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_h2v1_upsample(j_decompress_ptr cinfo,jpeg_component_info * compptr,JSAMPARRAY input_data,JSAMPARRAY * output_data_ptr)433*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_upsample(j_decompress_ptr cinfo, jpeg_component_info *compptr,
434*dfc6aa5cSAndroid Build Coastguard Worker JSAMPARRAY input_data, JSAMPARRAY *output_data_ptr)
435*dfc6aa5cSAndroid Build Coastguard Worker {
436*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
437*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
438*dfc6aa5cSAndroid Build Coastguard Worker
439*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
440*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_upsample_avx2(cinfo->max_v_samp_factor, cinfo->output_width,
441*dfc6aa5cSAndroid Build Coastguard Worker input_data, output_data_ptr);
442*dfc6aa5cSAndroid Build Coastguard Worker else
443*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_upsample_sse2(cinfo->max_v_samp_factor, cinfo->output_width,
444*dfc6aa5cSAndroid Build Coastguard Worker input_data, output_data_ptr);
445*dfc6aa5cSAndroid Build Coastguard Worker }
446*dfc6aa5cSAndroid Build Coastguard Worker
447*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_h2v2_fancy_upsample(void)448*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_h2v2_fancy_upsample(void)
449*dfc6aa5cSAndroid Build Coastguard Worker {
450*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
451*dfc6aa5cSAndroid Build Coastguard Worker
452*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
453*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
454*dfc6aa5cSAndroid Build Coastguard Worker return 0;
455*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
456*dfc6aa5cSAndroid Build Coastguard Worker return 0;
457*dfc6aa5cSAndroid Build Coastguard Worker
458*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) &&
459*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_AVX(jconst_fancy_upsample_avx2))
460*dfc6aa5cSAndroid Build Coastguard Worker return 1;
461*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) &&
462*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_SSE(jconst_fancy_upsample_sse2))
463*dfc6aa5cSAndroid Build Coastguard Worker return 1;
464*dfc6aa5cSAndroid Build Coastguard Worker
465*dfc6aa5cSAndroid Build Coastguard Worker return 0;
466*dfc6aa5cSAndroid Build Coastguard Worker }
467*dfc6aa5cSAndroid Build Coastguard Worker
468*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_h2v1_fancy_upsample(void)469*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_h2v1_fancy_upsample(void)
470*dfc6aa5cSAndroid Build Coastguard Worker {
471*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
472*dfc6aa5cSAndroid Build Coastguard Worker
473*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
474*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
475*dfc6aa5cSAndroid Build Coastguard Worker return 0;
476*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
477*dfc6aa5cSAndroid Build Coastguard Worker return 0;
478*dfc6aa5cSAndroid Build Coastguard Worker
479*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) &&
480*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_AVX(jconst_fancy_upsample_avx2))
481*dfc6aa5cSAndroid Build Coastguard Worker return 1;
482*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) &&
483*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_SSE(jconst_fancy_upsample_sse2))
484*dfc6aa5cSAndroid Build Coastguard Worker return 1;
485*dfc6aa5cSAndroid Build Coastguard Worker
486*dfc6aa5cSAndroid Build Coastguard Worker return 0;
487*dfc6aa5cSAndroid Build Coastguard Worker }
488*dfc6aa5cSAndroid Build Coastguard Worker
489*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_h2v2_fancy_upsample(j_decompress_ptr cinfo,jpeg_component_info * compptr,JSAMPARRAY input_data,JSAMPARRAY * output_data_ptr)490*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_fancy_upsample(j_decompress_ptr cinfo, jpeg_component_info *compptr,
491*dfc6aa5cSAndroid Build Coastguard Worker JSAMPARRAY input_data, JSAMPARRAY *output_data_ptr)
492*dfc6aa5cSAndroid Build Coastguard Worker {
493*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
494*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
495*dfc6aa5cSAndroid Build Coastguard Worker
496*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
497*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_fancy_upsample_avx2(cinfo->max_v_samp_factor,
498*dfc6aa5cSAndroid Build Coastguard Worker compptr->downsampled_width, input_data,
499*dfc6aa5cSAndroid Build Coastguard Worker output_data_ptr);
500*dfc6aa5cSAndroid Build Coastguard Worker else
501*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_fancy_upsample_sse2(cinfo->max_v_samp_factor,
502*dfc6aa5cSAndroid Build Coastguard Worker compptr->downsampled_width, input_data,
503*dfc6aa5cSAndroid Build Coastguard Worker output_data_ptr);
504*dfc6aa5cSAndroid Build Coastguard Worker }
505*dfc6aa5cSAndroid Build Coastguard Worker
506*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_h2v1_fancy_upsample(j_decompress_ptr cinfo,jpeg_component_info * compptr,JSAMPARRAY input_data,JSAMPARRAY * output_data_ptr)507*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_fancy_upsample(j_decompress_ptr cinfo, jpeg_component_info *compptr,
508*dfc6aa5cSAndroid Build Coastguard Worker JSAMPARRAY input_data, JSAMPARRAY *output_data_ptr)
509*dfc6aa5cSAndroid Build Coastguard Worker {
510*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
511*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
512*dfc6aa5cSAndroid Build Coastguard Worker
513*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
514*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_fancy_upsample_avx2(cinfo->max_v_samp_factor,
515*dfc6aa5cSAndroid Build Coastguard Worker compptr->downsampled_width, input_data,
516*dfc6aa5cSAndroid Build Coastguard Worker output_data_ptr);
517*dfc6aa5cSAndroid Build Coastguard Worker else
518*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_fancy_upsample_sse2(cinfo->max_v_samp_factor,
519*dfc6aa5cSAndroid Build Coastguard Worker compptr->downsampled_width, input_data,
520*dfc6aa5cSAndroid Build Coastguard Worker output_data_ptr);
521*dfc6aa5cSAndroid Build Coastguard Worker }
522*dfc6aa5cSAndroid Build Coastguard Worker
523*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_h2v2_merged_upsample(void)524*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_h2v2_merged_upsample(void)
525*dfc6aa5cSAndroid Build Coastguard Worker {
526*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
527*dfc6aa5cSAndroid Build Coastguard Worker
528*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
529*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
530*dfc6aa5cSAndroid Build Coastguard Worker return 0;
531*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
532*dfc6aa5cSAndroid Build Coastguard Worker return 0;
533*dfc6aa5cSAndroid Build Coastguard Worker
534*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) &&
535*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_AVX(jconst_merged_upsample_avx2))
536*dfc6aa5cSAndroid Build Coastguard Worker return 1;
537*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) &&
538*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_SSE(jconst_merged_upsample_sse2))
539*dfc6aa5cSAndroid Build Coastguard Worker return 1;
540*dfc6aa5cSAndroid Build Coastguard Worker
541*dfc6aa5cSAndroid Build Coastguard Worker return 0;
542*dfc6aa5cSAndroid Build Coastguard Worker }
543*dfc6aa5cSAndroid Build Coastguard Worker
544*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_h2v1_merged_upsample(void)545*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_h2v1_merged_upsample(void)
546*dfc6aa5cSAndroid Build Coastguard Worker {
547*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
548*dfc6aa5cSAndroid Build Coastguard Worker
549*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
550*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
551*dfc6aa5cSAndroid Build Coastguard Worker return 0;
552*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
553*dfc6aa5cSAndroid Build Coastguard Worker return 0;
554*dfc6aa5cSAndroid Build Coastguard Worker
555*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) &&
556*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_AVX(jconst_merged_upsample_avx2))
557*dfc6aa5cSAndroid Build Coastguard Worker return 1;
558*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) &&
559*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_SSE(jconst_merged_upsample_sse2))
560*dfc6aa5cSAndroid Build Coastguard Worker return 1;
561*dfc6aa5cSAndroid Build Coastguard Worker
562*dfc6aa5cSAndroid Build Coastguard Worker return 0;
563*dfc6aa5cSAndroid Build Coastguard Worker }
564*dfc6aa5cSAndroid Build Coastguard Worker
565*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_h2v2_merged_upsample(j_decompress_ptr cinfo,JSAMPIMAGE input_buf,JDIMENSION in_row_group_ctr,JSAMPARRAY output_buf)566*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v2_merged_upsample(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
567*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION in_row_group_ctr, JSAMPARRAY output_buf)
568*dfc6aa5cSAndroid Build Coastguard Worker {
569*dfc6aa5cSAndroid Build Coastguard Worker void (*avx2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
570*dfc6aa5cSAndroid Build Coastguard Worker void (*sse2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
571*dfc6aa5cSAndroid Build Coastguard Worker
572*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
573*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
574*dfc6aa5cSAndroid Build Coastguard Worker
575*dfc6aa5cSAndroid Build Coastguard Worker switch (cinfo->out_color_space) {
576*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGB:
577*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v2_extrgb_merged_upsample_avx2;
578*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v2_extrgb_merged_upsample_sse2;
579*dfc6aa5cSAndroid Build Coastguard Worker break;
580*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBX:
581*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBA:
582*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v2_extrgbx_merged_upsample_avx2;
583*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v2_extrgbx_merged_upsample_sse2;
584*dfc6aa5cSAndroid Build Coastguard Worker break;
585*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGR:
586*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v2_extbgr_merged_upsample_avx2;
587*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v2_extbgr_merged_upsample_sse2;
588*dfc6aa5cSAndroid Build Coastguard Worker break;
589*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRX:
590*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRA:
591*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v2_extbgrx_merged_upsample_avx2;
592*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v2_extbgrx_merged_upsample_sse2;
593*dfc6aa5cSAndroid Build Coastguard Worker break;
594*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XBGR:
595*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ABGR:
596*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v2_extxbgr_merged_upsample_avx2;
597*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v2_extxbgr_merged_upsample_sse2;
598*dfc6aa5cSAndroid Build Coastguard Worker break;
599*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XRGB:
600*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ARGB:
601*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v2_extxrgb_merged_upsample_avx2;
602*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v2_extxrgb_merged_upsample_sse2;
603*dfc6aa5cSAndroid Build Coastguard Worker break;
604*dfc6aa5cSAndroid Build Coastguard Worker default:
605*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v2_merged_upsample_avx2;
606*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v2_merged_upsample_sse2;
607*dfc6aa5cSAndroid Build Coastguard Worker break;
608*dfc6aa5cSAndroid Build Coastguard Worker }
609*dfc6aa5cSAndroid Build Coastguard Worker
610*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
611*dfc6aa5cSAndroid Build Coastguard Worker avx2fct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
612*dfc6aa5cSAndroid Build Coastguard Worker else
613*dfc6aa5cSAndroid Build Coastguard Worker sse2fct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
614*dfc6aa5cSAndroid Build Coastguard Worker }
615*dfc6aa5cSAndroid Build Coastguard Worker
616*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_h2v1_merged_upsample(j_decompress_ptr cinfo,JSAMPIMAGE input_buf,JDIMENSION in_row_group_ctr,JSAMPARRAY output_buf)617*dfc6aa5cSAndroid Build Coastguard Worker jsimd_h2v1_merged_upsample(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
618*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION in_row_group_ctr, JSAMPARRAY output_buf)
619*dfc6aa5cSAndroid Build Coastguard Worker {
620*dfc6aa5cSAndroid Build Coastguard Worker void (*avx2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
621*dfc6aa5cSAndroid Build Coastguard Worker void (*sse2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
622*dfc6aa5cSAndroid Build Coastguard Worker
623*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
624*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
625*dfc6aa5cSAndroid Build Coastguard Worker
626*dfc6aa5cSAndroid Build Coastguard Worker switch (cinfo->out_color_space) {
627*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGB:
628*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v1_extrgb_merged_upsample_avx2;
629*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v1_extrgb_merged_upsample_sse2;
630*dfc6aa5cSAndroid Build Coastguard Worker break;
631*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBX:
632*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_RGBA:
633*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v1_extrgbx_merged_upsample_avx2;
634*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v1_extrgbx_merged_upsample_sse2;
635*dfc6aa5cSAndroid Build Coastguard Worker break;
636*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGR:
637*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v1_extbgr_merged_upsample_avx2;
638*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v1_extbgr_merged_upsample_sse2;
639*dfc6aa5cSAndroid Build Coastguard Worker break;
640*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRX:
641*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_BGRA:
642*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v1_extbgrx_merged_upsample_avx2;
643*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v1_extbgrx_merged_upsample_sse2;
644*dfc6aa5cSAndroid Build Coastguard Worker break;
645*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XBGR:
646*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ABGR:
647*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v1_extxbgr_merged_upsample_avx2;
648*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v1_extxbgr_merged_upsample_sse2;
649*dfc6aa5cSAndroid Build Coastguard Worker break;
650*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_XRGB:
651*dfc6aa5cSAndroid Build Coastguard Worker case JCS_EXT_ARGB:
652*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v1_extxrgb_merged_upsample_avx2;
653*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v1_extxrgb_merged_upsample_sse2;
654*dfc6aa5cSAndroid Build Coastguard Worker break;
655*dfc6aa5cSAndroid Build Coastguard Worker default:
656*dfc6aa5cSAndroid Build Coastguard Worker avx2fct = jsimd_h2v1_merged_upsample_avx2;
657*dfc6aa5cSAndroid Build Coastguard Worker sse2fct = jsimd_h2v1_merged_upsample_sse2;
658*dfc6aa5cSAndroid Build Coastguard Worker break;
659*dfc6aa5cSAndroid Build Coastguard Worker }
660*dfc6aa5cSAndroid Build Coastguard Worker
661*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
662*dfc6aa5cSAndroid Build Coastguard Worker avx2fct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
663*dfc6aa5cSAndroid Build Coastguard Worker else
664*dfc6aa5cSAndroid Build Coastguard Worker sse2fct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
665*dfc6aa5cSAndroid Build Coastguard Worker }
666*dfc6aa5cSAndroid Build Coastguard Worker
667*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_convsamp(void)668*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_convsamp(void)
669*dfc6aa5cSAndroid Build Coastguard Worker {
670*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
671*dfc6aa5cSAndroid Build Coastguard Worker
672*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
673*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
674*dfc6aa5cSAndroid Build Coastguard Worker return 0;
675*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
676*dfc6aa5cSAndroid Build Coastguard Worker return 0;
677*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
678*dfc6aa5cSAndroid Build Coastguard Worker return 0;
679*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(DCTELEM) != 2)
680*dfc6aa5cSAndroid Build Coastguard Worker return 0;
681*dfc6aa5cSAndroid Build Coastguard Worker
682*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
683*dfc6aa5cSAndroid Build Coastguard Worker return 1;
684*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
685*dfc6aa5cSAndroid Build Coastguard Worker return 1;
686*dfc6aa5cSAndroid Build Coastguard Worker
687*dfc6aa5cSAndroid Build Coastguard Worker return 0;
688*dfc6aa5cSAndroid Build Coastguard Worker }
689*dfc6aa5cSAndroid Build Coastguard Worker
690*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_convsamp_float(void)691*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_convsamp_float(void)
692*dfc6aa5cSAndroid Build Coastguard Worker {
693*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
694*dfc6aa5cSAndroid Build Coastguard Worker
695*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
696*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
697*dfc6aa5cSAndroid Build Coastguard Worker return 0;
698*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
699*dfc6aa5cSAndroid Build Coastguard Worker return 0;
700*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
701*dfc6aa5cSAndroid Build Coastguard Worker return 0;
702*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(FAST_FLOAT) != 4)
703*dfc6aa5cSAndroid Build Coastguard Worker return 0;
704*dfc6aa5cSAndroid Build Coastguard Worker
705*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
706*dfc6aa5cSAndroid Build Coastguard Worker return 1;
707*dfc6aa5cSAndroid Build Coastguard Worker
708*dfc6aa5cSAndroid Build Coastguard Worker return 0;
709*dfc6aa5cSAndroid Build Coastguard Worker }
710*dfc6aa5cSAndroid Build Coastguard Worker
711*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_convsamp(JSAMPARRAY sample_data,JDIMENSION start_col,DCTELEM * workspace)712*dfc6aa5cSAndroid Build Coastguard Worker jsimd_convsamp(JSAMPARRAY sample_data, JDIMENSION start_col,
713*dfc6aa5cSAndroid Build Coastguard Worker DCTELEM *workspace)
714*dfc6aa5cSAndroid Build Coastguard Worker {
715*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
716*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
717*dfc6aa5cSAndroid Build Coastguard Worker
718*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
719*dfc6aa5cSAndroid Build Coastguard Worker jsimd_convsamp_avx2(sample_data, start_col, workspace);
720*dfc6aa5cSAndroid Build Coastguard Worker else
721*dfc6aa5cSAndroid Build Coastguard Worker jsimd_convsamp_sse2(sample_data, start_col, workspace);
722*dfc6aa5cSAndroid Build Coastguard Worker }
723*dfc6aa5cSAndroid Build Coastguard Worker
724*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_convsamp_float(JSAMPARRAY sample_data,JDIMENSION start_col,FAST_FLOAT * workspace)725*dfc6aa5cSAndroid Build Coastguard Worker jsimd_convsamp_float(JSAMPARRAY sample_data, JDIMENSION start_col,
726*dfc6aa5cSAndroid Build Coastguard Worker FAST_FLOAT *workspace)
727*dfc6aa5cSAndroid Build Coastguard Worker {
728*dfc6aa5cSAndroid Build Coastguard Worker jsimd_convsamp_float_sse2(sample_data, start_col, workspace);
729*dfc6aa5cSAndroid Build Coastguard Worker }
730*dfc6aa5cSAndroid Build Coastguard Worker
731*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_fdct_islow(void)732*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_fdct_islow(void)
733*dfc6aa5cSAndroid Build Coastguard Worker {
734*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
735*dfc6aa5cSAndroid Build Coastguard Worker
736*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
737*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
738*dfc6aa5cSAndroid Build Coastguard Worker return 0;
739*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(DCTELEM) != 2)
740*dfc6aa5cSAndroid Build Coastguard Worker return 0;
741*dfc6aa5cSAndroid Build Coastguard Worker
742*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) && IS_ALIGNED_AVX(jconst_fdct_islow_avx2))
743*dfc6aa5cSAndroid Build Coastguard Worker return 1;
744*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_fdct_islow_sse2))
745*dfc6aa5cSAndroid Build Coastguard Worker return 1;
746*dfc6aa5cSAndroid Build Coastguard Worker
747*dfc6aa5cSAndroid Build Coastguard Worker return 0;
748*dfc6aa5cSAndroid Build Coastguard Worker }
749*dfc6aa5cSAndroid Build Coastguard Worker
750*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_fdct_ifast(void)751*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_fdct_ifast(void)
752*dfc6aa5cSAndroid Build Coastguard Worker {
753*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
754*dfc6aa5cSAndroid Build Coastguard Worker
755*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
756*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
757*dfc6aa5cSAndroid Build Coastguard Worker return 0;
758*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(DCTELEM) != 2)
759*dfc6aa5cSAndroid Build Coastguard Worker return 0;
760*dfc6aa5cSAndroid Build Coastguard Worker
761*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_fdct_ifast_sse2))
762*dfc6aa5cSAndroid Build Coastguard Worker return 1;
763*dfc6aa5cSAndroid Build Coastguard Worker
764*dfc6aa5cSAndroid Build Coastguard Worker return 0;
765*dfc6aa5cSAndroid Build Coastguard Worker }
766*dfc6aa5cSAndroid Build Coastguard Worker
767*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_fdct_float(void)768*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_fdct_float(void)
769*dfc6aa5cSAndroid Build Coastguard Worker {
770*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
771*dfc6aa5cSAndroid Build Coastguard Worker
772*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
773*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
774*dfc6aa5cSAndroid Build Coastguard Worker return 0;
775*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(FAST_FLOAT) != 4)
776*dfc6aa5cSAndroid Build Coastguard Worker return 0;
777*dfc6aa5cSAndroid Build Coastguard Worker
778*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE) && IS_ALIGNED_SSE(jconst_fdct_float_sse))
779*dfc6aa5cSAndroid Build Coastguard Worker return 1;
780*dfc6aa5cSAndroid Build Coastguard Worker
781*dfc6aa5cSAndroid Build Coastguard Worker return 0;
782*dfc6aa5cSAndroid Build Coastguard Worker }
783*dfc6aa5cSAndroid Build Coastguard Worker
784*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_fdct_islow(DCTELEM * data)785*dfc6aa5cSAndroid Build Coastguard Worker jsimd_fdct_islow(DCTELEM *data)
786*dfc6aa5cSAndroid Build Coastguard Worker {
787*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
788*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
789*dfc6aa5cSAndroid Build Coastguard Worker
790*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
791*dfc6aa5cSAndroid Build Coastguard Worker jsimd_fdct_islow_avx2(data);
792*dfc6aa5cSAndroid Build Coastguard Worker else
793*dfc6aa5cSAndroid Build Coastguard Worker jsimd_fdct_islow_sse2(data);
794*dfc6aa5cSAndroid Build Coastguard Worker }
795*dfc6aa5cSAndroid Build Coastguard Worker
796*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_fdct_ifast(DCTELEM * data)797*dfc6aa5cSAndroid Build Coastguard Worker jsimd_fdct_ifast(DCTELEM *data)
798*dfc6aa5cSAndroid Build Coastguard Worker {
799*dfc6aa5cSAndroid Build Coastguard Worker jsimd_fdct_ifast_sse2(data);
800*dfc6aa5cSAndroid Build Coastguard Worker }
801*dfc6aa5cSAndroid Build Coastguard Worker
802*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_fdct_float(FAST_FLOAT * data)803*dfc6aa5cSAndroid Build Coastguard Worker jsimd_fdct_float(FAST_FLOAT *data)
804*dfc6aa5cSAndroid Build Coastguard Worker {
805*dfc6aa5cSAndroid Build Coastguard Worker jsimd_fdct_float_sse(data);
806*dfc6aa5cSAndroid Build Coastguard Worker }
807*dfc6aa5cSAndroid Build Coastguard Worker
808*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_quantize(void)809*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_quantize(void)
810*dfc6aa5cSAndroid Build Coastguard Worker {
811*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
812*dfc6aa5cSAndroid Build Coastguard Worker
813*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
814*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
815*dfc6aa5cSAndroid Build Coastguard Worker return 0;
816*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
817*dfc6aa5cSAndroid Build Coastguard Worker return 0;
818*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(DCTELEM) != 2)
819*dfc6aa5cSAndroid Build Coastguard Worker return 0;
820*dfc6aa5cSAndroid Build Coastguard Worker
821*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
822*dfc6aa5cSAndroid Build Coastguard Worker return 1;
823*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
824*dfc6aa5cSAndroid Build Coastguard Worker return 1;
825*dfc6aa5cSAndroid Build Coastguard Worker
826*dfc6aa5cSAndroid Build Coastguard Worker return 0;
827*dfc6aa5cSAndroid Build Coastguard Worker }
828*dfc6aa5cSAndroid Build Coastguard Worker
829*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_quantize_float(void)830*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_quantize_float(void)
831*dfc6aa5cSAndroid Build Coastguard Worker {
832*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
833*dfc6aa5cSAndroid Build Coastguard Worker
834*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
835*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
836*dfc6aa5cSAndroid Build Coastguard Worker return 0;
837*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
838*dfc6aa5cSAndroid Build Coastguard Worker return 0;
839*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(FAST_FLOAT) != 4)
840*dfc6aa5cSAndroid Build Coastguard Worker return 0;
841*dfc6aa5cSAndroid Build Coastguard Worker
842*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
843*dfc6aa5cSAndroid Build Coastguard Worker return 1;
844*dfc6aa5cSAndroid Build Coastguard Worker
845*dfc6aa5cSAndroid Build Coastguard Worker return 0;
846*dfc6aa5cSAndroid Build Coastguard Worker }
847*dfc6aa5cSAndroid Build Coastguard Worker
848*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_quantize(JCOEFPTR coef_block,DCTELEM * divisors,DCTELEM * workspace)849*dfc6aa5cSAndroid Build Coastguard Worker jsimd_quantize(JCOEFPTR coef_block, DCTELEM *divisors, DCTELEM *workspace)
850*dfc6aa5cSAndroid Build Coastguard Worker {
851*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
852*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
853*dfc6aa5cSAndroid Build Coastguard Worker
854*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
855*dfc6aa5cSAndroid Build Coastguard Worker jsimd_quantize_avx2(coef_block, divisors, workspace);
856*dfc6aa5cSAndroid Build Coastguard Worker else
857*dfc6aa5cSAndroid Build Coastguard Worker jsimd_quantize_sse2(coef_block, divisors, workspace);
858*dfc6aa5cSAndroid Build Coastguard Worker }
859*dfc6aa5cSAndroid Build Coastguard Worker
860*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_quantize_float(JCOEFPTR coef_block,FAST_FLOAT * divisors,FAST_FLOAT * workspace)861*dfc6aa5cSAndroid Build Coastguard Worker jsimd_quantize_float(JCOEFPTR coef_block, FAST_FLOAT *divisors,
862*dfc6aa5cSAndroid Build Coastguard Worker FAST_FLOAT *workspace)
863*dfc6aa5cSAndroid Build Coastguard Worker {
864*dfc6aa5cSAndroid Build Coastguard Worker jsimd_quantize_float_sse2(coef_block, divisors, workspace);
865*dfc6aa5cSAndroid Build Coastguard Worker }
866*dfc6aa5cSAndroid Build Coastguard Worker
867*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_idct_2x2(void)868*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_idct_2x2(void)
869*dfc6aa5cSAndroid Build Coastguard Worker {
870*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
871*dfc6aa5cSAndroid Build Coastguard Worker
872*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
873*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
874*dfc6aa5cSAndroid Build Coastguard Worker return 0;
875*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
876*dfc6aa5cSAndroid Build Coastguard Worker return 0;
877*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
878*dfc6aa5cSAndroid Build Coastguard Worker return 0;
879*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
880*dfc6aa5cSAndroid Build Coastguard Worker return 0;
881*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(ISLOW_MULT_TYPE) != 2)
882*dfc6aa5cSAndroid Build Coastguard Worker return 0;
883*dfc6aa5cSAndroid Build Coastguard Worker
884*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_red_sse2))
885*dfc6aa5cSAndroid Build Coastguard Worker return 1;
886*dfc6aa5cSAndroid Build Coastguard Worker
887*dfc6aa5cSAndroid Build Coastguard Worker return 0;
888*dfc6aa5cSAndroid Build Coastguard Worker }
889*dfc6aa5cSAndroid Build Coastguard Worker
890*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_idct_4x4(void)891*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_idct_4x4(void)
892*dfc6aa5cSAndroid Build Coastguard Worker {
893*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
894*dfc6aa5cSAndroid Build Coastguard Worker
895*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
896*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
897*dfc6aa5cSAndroid Build Coastguard Worker return 0;
898*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
899*dfc6aa5cSAndroid Build Coastguard Worker return 0;
900*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
901*dfc6aa5cSAndroid Build Coastguard Worker return 0;
902*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
903*dfc6aa5cSAndroid Build Coastguard Worker return 0;
904*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(ISLOW_MULT_TYPE) != 2)
905*dfc6aa5cSAndroid Build Coastguard Worker return 0;
906*dfc6aa5cSAndroid Build Coastguard Worker
907*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_red_sse2))
908*dfc6aa5cSAndroid Build Coastguard Worker return 1;
909*dfc6aa5cSAndroid Build Coastguard Worker
910*dfc6aa5cSAndroid Build Coastguard Worker return 0;
911*dfc6aa5cSAndroid Build Coastguard Worker }
912*dfc6aa5cSAndroid Build Coastguard Worker
913*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_idct_2x2(j_decompress_ptr cinfo,jpeg_component_info * compptr,JCOEFPTR coef_block,JSAMPARRAY output_buf,JDIMENSION output_col)914*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_2x2(j_decompress_ptr cinfo, jpeg_component_info *compptr,
915*dfc6aa5cSAndroid Build Coastguard Worker JCOEFPTR coef_block, JSAMPARRAY output_buf,
916*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION output_col)
917*dfc6aa5cSAndroid Build Coastguard Worker {
918*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_2x2_sse2(compptr->dct_table, coef_block, output_buf, output_col);
919*dfc6aa5cSAndroid Build Coastguard Worker }
920*dfc6aa5cSAndroid Build Coastguard Worker
921*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_idct_4x4(j_decompress_ptr cinfo,jpeg_component_info * compptr,JCOEFPTR coef_block,JSAMPARRAY output_buf,JDIMENSION output_col)922*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_4x4(j_decompress_ptr cinfo, jpeg_component_info *compptr,
923*dfc6aa5cSAndroid Build Coastguard Worker JCOEFPTR coef_block, JSAMPARRAY output_buf,
924*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION output_col)
925*dfc6aa5cSAndroid Build Coastguard Worker {
926*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_4x4_sse2(compptr->dct_table, coef_block, output_buf, output_col);
927*dfc6aa5cSAndroid Build Coastguard Worker }
928*dfc6aa5cSAndroid Build Coastguard Worker
929*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_idct_islow(void)930*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_idct_islow(void)
931*dfc6aa5cSAndroid Build Coastguard Worker {
932*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
933*dfc6aa5cSAndroid Build Coastguard Worker
934*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
935*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
936*dfc6aa5cSAndroid Build Coastguard Worker return 0;
937*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
938*dfc6aa5cSAndroid Build Coastguard Worker return 0;
939*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
940*dfc6aa5cSAndroid Build Coastguard Worker return 0;
941*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
942*dfc6aa5cSAndroid Build Coastguard Worker return 0;
943*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(ISLOW_MULT_TYPE) != 2)
944*dfc6aa5cSAndroid Build Coastguard Worker return 0;
945*dfc6aa5cSAndroid Build Coastguard Worker
946*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_AVX2) && IS_ALIGNED_AVX(jconst_idct_islow_avx2))
947*dfc6aa5cSAndroid Build Coastguard Worker return 1;
948*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_islow_sse2))
949*dfc6aa5cSAndroid Build Coastguard Worker return 1;
950*dfc6aa5cSAndroid Build Coastguard Worker
951*dfc6aa5cSAndroid Build Coastguard Worker return 0;
952*dfc6aa5cSAndroid Build Coastguard Worker }
953*dfc6aa5cSAndroid Build Coastguard Worker
954*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_idct_ifast(void)955*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_idct_ifast(void)
956*dfc6aa5cSAndroid Build Coastguard Worker {
957*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
958*dfc6aa5cSAndroid Build Coastguard Worker
959*dfc6aa5cSAndroid Build Coastguard Worker /* The code is optimised for these values only */
960*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
961*dfc6aa5cSAndroid Build Coastguard Worker return 0;
962*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
963*dfc6aa5cSAndroid Build Coastguard Worker return 0;
964*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
965*dfc6aa5cSAndroid Build Coastguard Worker return 0;
966*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
967*dfc6aa5cSAndroid Build Coastguard Worker return 0;
968*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(IFAST_MULT_TYPE) != 2)
969*dfc6aa5cSAndroid Build Coastguard Worker return 0;
970*dfc6aa5cSAndroid Build Coastguard Worker if (IFAST_SCALE_BITS != 2)
971*dfc6aa5cSAndroid Build Coastguard Worker return 0;
972*dfc6aa5cSAndroid Build Coastguard Worker
973*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_ifast_sse2))
974*dfc6aa5cSAndroid Build Coastguard Worker return 1;
975*dfc6aa5cSAndroid Build Coastguard Worker
976*dfc6aa5cSAndroid Build Coastguard Worker return 0;
977*dfc6aa5cSAndroid Build Coastguard Worker }
978*dfc6aa5cSAndroid Build Coastguard Worker
979*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_idct_float(void)980*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_idct_float(void)
981*dfc6aa5cSAndroid Build Coastguard Worker {
982*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
983*dfc6aa5cSAndroid Build Coastguard Worker
984*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
985*dfc6aa5cSAndroid Build Coastguard Worker return 0;
986*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
987*dfc6aa5cSAndroid Build Coastguard Worker return 0;
988*dfc6aa5cSAndroid Build Coastguard Worker if (BITS_IN_JSAMPLE != 8)
989*dfc6aa5cSAndroid Build Coastguard Worker return 0;
990*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JDIMENSION) != 4)
991*dfc6aa5cSAndroid Build Coastguard Worker return 0;
992*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(FAST_FLOAT) != 4)
993*dfc6aa5cSAndroid Build Coastguard Worker return 0;
994*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(FLOAT_MULT_TYPE) != 4)
995*dfc6aa5cSAndroid Build Coastguard Worker return 0;
996*dfc6aa5cSAndroid Build Coastguard Worker
997*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_float_sse2))
998*dfc6aa5cSAndroid Build Coastguard Worker return 1;
999*dfc6aa5cSAndroid Build Coastguard Worker
1000*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1001*dfc6aa5cSAndroid Build Coastguard Worker }
1002*dfc6aa5cSAndroid Build Coastguard Worker
1003*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_idct_islow(j_decompress_ptr cinfo,jpeg_component_info * compptr,JCOEFPTR coef_block,JSAMPARRAY output_buf,JDIMENSION output_col)1004*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_islow(j_decompress_ptr cinfo, jpeg_component_info *compptr,
1005*dfc6aa5cSAndroid Build Coastguard Worker JCOEFPTR coef_block, JSAMPARRAY output_buf,
1006*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION output_col)
1007*dfc6aa5cSAndroid Build Coastguard Worker {
1008*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support == ~0U)
1009*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
1010*dfc6aa5cSAndroid Build Coastguard Worker
1011*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_AVX2)
1012*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_islow_avx2(compptr->dct_table, coef_block, output_buf,
1013*dfc6aa5cSAndroid Build Coastguard Worker output_col);
1014*dfc6aa5cSAndroid Build Coastguard Worker else
1015*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_islow_sse2(compptr->dct_table, coef_block, output_buf,
1016*dfc6aa5cSAndroid Build Coastguard Worker output_col);
1017*dfc6aa5cSAndroid Build Coastguard Worker }
1018*dfc6aa5cSAndroid Build Coastguard Worker
1019*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_idct_ifast(j_decompress_ptr cinfo,jpeg_component_info * compptr,JCOEFPTR coef_block,JSAMPARRAY output_buf,JDIMENSION output_col)1020*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_ifast(j_decompress_ptr cinfo, jpeg_component_info *compptr,
1021*dfc6aa5cSAndroid Build Coastguard Worker JCOEFPTR coef_block, JSAMPARRAY output_buf,
1022*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION output_col)
1023*dfc6aa5cSAndroid Build Coastguard Worker {
1024*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_ifast_sse2(compptr->dct_table, coef_block, output_buf,
1025*dfc6aa5cSAndroid Build Coastguard Worker output_col);
1026*dfc6aa5cSAndroid Build Coastguard Worker }
1027*dfc6aa5cSAndroid Build Coastguard Worker
1028*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_idct_float(j_decompress_ptr cinfo,jpeg_component_info * compptr,JCOEFPTR coef_block,JSAMPARRAY output_buf,JDIMENSION output_col)1029*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_float(j_decompress_ptr cinfo, jpeg_component_info *compptr,
1030*dfc6aa5cSAndroid Build Coastguard Worker JCOEFPTR coef_block, JSAMPARRAY output_buf,
1031*dfc6aa5cSAndroid Build Coastguard Worker JDIMENSION output_col)
1032*dfc6aa5cSAndroid Build Coastguard Worker {
1033*dfc6aa5cSAndroid Build Coastguard Worker jsimd_idct_float_sse2(compptr->dct_table, coef_block, output_buf,
1034*dfc6aa5cSAndroid Build Coastguard Worker output_col);
1035*dfc6aa5cSAndroid Build Coastguard Worker }
1036*dfc6aa5cSAndroid Build Coastguard Worker
1037*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_huff_encode_one_block(void)1038*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_huff_encode_one_block(void)
1039*dfc6aa5cSAndroid Build Coastguard Worker {
1040*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
1041*dfc6aa5cSAndroid Build Coastguard Worker
1042*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
1043*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1044*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
1045*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1046*dfc6aa5cSAndroid Build Coastguard Worker
1047*dfc6aa5cSAndroid Build Coastguard Worker if ((simd_support & JSIMD_SSE2) && simd_huffman &&
1048*dfc6aa5cSAndroid Build Coastguard Worker IS_ALIGNED_SSE(jconst_huff_encode_one_block))
1049*dfc6aa5cSAndroid Build Coastguard Worker return 1;
1050*dfc6aa5cSAndroid Build Coastguard Worker
1051*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1052*dfc6aa5cSAndroid Build Coastguard Worker }
1053*dfc6aa5cSAndroid Build Coastguard Worker
1054*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(JOCTET *)
jsimd_huff_encode_one_block(void * state,JOCTET * buffer,JCOEFPTR block,int last_dc_val,c_derived_tbl * dctbl,c_derived_tbl * actbl)1055*dfc6aa5cSAndroid Build Coastguard Worker jsimd_huff_encode_one_block(void *state, JOCTET *buffer, JCOEFPTR block,
1056*dfc6aa5cSAndroid Build Coastguard Worker int last_dc_val, c_derived_tbl *dctbl,
1057*dfc6aa5cSAndroid Build Coastguard Worker c_derived_tbl *actbl)
1058*dfc6aa5cSAndroid Build Coastguard Worker {
1059*dfc6aa5cSAndroid Build Coastguard Worker return jsimd_huff_encode_one_block_sse2(state, buffer, block, last_dc_val,
1060*dfc6aa5cSAndroid Build Coastguard Worker dctbl, actbl);
1061*dfc6aa5cSAndroid Build Coastguard Worker }
1062*dfc6aa5cSAndroid Build Coastguard Worker
1063*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_encode_mcu_AC_first_prepare(void)1064*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_encode_mcu_AC_first_prepare(void)
1065*dfc6aa5cSAndroid Build Coastguard Worker {
1066*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
1067*dfc6aa5cSAndroid Build Coastguard Worker
1068*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
1069*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1070*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
1071*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1072*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
1073*dfc6aa5cSAndroid Build Coastguard Worker return 1;
1074*dfc6aa5cSAndroid Build Coastguard Worker
1075*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1076*dfc6aa5cSAndroid Build Coastguard Worker }
1077*dfc6aa5cSAndroid Build Coastguard Worker
1078*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(void)
jsimd_encode_mcu_AC_first_prepare(const JCOEF * block,const int * jpeg_natural_order_start,int Sl,int Al,UJCOEF * values,size_t * zerobits)1079*dfc6aa5cSAndroid Build Coastguard Worker jsimd_encode_mcu_AC_first_prepare(const JCOEF *block,
1080*dfc6aa5cSAndroid Build Coastguard Worker const int *jpeg_natural_order_start, int Sl,
1081*dfc6aa5cSAndroid Build Coastguard Worker int Al, UJCOEF *values, size_t *zerobits)
1082*dfc6aa5cSAndroid Build Coastguard Worker {
1083*dfc6aa5cSAndroid Build Coastguard Worker jsimd_encode_mcu_AC_first_prepare_sse2(block, jpeg_natural_order_start,
1084*dfc6aa5cSAndroid Build Coastguard Worker Sl, Al, values, zerobits);
1085*dfc6aa5cSAndroid Build Coastguard Worker }
1086*dfc6aa5cSAndroid Build Coastguard Worker
1087*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_can_encode_mcu_AC_refine_prepare(void)1088*dfc6aa5cSAndroid Build Coastguard Worker jsimd_can_encode_mcu_AC_refine_prepare(void)
1089*dfc6aa5cSAndroid Build Coastguard Worker {
1090*dfc6aa5cSAndroid Build Coastguard Worker init_simd();
1091*dfc6aa5cSAndroid Build Coastguard Worker
1092*dfc6aa5cSAndroid Build Coastguard Worker if (DCTSIZE != 8)
1093*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1094*dfc6aa5cSAndroid Build Coastguard Worker if (sizeof(JCOEF) != 2)
1095*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1096*dfc6aa5cSAndroid Build Coastguard Worker if (simd_support & JSIMD_SSE2)
1097*dfc6aa5cSAndroid Build Coastguard Worker return 1;
1098*dfc6aa5cSAndroid Build Coastguard Worker
1099*dfc6aa5cSAndroid Build Coastguard Worker return 0;
1100*dfc6aa5cSAndroid Build Coastguard Worker }
1101*dfc6aa5cSAndroid Build Coastguard Worker
1102*dfc6aa5cSAndroid Build Coastguard Worker GLOBAL(int)
jsimd_encode_mcu_AC_refine_prepare(const JCOEF * block,const int * jpeg_natural_order_start,int Sl,int Al,UJCOEF * absvalues,size_t * bits)1103*dfc6aa5cSAndroid Build Coastguard Worker jsimd_encode_mcu_AC_refine_prepare(const JCOEF *block,
1104*dfc6aa5cSAndroid Build Coastguard Worker const int *jpeg_natural_order_start, int Sl,
1105*dfc6aa5cSAndroid Build Coastguard Worker int Al, UJCOEF *absvalues, size_t *bits)
1106*dfc6aa5cSAndroid Build Coastguard Worker {
1107*dfc6aa5cSAndroid Build Coastguard Worker return jsimd_encode_mcu_AC_refine_prepare_sse2(block,
1108*dfc6aa5cSAndroid Build Coastguard Worker jpeg_natural_order_start,
1109*dfc6aa5cSAndroid Build Coastguard Worker Sl, Al, absvalues, bits);
1110*dfc6aa5cSAndroid Build Coastguard Worker }
1111