aboutsummaryrefslogtreecommitdiff
path: root/graphics/scaler
diff options
context:
space:
mode:
authorMax Horn2009-01-27 21:44:24 +0000
committerMax Horn2009-01-27 21:44:24 +0000
commit1c0d2c5ab958790565a82ebce2aeb747417c561a (patch)
treeb20a6f85398448382318f2fbf6b34cd3de2c5419 /graphics/scaler
parentc27c9c37b7548b785c38df8bfbd7437dc1a73bbd (diff)
downloadscummvm-rg350-1c0d2c5ab958790565a82ebce2aeb747417c561a.tar.gz
scummvm-rg350-1c0d2c5ab958790565a82ebce2aeb747417c561a.tar.bz2
scummvm-rg350-1c0d2c5ab958790565a82ebce2aeb747417c561a.zip
Fixed hq2x ASM scaler
svn-id: r36115
Diffstat (limited to 'graphics/scaler')
-rw-r--r--graphics/scaler/hq2x_i386.asm48
-rw-r--r--graphics/scaler/hq3x_i386.asm13
2 files changed, 23 insertions, 38 deletions
diff --git a/graphics/scaler/hq2x_i386.asm b/graphics/scaler/hq2x_i386.asm
index 3de1095e74..66bd9359e4 100644
--- a/graphics/scaler/hq2x_i386.asm
+++ b/graphics/scaler/hq2x_i386.asm
@@ -132,7 +132,7 @@ SECTION .text
%%fin:
%endmacro
-; interpolate16_2<bitFormat,3,1>
+; interpolate16_3_1
; Mix two pixels with weight 3 and 1, respectively: (c1*3+c2)/4;
%macro Interp1 3
mov edx,%2
@@ -170,7 +170,6 @@ SECTION .text
; Mix three pixels with weight 5, 2, and 1, respectively: (c1*5+c2*2+c3)/8;
%macro Interp6 3
; Unpack eax to ecx and multiply by 5
- mov eax, [w5]
mov ecx, eax
shl ecx, 16
or ecx, eax
@@ -182,10 +181,9 @@ SECTION .text
add ecx, edx
; unpack c2 to edx
- mov eax, %2
- mov edx, eax
+ mov edx, %2
shl edx, 16
- or edx, eax
+ or edx, %2
and edx, [_hqx_green_redBlue_Mask]
; add 2*c2 to c1*5
@@ -193,10 +191,9 @@ SECTION .text
add ecx, edx
; unpack c3 to edx
- mov eax, %3
- mov edx, eax
+ mov edx, %3
shl edx, 16
- or edx, eax
+ or edx, %3
and edx, [_hqx_green_redBlue_Mask]
; add c3 and 2*c2+c1*5, divide by 8, mask the result
@@ -216,7 +213,6 @@ SECTION .text
; Mix three pixels with weight 6, 1, and 1, respectively: (c1*6+c2+c3)/8;
%macro Interp7 3
; Unpack eax to ecx and multiply by 6
- mov eax, [w5]
mov ecx, eax
shl ecx, 16
or ecx, eax
@@ -229,20 +225,18 @@ SECTION .text
add ecx, ecx
; unpack c2 to edx
- mov eax, %2
- mov edx, eax
+ mov edx, %2
shl edx, 16
- or edx, eax
+ or edx, %2
and edx, [_hqx_green_redBlue_Mask]
; add c2 to c1*3
add ecx, edx
; unpack c3 to edx
- mov eax, %3
- mov edx, eax
+ mov edx, %3
shl edx, 16
- or edx, eax
+ or edx, %3
and edx, [_hqx_green_redBlue_Mask]
; add c3 and c2+c1*3, divide by 8, mask the result
@@ -262,17 +256,15 @@ SECTION .text
; Mix three pixels with weight 2, 3, and 3, respectively: (c1*2+(c2+c3)*3)/8;
%macro Interp9 3
; unpack c2
- mov eax, %2
- mov edx, eax
+ mov edx, %2
shl edx, 16
- or edx, eax
+ or edx, %2
and edx, [_hqx_green_redBlue_Mask]
; unpack c3
- mov eax, %3
- mov ecx, eax
+ mov ecx, %3
shl ecx, 16
- or ecx, eax
+ or ecx, %3
and ecx, [_hqx_green_redBlue_Mask]
; sum c2 and c3
@@ -284,8 +276,7 @@ SECTION .text
add edx, edx
add edx, ecx
- ; Restore eax, unpack it and multiply by 2
- mov eax, [w5]
+ ; unpack eax and multiply by 2
mov ecx, eax
shl ecx, 16
or ecx, eax
@@ -309,7 +300,6 @@ SECTION .text
; Mix three pixels with weight 14, 1, and 1, respectively: (c1*14+c2+c3)/16;
%macro Interp10 3
; Unpack eax to ecx and multiply by 14
- mov eax, [w5]
mov ecx, eax
shl ecx, 16
or ecx, eax
@@ -322,20 +312,18 @@ SECTION .text
add ecx, ecx
; unpack c2 to edx
- mov eax, %2
- mov edx, eax
+ mov edx, %2
shl edx, 16
- or edx, eax
+ or edx, %2
and edx, [_hqx_green_redBlue_Mask]
; add c2 to c1*14
add ecx, edx
; unpack c3 to edx
- mov eax, %3
- mov edx, eax
+ mov edx, %3
shl edx, 16
- or edx, eax
+ or edx, %3
and edx, [_hqx_green_redBlue_Mask]
; add c3 and c2+c1*14, divide by 16, mask the result
diff --git a/graphics/scaler/hq3x_i386.asm b/graphics/scaler/hq3x_i386.asm
index c3d1daec37..d63dba23a5 100644
--- a/graphics/scaler/hq3x_i386.asm
+++ b/graphics/scaler/hq3x_i386.asm
@@ -208,17 +208,15 @@ SECTION .text
; Mix three pixels with weight 2, 7, and 7, respectively: (c1*2+(c2+c3)*7)/16;
%macro Interp4 3
; unpack c2
- mov eax, %2
- mov edx, eax
+ mov edx, %2
shl edx, 16
- or edx, eax
+ or edx, %2
and edx, [_hqx_green_redBlue_Mask]
; unpack c3
- mov eax, %3
- mov ecx, eax
+ mov ecx, %3
shl ecx, 16
- or ecx, eax
+ or ecx, %3
and ecx, [_hqx_green_redBlue_Mask]
; sum c2 and c3
@@ -230,8 +228,7 @@ SECTION .text
shl edx, 3
sub edx, ecx
- ; Restore eax, unpack it and multiply by 2
- mov eax, [w5]
+ ; unpack eax and multiply by 2
mov ecx, eax
shl ecx, 16
or ecx, eax