Commit 7d7f78b5 authored by Michael Niedermayer's avatar Michael Niedermayer

green line fix for dstw%8!=0

Originally committed as revision 2681 to svn://svn.mplayerhq.hu/mplayer/trunk/postproc
parent 56993147
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include "swscale.h" #include "swscale.h"
#include "../mmx_defs.h" #include "../mmx_defs.h"
#undef MOVNTQ #undef MOVNTQ
#undef PAVGB
//#undef HAVE_MMX2 //#undef HAVE_MMX2
//#undef HAVE_MMX //#undef HAVE_MMX
...@@ -1399,10 +1400,15 @@ static int old_dstw= -1; ...@@ -1399,10 +1400,15 @@ static int old_dstw= -1;
static int old_s_xinc= -1; static int old_s_xinc= -1;
#endif #endif
int srcWidth= (dstw*s_xinc + 0x8000)>>16; int srcWidth;
int dstUVw= fullUVIpol ? dstw : dstw/2; int dstUVw;
int i; int i;
if(((dstw + 7)&(~7)) >= dststride) dstw&= ~7;
srcWidth= (dstw*s_xinc + 0x8000)>>16;
dstUVw= fullUVIpol ? dstw : dstw/2;
#ifdef HAVE_MMX2 #ifdef HAVE_MMX2
canMMX2BeUsed= (s_xinc <= 0x10000 && (dstw&31)==0 && (srcWidth&15)==0) ? 1 : 0; canMMX2BeUsed= (s_xinc <= 0x10000 && (dstw&31)==0 && (srcWidth&15)==0) ? 1 : 0;
#endif #endif
...@@ -1420,6 +1426,7 @@ else s_xinc2= s_xinc; ...@@ -1420,6 +1426,7 @@ else s_xinc2= s_xinc;
// force calculation of the horizontal interpolation of the first line // force calculation of the horizontal interpolation of the first line
if(y==0){ if(y==0){
// printf("dstw %d, srcw %d, mmx2 %d\n", dstw, srcWidth, canMMX2BeUsed);
s_last_ypos=-99; s_last_ypos=-99;
s_last_y1pos=-99; s_last_y1pos=-99;
s_srcypos= s_yinc/2 - 0x8000; s_srcypos= s_yinc/2 - 0x8000;
...@@ -1429,9 +1436,9 @@ else s_xinc2= s_xinc; ...@@ -1429,9 +1436,9 @@ else s_xinc2= s_xinc;
for(i=dstw-2; i<dstw+20; i++) for(i=dstw-2; i<dstw+20; i++)
{ {
pix_buf_uv[0][i] = pix_buf_uv[1][i] pix_buf_uv[0][i] = pix_buf_uv[1][i]
= pix_buf_uv[0][2048+i] = pix_buf_uv[1][2048+i] = 128; = pix_buf_uv[0][2048+i] = pix_buf_uv[1][2048+i] = 128*128;
pix_buf_uv[0][i/2] = pix_buf_uv[1][i/2] pix_buf_uv[0][i/2] = pix_buf_uv[1][i/2]
= pix_buf_uv[0][2048+i/2] = pix_buf_uv[1][2048+i/2] = 128; = pix_buf_uv[0][2048+i/2] = pix_buf_uv[1][2048+i/2] = 128*128;
pix_buf_y[0][i]= pix_buf_y[1][i]= 0; pix_buf_y[0][i]= pix_buf_y[1][i]= 0;
} }
......
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include "swscale.h" #include "swscale.h"
#include "../mmx_defs.h" #include "../mmx_defs.h"
#undef MOVNTQ #undef MOVNTQ
#undef PAVGB
//#undef HAVE_MMX2 //#undef HAVE_MMX2
//#undef HAVE_MMX //#undef HAVE_MMX
...@@ -1399,10 +1400,15 @@ static int old_dstw= -1; ...@@ -1399,10 +1400,15 @@ static int old_dstw= -1;
static int old_s_xinc= -1; static int old_s_xinc= -1;
#endif #endif
int srcWidth= (dstw*s_xinc + 0x8000)>>16; int srcWidth;
int dstUVw= fullUVIpol ? dstw : dstw/2; int dstUVw;
int i; int i;
if(((dstw + 7)&(~7)) >= dststride) dstw&= ~7;
srcWidth= (dstw*s_xinc + 0x8000)>>16;
dstUVw= fullUVIpol ? dstw : dstw/2;
#ifdef HAVE_MMX2 #ifdef HAVE_MMX2
canMMX2BeUsed= (s_xinc <= 0x10000 && (dstw&31)==0 && (srcWidth&15)==0) ? 1 : 0; canMMX2BeUsed= (s_xinc <= 0x10000 && (dstw&31)==0 && (srcWidth&15)==0) ? 1 : 0;
#endif #endif
...@@ -1420,6 +1426,7 @@ else s_xinc2= s_xinc; ...@@ -1420,6 +1426,7 @@ else s_xinc2= s_xinc;
// force calculation of the horizontal interpolation of the first line // force calculation of the horizontal interpolation of the first line
if(y==0){ if(y==0){
// printf("dstw %d, srcw %d, mmx2 %d\n", dstw, srcWidth, canMMX2BeUsed);
s_last_ypos=-99; s_last_ypos=-99;
s_last_y1pos=-99; s_last_y1pos=-99;
s_srcypos= s_yinc/2 - 0x8000; s_srcypos= s_yinc/2 - 0x8000;
...@@ -1429,9 +1436,9 @@ else s_xinc2= s_xinc; ...@@ -1429,9 +1436,9 @@ else s_xinc2= s_xinc;
for(i=dstw-2; i<dstw+20; i++) for(i=dstw-2; i<dstw+20; i++)
{ {
pix_buf_uv[0][i] = pix_buf_uv[1][i] pix_buf_uv[0][i] = pix_buf_uv[1][i]
= pix_buf_uv[0][2048+i] = pix_buf_uv[1][2048+i] = 128; = pix_buf_uv[0][2048+i] = pix_buf_uv[1][2048+i] = 128*128;
pix_buf_uv[0][i/2] = pix_buf_uv[1][i/2] pix_buf_uv[0][i/2] = pix_buf_uv[1][i/2]
= pix_buf_uv[0][2048+i/2] = pix_buf_uv[1][2048+i/2] = 128; = pix_buf_uv[0][2048+i/2] = pix_buf_uv[1][2048+i/2] = 128*128;
pix_buf_y[0][i]= pix_buf_y[1][i]= 0; pix_buf_y[0][i]= pix_buf_y[1][i]= 0;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment