42 int srcW =
desc->src->width;
43 int dstW =
desc->dst->width;
44 int xInc = instance->
xInc;
47 for (
i = 0;
i < sliceH; ++
i) {
48 uint8_t **
src =
desc->src->plane[0].line;
49 uint8_t ** dst =
desc->dst->plane[0].line;
50 int src_pos = sliceY+
i -
desc->src->plane[0].sliceY;
51 int dst_pos = sliceY+
i -
desc->dst->plane[0].sliceY;
54 if (
c->hyscale_fast) {
55 c->hyscale_fast(
c, (int16_t*)dst[dst_pos], dstW,
src[src_pos], srcW, xInc);
57 c->hyScale(
c, (int16_t*)dst[dst_pos], dstW, (
const uint8_t *)
src[src_pos], instance->
filter,
61 if (
c->lumConvertRange)
62 c->lumConvertRange((int16_t*)dst[dst_pos], dstW);
64 desc->dst->plane[0].sliceH += 1;
68 dst =
desc->dst->plane[3].line;
70 src_pos = sliceY+
i -
desc->src->plane[3].sliceY;
71 dst_pos = sliceY+
i -
desc->dst->plane[3].sliceY;
73 desc->dst->plane[3].sliceH += 1;
75 if (
c->hyscale_fast) {
76 c->hyscale_fast(
c, (int16_t*)dst[dst_pos], dstW,
src[src_pos], srcW, xInc);
78 c->hyScale(
c, (int16_t*)dst[dst_pos], dstW, (
const uint8_t *)
src[src_pos], instance->
filter,
89 int srcW =
desc->src->width;
91 uint32_t * pal = instance->
pal;
94 desc->dst->plane[0].sliceY = sliceY;
95 desc->dst->plane[0].sliceH = sliceH;
96 desc->dst->plane[3].sliceY = sliceY;
97 desc->dst->plane[3].sliceH = sliceH;
99 for (
i = 0;
i < sliceH; ++
i) {
100 int sp0 = sliceY+
i -
desc->src->plane[0].sliceY;
101 int sp1 = ((sliceY+
i) >>
desc->src->v_chr_sub_sample) -
desc->src->plane[1].sliceY;
102 const uint8_t *
src[4] = {
desc->src->plane[0].line[sp0],
103 desc->src->plane[1].line[sp1],
104 desc->src->plane[2].line[sp1],
105 desc->src->plane[3].line[sp0]};
106 uint8_t * dst =
desc->dst->plane[0].line[
i];
109 c->lumToYV12(dst,
src[0],
src[1],
src[2], srcW, pal,
c->input_opaque);
110 }
else if (
c->readLumPlanar) {
111 c->readLumPlanar(dst,
src, srcW,
c->input_rgb2yuv_table,
c->input_opaque);
116 dst =
desc->dst->plane[3].line[
i];
118 c->alpToYV12(dst,
src[3],
src[1],
src[2], srcW, pal,
c->input_opaque);
119 }
else if (
c->readAlpPlanar) {
120 c->readAlpPlanar(dst,
src, srcW,
NULL,
c->input_opaque);
172 int xInc = instance->
xInc;
174 uint8_t **
src1 =
desc->src->plane[1].line;
175 uint8_t ** dst1 =
desc->dst->plane[1].line;
176 uint8_t **
src2 =
desc->src->plane[2].line;
177 uint8_t ** dst2 =
desc->dst->plane[2].line;
179 int src_pos1 = sliceY -
desc->src->plane[1].sliceY;
180 int dst_pos1 = sliceY -
desc->dst->plane[1].sliceY;
182 int src_pos2 = sliceY -
desc->src->plane[2].sliceY;
183 int dst_pos2 = sliceY -
desc->dst->plane[2].sliceY;
186 for (
i = 0;
i < sliceH; ++
i) {
187 if (
c->hcscale_fast) {
188 c->hcscale_fast(
c, (uint16_t*)dst1[dst_pos1+
i], (uint16_t*)dst2[dst_pos2+
i], dstW,
src1[src_pos1+
i],
src2[src_pos2+
i], srcW, xInc);
194 if (
c->chrConvertRange)
195 c->chrConvertRange((uint16_t*)dst1[dst_pos1+
i], (uint16_t*)dst2[dst_pos2+
i], dstW);
197 desc->dst->plane[1].sliceH += 1;
198 desc->dst->plane[2].sliceH += 1;
207 uint32_t * pal = instance->
pal;
209 int sp0 = (sliceY - (
desc->src->plane[0].sliceY >>
desc->src->v_chr_sub_sample)) <<
desc->src->v_chr_sub_sample;
210 int sp1 = sliceY -
desc->src->plane[1].sliceY;
214 desc->dst->plane[1].sliceY = sliceY;
215 desc->dst->plane[1].sliceH = sliceH;
216 desc->dst->plane[2].sliceY = sliceY;
217 desc->dst->plane[2].sliceH = sliceH;
219 for (
i = 0;
i < sliceH; ++
i) {
220 const uint8_t *
src[4] = {
desc->src->plane[0].line[sp0+
i],
221 desc->src->plane[1].line[sp1+
i],
222 desc->src->plane[2].line[sp1+
i],
223 desc->src->plane[3].line[sp0+
i]};
225 uint8_t * dst1 =
desc->dst->plane[1].line[
i];
226 uint8_t * dst2 =
desc->dst->plane[2].line[
i];
228 c->chrToYV12(dst1, dst2,
src[0],
src[1],
src[2], srcW, pal,
c->input_opaque);
229 }
else if (
c->readChrPlanar) {
230 c->readChrPlanar(dst1, dst2,
src, srcW,
c->input_rgb2yuv_table,
c->input_opaque);
275 desc->dst->plane[1].sliceY = sliceY + sliceH -
desc->dst->plane[1].available_lines;
276 desc->dst->plane[1].sliceH =
desc->dst->plane[1].available_lines;
277 desc->dst->plane[2].sliceY = sliceY + sliceH -
desc->dst->plane[2].available_lines;
278 desc->dst->plane[2].sliceH =
desc->dst->plane[2].available_lines;