annotate Gui/wm/wsconv.c @ 2739:f365024806c0

mmx2 bgr24 stuff from swscale (slightly faster)
author michael
date Tue, 06 Nov 2001 14:43:19 +0000
parents 4dddb055d2cd
children b52d3e6ff4ab
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
1
2082
016f6d583733 missing newlines fixed
arpi
parents: 1693
diff changeset
2 #include <stdio.h>
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
3 #include <stdlib.h>
2082
016f6d583733 missing newlines fixed
arpi
parents: 1693
diff changeset
4 #include <string.h>
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
5
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
6 #include "../../config.h"
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
7 #ifdef xHAVE_MMX
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
8 #include "../../main/libvo/mmx.h"
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
9 #include "../../main/libvo/fastmemcpy.h"
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
10 #endif
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
11 #include "wsconv.h"
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
12
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
13 wsTConvFunc wsConvFunc = NULL;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
14
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
15 // ---
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
16
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
17 #define COPY_RGB_24(src,dst) dst[0]=src[0];dst[1]=src[1];dst[2]=src[2]
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
18
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
19 #define SWAP_RGB_24(src,dst) dst[1]=src[0];dst[1]=src[1];dst[2]=src[0]
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
20
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
21 void BGR8880_to_RGB555_c( unsigned char * in_pixels, unsigned char * out_pixels, int num_pixels)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
22 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
23 unsigned short pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
24 int i;
2733
4dddb055d2cd add prostproc/rgb2rgb
pontscho
parents: 2082
diff changeset
25 for(i = 0; i < num_pixels / 4; i++)
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
26 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
27 PACK_RGB15(in_pixels[0],in_pixels[1],in_pixels[2],pixel);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
28 *(unsigned short*)out_pixels = pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
29 in_pixels += 4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
30 out_pixels += 2;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
31 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
32 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
33
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
34 void BGR8880_to_BGR555_c( unsigned char * in_pixels, unsigned char * out_pixels, int num_pixels)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
35 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
36 unsigned short pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
37 int i;
2733
4dddb055d2cd add prostproc/rgb2rgb
pontscho
parents: 2082
diff changeset
38 for(i = 0; i < num_pixels / 4; i++)
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
39 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
40 PACK_RGB15(in_pixels[2],in_pixels[1],in_pixels[0],pixel);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
41 *(unsigned short*)out_pixels = pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
42 in_pixels += 4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
43 out_pixels += 2;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
44 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
45 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
46
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
47 void BGR8880_to_RGB565_c( unsigned char * in_pixels, unsigned char * out_pixels, int num_pixels)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
48 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
49 unsigned short pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
50 int i;
2733
4dddb055d2cd add prostproc/rgb2rgb
pontscho
parents: 2082
diff changeset
51 for(i = 0; i < num_pixels / 4; i++)
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
52 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
53 PACK_RGB16(in_pixels[0],in_pixels[1],in_pixels[2],pixel);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
54 *(unsigned short*)out_pixels = pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
55 in_pixels += 4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
56 out_pixels += 2;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
57 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
58 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
59
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
60 void BGR8880_to_BGR565_c( unsigned char * in_pixels, unsigned char * out_pixels, int num_pixels)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
61 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
62 unsigned short pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
63 int i;
2733
4dddb055d2cd add prostproc/rgb2rgb
pontscho
parents: 2082
diff changeset
64 for(i = 0; i < num_pixels / 4; i++)
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
65 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
66 PACK_RGB16(in_pixels[2],in_pixels[1],in_pixels[0],pixel);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
67 *(unsigned short*)out_pixels = pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
68 in_pixels += 4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
69 out_pixels += 2;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
70 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
71 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
72
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
73 void BGR8880_to_RGB888_c( unsigned char * in_pixels, unsigned char * out_pixels,int num_pixels )
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
74 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
75 int i;
2733
4dddb055d2cd add prostproc/rgb2rgb
pontscho
parents: 2082
diff changeset
76 for(i = 0; i < num_pixels / 4; i++)
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
77 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
78 COPY_RGB_24(in_pixels,out_pixels);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
79 in_pixels += 4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
80 out_pixels += 3;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
81 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
82 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
83
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
84 void BGR8880_to_BGR888_c( unsigned char * in_pixels, unsigned char * out_pixels,int num_pixels )
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
85 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
86 int i;
2733
4dddb055d2cd add prostproc/rgb2rgb
pontscho
parents: 2082
diff changeset
87 for(i = 0; i < num_pixels / 4; i++)
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
88 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
89 SWAP_RGB_24(in_pixels,out_pixels);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
90 in_pixels += 4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
91 out_pixels += 3;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
92 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
93 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
94
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
95 void BGR8880_to_BGR8880_c( unsigned char * in_pixels, unsigned char * out_pixels,int num_pixels )
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
96 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
97 int i;
2733
4dddb055d2cd add prostproc/rgb2rgb
pontscho
parents: 2082
diff changeset
98 for(i = 0; i < num_pixels / 4; i++)
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
99 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
100 SWAP_RGB_24(in_pixels,out_pixels);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
101 in_pixels += 4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
102 out_pixels += 4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
103 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
104 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
105
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
106 void BGR8880_to_RGB8880_c( unsigned char * in_pixels, unsigned char * out_pixels,int num_pixels )
2733
4dddb055d2cd add prostproc/rgb2rgb
pontscho
parents: 2082
diff changeset
107 { memcpy( out_pixels,in_pixels,num_pixels ); }
1693
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
108
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
109 /*
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
110
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
111 unsigned char * map_5_to_8[32];
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
112 unsigned char * map_6_to_8[64];
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
113
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
114 #define POINTER_TO_GUINT16(a) *((unsigned short*)a)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
115 #define RGB16_TO_R(pixel) map_5_to_8[pixel & RGB16_LOWER_MASK]
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
116 #define RGB16_TO_G(pixel) map_6_to_8[(pixel & RGB16_MIDDLE_MASK)>>5]
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
117 #define RGB16_TO_B(pixel) map_5_to_8[(pixel & RGB16_UPPER_MASK)>>11]
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
118 #define RGB16_LOWER_MASK 0x001f
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
119 #define RGB16_MIDDLE_MASK 0x07e0
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
120 #define RGB16_UPPER_MASK 0xf800
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
121
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
122 void RGB565_to_RGB888_c( unsigned char * in_pixels, unsigned char * out_pixels,int num_pixels)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
123 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
124 unsigned short in_pixel;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
125 int i;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
126 for(i = 0; i < num_pixels; i++)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
127 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
128 in_pixel = POINTER_TO_GUINT16(in_pixels);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
129 out_pixels[0] = RGB16_TO_R(in_pixel);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
130 out_pixels[1] = RGB16_TO_G(in_pixel);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
131 out_pixels[2] = RGB16_TO_B(in_pixel);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
132 in_pixels += 2;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
133 out_pixels += 3;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
134 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
135 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
136
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
137 */
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
138
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
139 // ---
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
140
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
141 #ifdef xHAVE_MMX
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
142
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
143 #define LOAD_32(in) movq_m2r(*in, mm0); in += 8;\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
144 movq_m2r(*in, mm1); in += 8
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
145
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
146 #define PACK_32_TO_24 movq_r2r(mm0, mm2);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
147 pand_m2r(rgb32_l_mask,mm0);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
148 pand_m2r(rgb32_u_mask,mm2);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
149 psrlq_i2r(8, mm2);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
150 por_r2r(mm2,mm0);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
151 movq_r2r(mm1, mm2);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
152 pand_m2r(rgb32_l_mask,mm1);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
153 pand_m2r(rgb32_u_mask,mm2);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
154 psrlq_i2r(8, mm2);\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
155 por_r2r(mm2,mm1);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
156
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
157 #define WRITE_24(out) movq_r2m(mm0, *out); out+=6;\
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
158 movq_r2m(mm1, *out); out+=6;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
159
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
160 #define WRITE_16(out) movq_r2m(mm0, *out); out+=8;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
161
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
162 static mmx_t rgb32_l_mask; // Mask for the lower of 2 RGB24 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
163 static mmx_t rgb32_u_mask; // Mask for the upper of 2 RGB24 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
164
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
165 static mmx_t rgb32_r_mask; // Mask for the reds of 2 RGB32 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
166 static mmx_t rgb32_g_mask; // Mask for the greens of 2 RGB32 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
167 static mmx_t rgb32_b_mask; // Mask for the blues of 2 RGB32 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
168
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
169 static mmx_t lower_dword_mask; // Mask for the lower doublewords
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
170 static mmx_t upper_dword_mask; // Mask for the upper doublewords
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
171
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
172 void BGR8880_to_RGB888_mmx(unsigned char * in_pixels,unsigned char * out_pixels,int num_pixels)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
173 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
174 int imax = num_pixels/4;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
175 int i;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
176
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
177 for(i = 0; i < imax; i++)
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
178 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
179 LOAD_32(in_pixels);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
180 PACK_32_TO_24;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
181 WRITE_24(out_pixels);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
182 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
183 emms();
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
184 }
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
185
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
186 #endif
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
187
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
188 // ---
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
189
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
190 void initConverter( void )
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
191 {
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
192 #ifdef xHAVE_MMX
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
193 // int i;
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
194
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
195 // for(i = 0; i < 64; i++) map_6_to_8[i] = (unsigned char)((float)i/63.0*255.0+0.5);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
196 // for(i = 0; i < 32; i++) map_5_to_8[i] = (unsigned char)((float)i/31.0*255.0+0.5);
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
197
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
198 rgb32_l_mask.q = 0x0000000000FFFFFFLL; // Mask for the lower of 2 RGB32 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
199 rgb32_u_mask.q = 0x00FFFFFF00000000LL; // Mask for the upper of 2 RGB32 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
200
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
201 rgb32_r_mask.q = 0x000000FF000000FFLL; // Mask for the reds of 2 RGB32 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
202 rgb32_g_mask.q = 0x0000FF000000FF00LL; // Mask for the greens of 2 RGB32 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
203 rgb32_b_mask.q = 0x00FF000000FF0000LL; // Mask for the blues of 2 RGB32 pixels
d237c5d4b216 GUI version n-1
arpi
parents:
diff changeset
204 #endif
2082
016f6d583733 missing newlines fixed
arpi
parents: 1693
diff changeset
205 }
016f6d583733 missing newlines fixed
arpi
parents: 1693
diff changeset
206