|  |  | @@ -1893,6 +1893,8 @@ static void initMMX2HScaler(int dstW, int xInc, uint8_t *funnyCode, int16_t *fil | 
		
	
		
			
			|  |  |  | x86_reg imm8OfPShufW1  = (d+1<4) ? imm8OfPShufW1B  : imm8OfPShufW1A; | 
		
	
		
			
			|  |  |  | x86_reg imm8OfPShufW2  = (d+1<4) ? imm8OfPShufW2B  : imm8OfPShufW2A; | 
		
	
		
			
			|  |  |  | x86_reg fragmentLength = (d+1<4) ? fragmentLengthB : fragmentLengthA; | 
		
	
		
			
			|  |  |  | int maxShift= 3-(d+inc); | 
		
	
		
			
			|  |  |  | int shift=0; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | filter[i  ] = (( xpos         & 0xFFFF) ^ 0xFFFF)>>9; | 
		
	
		
			
			|  |  |  | filter[i+1] = (((xpos+xInc  ) & 0xFFFF) ^ 0xFFFF)>>9; | 
		
	
	
		
			
				|  |  | @@ -1900,30 +1902,25 @@ static void initMMX2HScaler(int dstW, int xInc, uint8_t *funnyCode, int16_t *fil | 
		
	
		
			
			|  |  |  | filter[i+3] = (((xpos+xInc*3) & 0xFFFF) ^ 0xFFFF)>>9; | 
		
	
		
			
			|  |  |  | filterPos[i/2]= xx; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | { | 
		
	
		
			
			|  |  |  | int maxShift= 3-(d+inc); | 
		
	
		
			
			|  |  |  | int shift=0; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | memcpy(funnyCode + fragmentPos, fragment, fragmentLength); | 
		
	
		
			
			|  |  |  | memcpy(funnyCode + fragmentPos, fragment, fragmentLength); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos + imm8OfPShufW1]= | 
		
	
		
			
			|  |  |  | (a+inc) | ((b+inc)<<2) | ((c+inc)<<4) | ((d+inc)<<6); | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos + imm8OfPShufW2]= | 
		
	
		
			
			|  |  |  | a | (b<<2) | (c<<4) | (d<<6); | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos + imm8OfPShufW1]= | 
		
	
		
			
			|  |  |  | (a+inc) | ((b+inc)<<2) | ((c+inc)<<4) | ((d+inc)<<6); | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos + imm8OfPShufW2]= | 
		
	
		
			
			|  |  |  | a | (b<<2) | (c<<4) | (d<<6); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | if (i+4-inc>=dstW) shift=maxShift; //avoid overread | 
		
	
		
			
			|  |  |  | else if ((filterPos[i/2]&3) <= maxShift) shift=filterPos[i/2]&3; //Align | 
		
	
		
			
			|  |  |  | if (i+4-inc>=dstW) shift=maxShift; //avoid overread | 
		
	
		
			
			|  |  |  | else if ((filterPos[i/2]&3) <= maxShift) shift=filterPos[i/2]&3; //Align | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | if (shift && i>=shift) | 
		
	
		
			
			|  |  |  | { | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos + imm8OfPShufW1]+= 0x55*shift; | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos + imm8OfPShufW2]+= 0x55*shift; | 
		
	
		
			
			|  |  |  | filterPos[i/2]-=shift; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | fragmentPos+= fragmentLength; | 
		
	
		
			
			|  |  |  | if (shift && i>=shift) | 
		
	
		
			
			|  |  |  | { | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos + imm8OfPShufW1]+= 0x55*shift; | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos + imm8OfPShufW2]+= 0x55*shift; | 
		
	
		
			
			|  |  |  | filterPos[i/2]-=shift; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | fragmentPos+= fragmentLength; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | funnyCode[fragmentPos]= RET; | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | xpos+=xInc; | 
		
	
	
		
			
				|  |  | 
 |