• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Loongson MMI optimizations for libjpeg-turbo
3  *
4  * Copyright (C) 2011, 2014, D. R. Commander.  All Rights Reserved.
5  * Copyright (C) 2016-2017, Loongson Technology Corporation Limited, BeiJing.
6  *                          All Rights Reserved.
7  * Authors:  ZhuChen     <zhuchen@loongson.cn>
8  *           CaiWanwei   <caiwanwei@loongson.cn>
9  *           SunZhangzhi <sunzhangzhi-cq@loongson.cn>
10  *
11  * This software is provided 'as-is', without any express or implied
12  * warranty.  In no event will the authors be held liable for any damages
13  * arising from the use of this software.
14  *
15  * Permission is granted to anyone to use this software for any purpose,
16  * including commercial applications, and to alter it and redistribute it
17  * freely, subject to the following restrictions:
18  *
19  * 1. The origin of this software must not be misrepresented; you must not
20  *    claim that you wrote the original software. If you use this software
21  *    in a product, an acknowledgment in the product documentation would be
22  *    appreciated but is not required.
23  * 2. Altered source versions must be plainly marked as such, and must not be
24  *    misrepresented as being the original software.
25  * 3. This notice may not be removed or altered from any source distribution.
26  */
27 
28 /* RGB --> YCC CONVERSION */
29 
30 #include "jsimd_mmi.h"
31 
32 
33 #define F_0_081  ((short)5329)                /* FIX(0.08131) */
34 #define F_0_114  ((short)7471)                /* FIX(0.11400) */
35 #define F_0_168  ((short)11059)               /* FIX(0.16874) */
36 #define F_0_250  ((short)16384)               /* FIX(0.25000) */
37 #define F_0_299  ((short)19595)               /* FIX(0.29900) */
38 #define F_0_331  ((short)21709)               /* FIX(0.33126) */
39 #define F_0_418  ((short)27439)               /* FIX(0.41869) */
40 #define F_0_587  ((short)38470)               /* FIX(0.58700) */
41 #define F_0_337  ((short)(F_0_587 - F_0_250)) /* FIX(0.58700) - FIX(0.25000) */
42 
43 enum const_index {
44   index_PD_ONEHALF,
45   index_PW_F0299_F0337,
46   index_PW_F0114_F0250,
47   index_PW_MF016_MF033,
48   index_PW_MF008_MF041,
49   index_PD_ONEHALFM1_CJ
50 };
51 
52 static uint64_t const_value[] = {
53   _uint64_set_pi32((int)(1 << (SCALEBITS - 1)), (int)(1 << (SCALEBITS - 1))),
54   _uint64_set_pi16(F_0_337, F_0_299, F_0_337, F_0_299),
55   _uint64_set_pi16(F_0_250, F_0_114, F_0_250, F_0_114),
56   _uint64_set_pi16(-F_0_331, -F_0_168, -F_0_331, -F_0_168),
57   _uint64_set_pi16(-F_0_418, -F_0_081, -F_0_418, -F_0_081),
58   _uint64_set_pi32(((1 << (SCALEBITS - 1)) - 1 + (CENTERJSAMPLE << SCALEBITS)),
59                    ((1 << (SCALEBITS - 1)) - 1 + (CENTERJSAMPLE << SCALEBITS)))
60 };
61 
62 #define get_const_value(index)  (*(__m64 *)&const_value[index])
63 
64 #define PD_ONEHALF       get_const_value(index_PD_ONEHALF)
65 #define PW_F0299_F0337   get_const_value(index_PW_F0299_F0337)
66 #define PW_F0114_F0250   get_const_value(index_PW_F0114_F0250)
67 #define PW_MF016_MF033   get_const_value(index_PW_MF016_MF033)
68 #define PW_MF008_MF041   get_const_value(index_PW_MF008_MF041)
69 #define PD_ONEHALFM1_CJ  get_const_value(index_PD_ONEHALFM1_CJ)
70 
71 
72 #include "jccolext-mmi.c"
73 #undef RGB_RED
74 #undef RGB_GREEN
75 #undef RGB_BLUE
76 #undef RGB_PIXELSIZE
77 
78 #define RGB_RED  EXT_RGB_RED
79 #define RGB_GREEN  EXT_RGB_GREEN
80 #define RGB_BLUE  EXT_RGB_BLUE
81 #define RGB_PIXELSIZE  EXT_RGB_PIXELSIZE
82 #define jsimd_rgb_ycc_convert_mmi  jsimd_extrgb_ycc_convert_mmi
83 #include "jccolext-mmi.c"
84 #undef RGB_RED
85 #undef RGB_GREEN
86 #undef RGB_BLUE
87 #undef RGB_PIXELSIZE
88 #undef jsimd_rgb_ycc_convert_mmi
89 
90 #define RGB_RED  EXT_RGBX_RED
91 #define RGB_GREEN  EXT_RGBX_GREEN
92 #define RGB_BLUE  EXT_RGBX_BLUE
93 #define RGB_PIXELSIZE  EXT_RGBX_PIXELSIZE
94 #define jsimd_rgb_ycc_convert_mmi  jsimd_extrgbx_ycc_convert_mmi
95 #include "jccolext-mmi.c"
96 #undef RGB_RED
97 #undef RGB_GREEN
98 #undef RGB_BLUE
99 #undef RGB_PIXELSIZE
100 #undef jsimd_rgb_ycc_convert_mmi
101 
102 #define RGB_RED  EXT_BGR_RED
103 #define RGB_GREEN  EXT_BGR_GREEN
104 #define RGB_BLUE  EXT_BGR_BLUE
105 #define RGB_PIXELSIZE  EXT_BGR_PIXELSIZE
106 #define jsimd_rgb_ycc_convert_mmi  jsimd_extbgr_ycc_convert_mmi
107 #include "jccolext-mmi.c"
108 #undef RGB_RED
109 #undef RGB_GREEN
110 #undef RGB_BLUE
111 #undef RGB_PIXELSIZE
112 #undef jsimd_rgb_ycc_convert_mmi
113 
114 #define RGB_RED  EXT_BGRX_RED
115 #define RGB_GREEN  EXT_BGRX_GREEN
116 #define RGB_BLUE  EXT_BGRX_BLUE
117 #define RGB_PIXELSIZE  EXT_BGRX_PIXELSIZE
118 #define jsimd_rgb_ycc_convert_mmi  jsimd_extbgrx_ycc_convert_mmi
119 #include "jccolext-mmi.c"
120 #undef RGB_RED
121 #undef RGB_GREEN
122 #undef RGB_BLUE
123 #undef RGB_PIXELSIZE
124 #undef jsimd_rgb_ycc_convert_mmi
125 
126 #define RGB_RED  EXT_XBGR_RED
127 #define RGB_GREEN  EXT_XBGR_GREEN
128 #define RGB_BLUE  EXT_XBGR_BLUE
129 #define RGB_PIXELSIZE  EXT_XBGR_PIXELSIZE
130 #define jsimd_rgb_ycc_convert_mmi  jsimd_extxbgr_ycc_convert_mmi
131 #include "jccolext-mmi.c"
132 #undef RGB_RED
133 #undef RGB_GREEN
134 #undef RGB_BLUE
135 #undef RGB_PIXELSIZE
136 #undef jsimd_rgb_ycc_convert_mmi
137 
138 #define RGB_RED  EXT_XRGB_RED
139 #define RGB_GREEN  EXT_XRGB_GREEN
140 #define RGB_BLUE  EXT_XRGB_BLUE
141 #define RGB_PIXELSIZE  EXT_XRGB_PIXELSIZE
142 #define jsimd_rgb_ycc_convert_mmi  jsimd_extxrgb_ycc_convert_mmi
143 #include "jccolext-mmi.c"
144 #undef RGB_RED
145 #undef RGB_GREEN
146 #undef RGB_BLUE
147 #undef RGB_PIXELSIZE
148 #undef jsimd_rgb_ycc_convert_mmi
149