summaryrefslogtreecommitdiffstats
path: root/libswscale
diff options
context:
space:
mode:
authormru <mru@b3059339-0415-0410-9bf9-f77b7e298cf2>2010-05-07 21:59:18 +0000
committermru <mru@b3059339-0415-0410-9bf9-f77b7e298cf2>2010-05-07 21:59:18 +0000
commit668854c7dc587511add601df5e4fbc398b88db86 (patch)
treeefe7541862b8dcff4ebc78cff3ed6ba6579c5836 /libswscale
parent1292c8adc351b1bf461354cd632b39ec3303a8f2 (diff)
downloadmpv-668854c7dc587511add601df5e4fbc398b88db86.tar.bz2
mpv-668854c7dc587511add601df5e4fbc398b88db86.tar.xz
blackfin: fix yuv422 to yuv420 conversion
The old code is correct only when stride = 2*width. Patch by Ronaldo Moura <ronaldo d moura monity com br> git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@31142 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libswscale')
-rw-r--r--libswscale/bfin/internal_bfin.S17
1 files changed, 12 insertions, 5 deletions
diff --git a/libswscale/bfin/internal_bfin.S b/libswscale/bfin/internal_bfin.S
index 98f69ef53f..5af46540a8 100644
--- a/libswscale/bfin/internal_bfin.S
+++ b/libswscale/bfin/internal_bfin.S
@@ -479,9 +479,6 @@ DEFUN(uyvytoyv12, mL3, (const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8
r1 = [fp + ARG_srcStride];
r2 = r0 + r1;
- r1 += -8; // i0,i1 is pre read need to correct
- m0 = r1;
-
i0 = r0; // uyvy_T even
i1 = r2; // uyvy_B odd
@@ -494,6 +491,12 @@ DEFUN(uyvytoyv12, mL3, (const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8
p4 = p4 >> 1;
p5 = p5 >> 2;
+ r2 = r0 << 1;
+ r1 = r1 << 1;
+ r1 = r1 - r2; // srcStride + (srcStride - 2*width)
+ r1 += -8; // i0,i1 is pre read need to correct
+ m0 = r1;
+
r2 = [fp + ARG_chromStride];
r0 = r0 >> 1;
r2 = r2 - r0;
@@ -549,8 +552,6 @@ DEFUN(yuyvtoyv12, mL3, (const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8
r1 = [fp + ARG_srcStride];
r2 = r0 + r1;
- r1 += -8; // i0,i1 is pre read need to correct
- m0 = r1;
i0 = r0; // uyvy_T even
i1 = r2; // uyvy_B odd
@@ -564,6 +565,12 @@ DEFUN(yuyvtoyv12, mL3, (const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8
p4 = p4 >> 1;
p5 = p5 >> 2;
+ r2 = r0 << 1;
+ r1 = r1 << 1;
+ r1 = r1 - r2; // srcStride + (srcStride - 2*width)
+ r1 += -8; // i0,i1 is pre read need to correct
+ m0 = r1;
+
r2 = [fp + ARG_chromStride];
r0 = r0 >> 1;
r2 = r2 - r0;