35 static int yv12toyuy2_unscaled_altivec(
SwsInternal *
c,
const uint8_t *
const src[],
36 const int srcStride[],
int srcSliceY,
37 int srcSliceH, uint8_t *
const dstParam[],
38 const int dstStride_a[])
40 uint8_t *
dst = dstParam[0] + dstStride_a[0] * srcSliceY;
43 const uint8_t *ysrc =
src[0];
44 const uint8_t *usrc =
src[1];
45 const uint8_t *vsrc =
src[2];
46 const int width =
c->opts.src_w;
47 const int height = srcSliceH;
48 const int lumStride = srcStride[0];
49 const int chromStride = srcStride[1];
50 const int dstStride = dstStride_a[0];
51 const vector
unsigned char yperm = vec_lvsl(0, ysrc);
52 const int vertLumPerChroma = 2;
53 register unsigned int y;
63 for (y = 0; y <
height; y++) {
65 for (
i = 0;
i <
width - 31;
i += 32) {
66 const unsigned int j =
i >> 1;
67 vector
unsigned char v_yA = vec_ld(
i, ysrc);
68 vector
unsigned char v_yB = vec_ld(
i + 16, ysrc);
69 vector
unsigned char v_yC = vec_ld(
i + 32, ysrc);
70 vector
unsigned char v_y1 = vec_perm(v_yA, v_yB, yperm);
71 vector
unsigned char v_y2 = vec_perm(v_yB, v_yC, yperm);
72 vector
unsigned char v_uA = vec_ld(j, usrc);
73 vector
unsigned char v_uB = vec_ld(j + 16, usrc);
74 vector
unsigned char v_u = vec_perm(v_uA, v_uB, vec_lvsl(j, usrc));
75 vector
unsigned char v_vA = vec_ld(j, vsrc);
76 vector
unsigned char v_vB = vec_ld(j + 16, vsrc);
77 vector
unsigned char v_v = vec_perm(v_vA, v_vB, vec_lvsl(j, vsrc));
78 vector
unsigned char v_uv_a = vec_mergeh(v_u, v_v);
79 vector
unsigned char v_uv_b = vec_mergel(v_u, v_v);
80 vector
unsigned char v_yuy2_0 = vec_mergeh(v_y1, v_uv_a);
81 vector
unsigned char v_yuy2_1 = vec_mergel(v_y1, v_uv_a);
82 vector
unsigned char v_yuy2_2 = vec_mergeh(v_y2, v_uv_b);
83 vector
unsigned char v_yuy2_3 = vec_mergel(v_y2, v_uv_b);
84 vec_st(v_yuy2_0, (
i << 1),
dst);
85 vec_st(v_yuy2_1, (
i << 1) + 16,
dst);
86 vec_st(v_yuy2_2, (
i << 1) + 32,
dst);
87 vec_st(v_yuy2_3, (
i << 1) + 48,
dst);
90 const unsigned int j =
i >> 1;
91 vector
unsigned char v_y1 = vec_ld(
i, ysrc);
92 vector
unsigned char v_u = vec_ld(j, usrc);
93 vector
unsigned char v_v = vec_ld(j, vsrc);
94 vector
unsigned char v_uv_a = vec_mergeh(v_u, v_v);
95 vector
unsigned char v_yuy2_0 = vec_mergeh(v_y1, v_uv_a);
96 vector
unsigned char v_yuy2_1 = vec_mergel(v_y1, v_uv_a);
97 vec_st(v_yuy2_0, (
i << 1),
dst);
98 vec_st(v_yuy2_1, (
i << 1) + 16,
dst);
100 if ((y & (vertLumPerChroma - 1)) == vertLumPerChroma - 1) {
111 static int yv12touyvy_unscaled_altivec(
SwsInternal *
c,
const uint8_t *
const src[],
112 const int srcStride[],
int srcSliceY,
113 int srcSliceH, uint8_t *
const dstParam[],
114 const int dstStride_a[])
116 uint8_t *
dst = dstParam[0] + dstStride_a[0] * srcSliceY;
119 const uint8_t *ysrc =
src[0];
120 const uint8_t *usrc =
src[1];
121 const uint8_t *vsrc =
src[2];
122 const int width =
c->opts.src_w;
123 const int height = srcSliceH;
124 const int lumStride = srcStride[0];
125 const int chromStride = srcStride[1];
126 const int dstStride = dstStride_a[0];
127 const int vertLumPerChroma = 2;
128 const vector
unsigned char yperm = vec_lvsl(0, ysrc);
129 register unsigned int y;
139 for (y = 0; y <
height; y++) {
141 for (
i = 0;
i <
width - 31;
i += 32) {
142 const unsigned int j =
i >> 1;
143 vector
unsigned char v_yA = vec_ld(
i, ysrc);
144 vector
unsigned char v_yB = vec_ld(
i + 16, ysrc);
145 vector
unsigned char v_yC = vec_ld(
i + 32, ysrc);
146 vector
unsigned char v_y1 = vec_perm(v_yA, v_yB, yperm);
147 vector
unsigned char v_y2 = vec_perm(v_yB, v_yC, yperm);
148 vector
unsigned char v_uA = vec_ld(j, usrc);
149 vector
unsigned char v_uB = vec_ld(j + 16, usrc);
150 vector
unsigned char v_u = vec_perm(v_uA, v_uB, vec_lvsl(j, usrc));
151 vector
unsigned char v_vA = vec_ld(j, vsrc);
152 vector
unsigned char v_vB = vec_ld(j + 16, vsrc);
153 vector
unsigned char v_v = vec_perm(v_vA, v_vB, vec_lvsl(j, vsrc));
154 vector
unsigned char v_uv_a = vec_mergeh(v_u, v_v);
155 vector
unsigned char v_uv_b = vec_mergel(v_u, v_v);
156 vector
unsigned char v_uyvy_0 = vec_mergeh(v_uv_a, v_y1);
157 vector
unsigned char v_uyvy_1 = vec_mergel(v_uv_a, v_y1);
158 vector
unsigned char v_uyvy_2 = vec_mergeh(v_uv_b, v_y2);
159 vector
unsigned char v_uyvy_3 = vec_mergel(v_uv_b, v_y2);
160 vec_st(v_uyvy_0, (
i << 1),
dst);
161 vec_st(v_uyvy_1, (
i << 1) + 16,
dst);
162 vec_st(v_uyvy_2, (
i << 1) + 32,
dst);
163 vec_st(v_uyvy_3, (
i << 1) + 48,
dst);
166 const unsigned int j =
i >> 1;
167 vector
unsigned char v_y1 = vec_ld(
i, ysrc);
168 vector
unsigned char v_u = vec_ld(j, usrc);
169 vector
unsigned char v_v = vec_ld(j, vsrc);
170 vector
unsigned char v_uv_a = vec_mergeh(v_u, v_v);
171 vector
unsigned char v_uyvy_0 = vec_mergeh(v_uv_a, v_y1);
172 vector
unsigned char v_uyvy_1 = vec_mergel(v_uv_a, v_y1);
173 vec_st(v_uyvy_0, (
i << 1),
dst);
174 vec_st(v_uyvy_1, (
i << 1) + 16,
dst);
176 if ((y & (vertLumPerChroma - 1)) == vertLumPerChroma - 1) {
200 c->convert_unscaled = yv12toyuy2_unscaled_altivec;
202 c->convert_unscaled = yv12touyvy_unscaled_altivec;