diff options
author | mru <mru@b3059339-0415-0410-9bf9-f77b7e298cf2> | 2010-05-07 21:59:18 +0000 |
---|---|---|
committer | mru <mru@b3059339-0415-0410-9bf9-f77b7e298cf2> | 2010-05-07 21:59:18 +0000 |
commit | 668854c7dc587511add601df5e4fbc398b88db86 (patch) | |
tree | efe7541862b8dcff4ebc78cff3ed6ba6579c5836 /libswscale | |
parent | 1292c8adc351b1bf461354cd632b39ec3303a8f2 (diff) | |
download | mpv-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.S | 17 |
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; |