move around - flatter.
[profile/ivi/evas.git] / src / lib / engines / common / evas_op_blend / op_blend_pixel_i386.c
1
2 /* blend pixel --> dst */
3
4 #ifdef BUILD_MMX
5 static void
6 _op_blend_p_dp_mmx(DATA32 *s, DATA8 *m, DATA32 c, DATA32 *d, int l) {
7    DATA32 *e = d + l;
8    pxor_r2r(mm0, mm0);
9    MOV_A2R(ALPHA_256, mm6)
10    while (d < e)
11      {
12         MOV_P2R(*s, mm2, mm0)
13         MOV_RA2R(mm2, mm1)
14         movq_r2r(mm6, mm3);
15         psubw_r2r(mm1, mm3);
16
17         MOV_P2R(*d, mm1, mm0)
18         MUL4_256_R2R(mm3, mm1)
19
20         paddw_r2r(mm2, mm1);
21         MOV_R2P(mm1, *d, mm0)
22         s++;  d++;
23      }
24 }
25
26 static void
27 _op_blend_pas_dp_mmx(DATA32 *s, DATA8 *m, DATA32 c, DATA32 *d, int l) {
28    DATA32 *e = d + l;
29    pxor_r2r(mm0, mm0);
30    MOV_A2R(ALPHA_256, mm6)
31    while (d < e)
32      {
33         switch (*s & 0xff000000)
34           {
35             case 0:
36               break;
37             case 0xff000000:
38                 *d = *s;
39               break;
40             default :
41                 MOV_P2R(*s, mm2, mm0)
42                 MOV_RA2R(mm2, mm1)
43                 movq_r2r(mm6, mm3);
44                 psubw_r2r(mm1, mm3);
45
46                 MOV_P2R(*d, mm1, mm0)
47                 MUL4_256_R2R(mm3, mm1)
48
49                 paddw_r2r(mm2, mm1);
50                 MOV_R2P(mm1, *d, mm0)
51               break;
52           }
53         s++;  d++;
54      }
55 }
56
57 #define _op_blend_pan_dp_mmx NULL
58
59 #define _op_blend_p_dpan_mmx _op_blend_p_dp_mmx
60 #define _op_blend_pas_dpan_mmx _op_blend_pas_dp_mmx
61 #define _op_blend_pan_dpan_mmx _op_blend_pan_dp_mmx
62
63 static void
64 init_blend_pixel_span_funcs_mmx(void)
65 {
66    op_blend_span_funcs[SP][SM_N][SC_N][DP][CPU_MMX] = _op_blend_p_dp_mmx;
67    op_blend_span_funcs[SP_AS][SM_N][SC_N][DP][CPU_MMX] = _op_blend_pas_dp_mmx;
68    op_blend_span_funcs[SP_AN][SM_N][SC_N][DP][CPU_MMX] = _op_blend_pan_dp_mmx;
69
70    op_blend_span_funcs[SP][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_p_dpan_mmx;
71    op_blend_span_funcs[SP_AS][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_pas_dpan_mmx;
72    op_blend_span_funcs[SP_AN][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_pan_dpan_mmx;
73 }
74 #endif
75
76 #ifdef BUILD_MMX
77 static void
78 _op_blend_pt_p_dp_mmx(DATA32 s, DATA8 m, DATA32 c, DATA32 *d) {
79         pxor_r2r(mm0, mm0);
80         MOV_A2R(ALPHA_256, mm6)
81         MOV_P2R(s, mm2, mm0)
82         MOV_RA2R(mm2, mm1)
83         movq_r2r(mm6, mm3);
84         psubw_r2r(mm1, mm3);
85
86         MOV_P2R(*d, mm1, mm0)
87         MUL4_256_R2R(mm3, mm1)
88
89         paddw_r2r(mm2, mm1);
90         MOV_R2P(mm1, *d, mm0)
91 }
92
93
94 #define _op_blend_pt_pan_dp_mmx NULL
95 #define _op_blend_pt_pas_dp_mmx _op_blend_pt_p_dp_mmx
96
97 #define _op_blend_pt_p_dpan_mmx _op_blend_pt_p_dp_mmx
98 #define _op_blend_pt_pan_dpan_mmx _op_blend_pt_pan_dp_mmx
99 #define _op_blend_pt_pas_dpan_mmx _op_blend_pt_pas_dp_mmx
100
101 static void
102 init_blend_pixel_pt_funcs_mmx(void)
103 {
104    op_blend_pt_funcs[SP][SM_N][SC_N][DP][CPU_MMX] = _op_blend_pt_p_dp_mmx;
105    op_blend_pt_funcs[SP_AS][SM_N][SC_N][DP][CPU_MMX] = _op_blend_pt_pas_dp_mmx;
106    op_blend_pt_funcs[SP_AN][SM_N][SC_N][DP][CPU_MMX] = _op_blend_pt_pan_dp_mmx;
107
108    op_blend_pt_funcs[SP][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_pt_p_dpan_mmx;
109    op_blend_pt_funcs[SP_AS][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_pt_pas_dpan_mmx;
110    op_blend_pt_funcs[SP_AN][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_pt_pan_dpan_mmx;
111 }
112 #endif
113
114 /*-----*/
115
116 /* blend_rel pixel -> dst */
117
118 #ifdef BUILD_MMX
119 static void
120 _op_blend_rel_p_dp_mmx(DATA32 *s, DATA8 *m, DATA32 c, DATA32 *d, int l) {
121    DATA32 *e = d + l;
122    pxor_r2r(mm0, mm0);
123    MOV_A2R(ALPHA_256, mm6)
124    MOV_A2R(ALPHA_255, mm5)
125    while (d < e)
126      {
127         MOV_P2R(*s, mm2, mm0)
128         MOV_RA2R(mm2, mm1)
129         movq_r2r(mm6, mm3);
130         psubw_r2r(mm1, mm3);
131
132         MOV_P2R(*d, mm1, mm0)
133         MOV_RA2R(mm1, mm4)
134         MUL4_256_R2R(mm3, mm1)
135
136         MUL4_SYM_R2R(mm4, mm2, mm5)
137         paddw_r2r(mm2, mm1);
138         MOV_R2P(mm1, *d, mm0)
139         s++;  d++;
140      }
141 }
142
143 static void
144 _op_blend_rel_pan_dp_mmx(DATA32 *s, DATA8 *m, DATA32 c, DATA32 *d, int l) {
145    DATA32 *e = d + l;
146    pxor_r2r(mm0, mm0);
147    MOV_A2R(ALPHA_256, mm6)
148    MOV_A2R(ALPHA_255, mm5)
149    while (d < e)
150      {
151         MOV_P2R(*s, mm2, mm0)
152         MOV_PA2R(*d, mm1)
153         MUL4_SYM_R2R(mm2, mm1, mm5)
154         MOV_R2P(mm1, *d, mm0)
155         s++;  d++;
156      }
157 }
158
159 #define _op_blend_rel_pas_dp_mmx _op_blend_rel_p_dp_mmx
160
161 #define _op_blend_rel_p_dpan_mmx _op_blend_p_dpan_mmx
162 #define _op_blend_rel_pan_dpan_mmx _op_blend_pan_dpan_mmx
163 #define _op_blend_rel_pas_dpan_mmx _op_blend_pas_dpan_mmx
164
165 static void
166 init_blend_rel_pixel_span_funcs_mmx(void)
167 {
168    op_blend_rel_span_funcs[SP][SM_N][SC_N][DP][CPU_MMX] = _op_blend_rel_p_dp_mmx;
169    op_blend_rel_span_funcs[SP_AS][SM_N][SC_N][DP][CPU_MMX] = _op_blend_rel_pas_dp_mmx;
170    op_blend_rel_span_funcs[SP_AN][SM_N][SC_N][DP][CPU_MMX] = _op_blend_rel_pan_dp_mmx;
171
172    op_blend_rel_span_funcs[SP][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_rel_p_dpan_mmx;
173    op_blend_rel_span_funcs[SP_AS][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_rel_pas_dpan_mmx;
174    op_blend_rel_span_funcs[SP_AN][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_rel_pan_dpan_mmx;
175 }
176 #endif
177
178 #ifdef BUILD_MMX
179 static void
180 _op_blend_rel_pt_p_dp_mmx(DATA32 s, DATA8 m, DATA32 c, DATA32 *d) {
181         pxor_r2r(mm0, mm0);
182         MOV_A2R(ALPHA_256, mm6)
183         MOV_A2R(ALPHA_255, mm5)
184
185         MOV_P2R(s, mm2, mm0)
186         MOV_RA2R(mm2, mm1)
187         psubw_r2r(mm1, mm6);
188
189         MOV_P2R(*d, mm1, mm0)
190         MOV_RA2R(mm1, mm4)
191         MUL4_256_R2R(mm6, mm1)
192
193         MUL4_SYM_R2R(mm4, mm2, mm5)
194         paddw_r2r(mm2, mm1);
195         MOV_R2P(mm1, *d, mm0)
196 }
197
198 #define _op_blend_rel_pt_pas_dp_mmx _op_blend_rel_pt_p_dp_mmx
199 #define _op_blend_rel_pt_pan_dp_mmx _op_blend_rel_pt_p_dp_mmx
200
201 #define _op_blend_rel_pt_p_dpan_mmx _op_blend_pt_p_dpan_mmx
202 #define _op_blend_rel_pt_pas_dpan_mmx _op_blend_pt_pas_dpan_mmx
203 #define _op_blend_rel_pt_pan_dpan_mmx _op_blend_pt_pan_dpan_mmx
204
205 static void
206 init_blend_rel_pixel_pt_funcs_mmx(void)
207 {
208    op_blend_rel_pt_funcs[SP][SM_N][SC_N][DP][CPU_MMX] = _op_blend_rel_pt_p_dp_mmx;
209    op_blend_rel_pt_funcs[SP_AS][SM_N][SC_N][DP][CPU_MMX] = _op_blend_rel_pt_pas_dp_mmx;
210    op_blend_rel_pt_funcs[SP_AN][SM_N][SC_N][DP][CPU_MMX] = _op_blend_rel_pt_pan_dp_mmx;
211
212    op_blend_rel_pt_funcs[SP][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_rel_pt_p_dpan_mmx;
213    op_blend_rel_pt_funcs[SP_AS][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_rel_pt_pas_dpan_mmx;
214    op_blend_rel_pt_funcs[SP_AN][SM_N][SC_N][DP_AN][CPU_MMX] = _op_blend_rel_pt_pan_dpan_mmx;
215 }
216 #endif