From bcc1b7518f7720f7e3ef6e1d5f33132c5435adce Mon Sep 17 00:00:00 2001 From: nmlgc Date: Sat, 29 Dec 2018 15:54:07 +0100 Subject: [PATCH] [Reverse-engineering] [th04/th05] Applying VRAM scrolling to Y coordinates Funded by -Tom-. --- th04/scroll_y_1.asm | 29 ++++++ th04/scroll_y_3.asm | 51 +++++++++++ th04_main.asm | 214 +++++++++++--------------------------------- th05_main.asm | 195 ++++++++++------------------------------ 4 files changed, 176 insertions(+), 313 deletions(-) create mode 100644 th04/scroll_y_1.asm create mode 100644 th04/scroll_y_3.asm diff --git a/th04/scroll_y_1.asm b/th04/scroll_y_1.asm new file mode 100644 index 00000000..d96fbd8d --- /dev/null +++ b/th04/scroll_y_1.asm @@ -0,0 +1,29 @@ +; Transforms the 1/16-pixel on-screen Y coordinate [sy] to its corresponding +; VRAM line given the current scrolling offset. + +; int scroll_subpixel_y_to_vram(int sy) +public scroll_subpixel_y_to_vram_seg1 +scroll_subpixel_y_to_vram_seg1 proc near +@@sy = word ptr 2 + + mov bx, sp + mov ax, ss:[bx+@@sy] + sar ax, 4 + cmp _scroll_active, 0 + jz short @@lt0? + add ax, _scroll_line + +@@lt0?: + or ax, ax + jge short @@lt400? + add ax, RES_Y + jmp short @@ret + +@@lt400?: + cmp ax, RES_Y + jl short @@ret + sub ax, RES_Y + +@@ret: + ret 2 +scroll_subpixel_y_to_vram_seg1 endp diff --git a/th04/scroll_y_3.asm b/th04/scroll_y_3.asm new file mode 100644 index 00000000..76a0d090 --- /dev/null +++ b/th04/scroll_y_3.asm @@ -0,0 +1,51 @@ +; See scroll_subpixel_y_to_vram_seg1(). +public scroll_subpixel_y_to_vram_seg3 +scroll_subpixel_y_to_vram_seg3 proc near +@@sy = word ptr 2 + + mov bx, sp + mov ax, ss:[bx+@@sy] + sar ax, 4 + cmp _scroll_active, 0 + jz short @@lt400? + add ax, _scroll_line + +@@lt400?: + cmp ax, RES_Y + jl short @@lt0? + sub ax, RES_Y + jmp short @@ret + +@@lt0?: + or ax, ax + jge short @@ret + add ax, RES_Y + +@@ret: + ret 2 +scroll_subpixel_y_to_vram_seg3 endp + + +; Like the one above, but transforming even if scrolling is disabled. +public scroll_subpixel_y_to_vram_always +scroll_subpixel_y_to_vram_always proc near +@@sy = word ptr 2 + + mov bx, sp + mov ax, ss:[bx+@@sy] + sar ax, 4 + add ax, _scroll_line + cmp ax, RES_Y + jl short @@lt0? + sub ax, RES_Y + jmp short @@ret + +@@lt0?: + or ax, ax + jge short @@ret + add ax, RES_Y + +@@ret: + ret 2 +scroll_subpixel_y_to_vram_always endp + nop diff --git a/th04_main.asm b/th04_main.asm index 28f0e9b2..6b053a8d 100644 --- a/th04_main.asm +++ b/th04_main.asm @@ -1402,9 +1402,8 @@ arg_4 = word ptr 0Ah mov al, _scroll_active mov [bp+var_1], al mov _scroll_active, 1 - lea ax, [di+100h] - push ax - call sub_BC10 + lea ax, [di+(16 shl 4)] + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov di, ax mov bx, 10h cwd @@ -2015,34 +2014,7 @@ loc_BBFA: retn sub_BBA4 endp - -; =============== S U B R O U T I N E ======================================= - - -sub_BC10 proc near - mov bx, sp - mov ax, ss:[bx+2] - sar ax, 4 - cmp _scroll_active, 0 - jz short loc_BC24 - add ax, _scroll_line - -loc_BC24: - or ax, ax - jge short loc_BC2D - add ax, RES_Y - jmp short locret_BC35 -; --------------------------------------------------------------------------- - -loc_BC2D: - cmp ax, RES_Y - jl short locret_BC35 - sub ax, RES_Y - -locret_BC35: - retn 2 -sub_BC10 endp - +include th04/scroll_y_1.asm MOTION_UPDATE_DEF 1 include th03/math/randring_fill.asm RANDRING_NEXT_DEF 1 @@ -2223,9 +2195,8 @@ loc_BD96: sar dx, 4 add dx, 0Ch mov ax, [si+4] - add ax, 0C0h - push ax - call sub_BC10 + add ax, (12 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov bp, 4 add si, 0Bh @@ -2863,8 +2834,7 @@ loc_C19A: jge short loc_C1E6 mov ax, _drawpoint.y add ax, (16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, _drawpoint.x sar ax, 4 @@ -3029,12 +2999,11 @@ loc_C2C4: cmp byte ptr [si], 1 jnz short loc_C2E4 mov ax, [si+4] - add ax, 0C0h - push ax - call sub_BC10 + add ax, (12 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] - add ax, 1C0h + add ax, (28 shl 4) sar ax, 4 mov cl, [si+1] call sub_C200 @@ -3567,8 +3536,7 @@ sub_C778 proc near sar ax, 4 add ax, 16 mov di, ax - push _midboss_pos.cur.y - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, _midboss_pos.cur.y mov si, ax push di push ax @@ -3585,8 +3553,7 @@ loc_C7A1: mov di, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov si, ax push di push ax @@ -3596,8 +3563,7 @@ loc_C7A1: call super_roll_put mov ax, _midboss_pos.cur.y add ax, (16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov si, ax push di push ax @@ -3621,8 +3587,7 @@ loc_C7E6: mov di, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov si, ax cmp byte_26708, 0 jnz short loc_C836 @@ -3638,8 +3603,7 @@ loc_C7E6: call super_roll_put mov ax, _midboss_pos.cur.y add ax, (16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov si, ax push di push ax @@ -3661,8 +3625,7 @@ loc_C836: call super_roll_put_1plane mov ax, _midboss_pos.cur.y add ax, (16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov si, ax push di push ax @@ -3710,8 +3673,7 @@ var_2 = word ptr -2 mov di, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax cmp byte_26705, 0FEh jnz short loc_C8D2 @@ -3803,8 +3765,7 @@ var_2 = word ptr -2 sar ax, 4 add ax, 16 mov [bp+var_2], ax - push _midboss_pos.cur.y - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, _midboss_pos.cur.y mov [bp+var_4], ax mov al, frame_mod16 mov ah, 0 @@ -4206,8 +4167,7 @@ var_2 = word ptr -2 mov di, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax cmp byte_26705, 2 ja short loc_CCD2 @@ -4435,8 +4395,7 @@ var_2 = word ptr -2 mov di, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax cmp byte_26705, 2 ja short loc_CE85 @@ -7205,8 +7164,7 @@ loc_E276: mov ah, al call _grcg_setcolor_direct_noint_1 mov si, word ptr dword_2560C+2 - push 100h - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, (16 shl 4) mov dx, ax mov ax, word ptr dword_2560C sar ax, 4 @@ -7214,8 +7172,7 @@ loc_E276: mov bx, di call sub_BE68 mov si, word ptr dword_2560C+2 - push 100h - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, (16 shl 4) mov dx, ax mov ax, word ptr dword_2560C sar ax, 4 @@ -8372,9 +8329,8 @@ loc_EC24: mov bx, si add bx, bx mov ax, [bx-430Ch] - add ax, 0FE80h - push ax - call sub_BC10 + add ax, (-24 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax mov ax, si shl ax, 7 @@ -11780,9 +11736,8 @@ loc_10570: loc_1058D: mov ax, [si+4] - add ax, 80h - push ax - call sub_BC10 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -12010,8 +11965,7 @@ loc_10776: sar ax, 4 add ax, 10h mov di, ax - push word ptr [si+4] - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, word ptr [si+4] mov [bp+var_4], ax or di, di jle short loc_107D0 @@ -12564,8 +12518,7 @@ loc_10C13: mov di, ax mov ax, player_pos.cur.y add ax, -128 - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax cmp player_pos.velocity.x, 0 jge short loc_10C37 @@ -12610,9 +12563,8 @@ loc_10C6F: sar ax, 4 mov di, ax mov ax, word ptr dword_259AC+2 - add ax, 80h - push ax - call sub_BC10 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax mov ax, di mov dx, [bp+var_2] @@ -12670,8 +12622,7 @@ loc_10CE0: mov di, ax mov ax, _drawpoint.y add ax, (-8 shl 4) - push ax - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax push di push ax @@ -12935,7 +12886,7 @@ sub_10E39 endp sub_10EA5 proc near arg_0 = word ptr 4 -arg_2 = word ptr 6 +@@y = word ptr 6 arg_4 = word ptr 8 push bp @@ -12952,9 +12903,8 @@ arg_4 = word ptr 8 mov ax, 8 imul si mov si, ax - push [bp+arg_2] - call sub_BC10 - mov [bp+arg_2], ax + call scroll_subpixel_y_to_vram_seg1 pascal, [bp+@@y] + mov [bp+@@y], ax mov ax, GRAM_400 mov es, ax assume es:nothing @@ -12965,7 +12915,7 @@ loc_10ED1: mov al, byte_22EF6 mov ah, 0 mov cx, ax - mov dx, [bp+arg_2] + mov dx, [bp+@@y] mov ax, si call sub_C09A add si, 10h @@ -14355,8 +14305,7 @@ loc_11AC4: sar ax, 4 add ax, 10h mov si, ax - push di - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, di mov di, ax push si push ax @@ -16726,9 +16675,8 @@ loc_12CFA: cmp byte ptr [si+12h], 3 ja short loc_12D24 mov ax, [si+4] - add ax, 80h - push ax - call sub_BC10 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -16777,8 +16725,7 @@ loc_12D6D: cwd idiv bx add [bp+var_2], ax - push word ptr [si+4] - call sub_BC10 + call scroll_subpixel_y_to_vram_seg1 pascal, word ptr [si+4] mov dx, ax mov ax, [si+2] sar ax, 4 @@ -16815,9 +16762,8 @@ loc_12DC2: cmp byte ptr [si], 1 jnz short loc_12DE2 mov ax, [si+4] - add ax, 80h - push ax - call sub_BC10 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -16864,9 +16810,8 @@ loc_12E04: cmp word ptr [si+4], 0FF80h jle short loc_12E2A mov ax, [si+4] - add ax, 80h - push ax - call sub_BC10 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -17909,8 +17854,7 @@ loc_13C8F: jz short loc_13CD1 mov ax, _drawpoint.y add ax, (12 shl 4) - push ax - call sub_13CE8 + call scroll_subpixel_y_to_vram_seg3 pascal, ax mov dx, ax mov ax, _drawpoint.x sar ax, 4 @@ -17940,60 +17884,7 @@ sub_13C5C endp ; --------------------------------------------------------------------------- db 0 -; =============== S U B R O U T I N E ======================================= - - -sub_13CE8 proc near - mov bx, sp - mov ax, ss:[bx+2] - sar ax, 4 - cmp _scroll_active, 0 - jz short loc_13CFC - add ax, _scroll_line - -loc_13CFC: - cmp ax, RES_Y - jl short loc_13D06 - sub ax, RES_Y - jmp short locret_13D0D -; --------------------------------------------------------------------------- - -loc_13D06: - or ax, ax - jge short locret_13D0D - add ax, RES_Y - -locret_13D0D: - retn 2 -sub_13CE8 endp - - -; =============== S U B R O U T I N E ======================================= - - -sub_13D10 proc near - mov bx, sp - mov ax, ss:[bx+2] - sar ax, 4 - add ax, _scroll_line - cmp ax, RES_Y - jl short loc_13D27 - sub ax, RES_Y - jmp short locret_13D2E -; --------------------------------------------------------------------------- - -loc_13D27: - or ax, ax - jge short locret_13D2E - add ax, RES_Y - -locret_13D2E: - retn 2 -sub_13D10 endp - -; --------------------------------------------------------------------------- - nop - +include th04/scroll_y_3.asm MOTION_UPDATE_DEF 2 RANDRING_NEXT_DEF 2 db 0 @@ -18401,8 +18292,7 @@ sub_14017 proc far mov al, _scroll_subpixel_line mov ah, 0 add _midboss_pos.cur.y, ax - push _midboss_pos.cur.y - call sub_13CE8 + call scroll_subpixel_y_to_vram_seg3 pascal, _midboss_pos.cur.y mov word_25596, ax push _midboss_pos.cur.x push _midboss_pos.cur.y @@ -18446,8 +18336,7 @@ loc_14158: sub _midboss_pos.cur.y, (16 shl 4) mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_13CE8 + call scroll_subpixel_y_to_vram_seg3 pascal, ax mov word_25596, ax push _midboss_pos.cur.x push _midboss_pos.cur.y @@ -18929,8 +18818,7 @@ loc_14629: mov byte_26708, 1 mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_13D10 + call scroll_subpixel_y_to_vram_always pascal, ax mov si, ax mov _bullet_clear_trigger, 1 mov al, byte_2559A @@ -20509,8 +20397,7 @@ loc_15414: mov byte_26708, 1 mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_13D10 + call scroll_subpixel_y_to_vram_always pascal, ax mov si, ax mov _bullet_clear_trigger, 1 mov al, byte_255C7 @@ -34632,9 +34519,8 @@ loc_1CAC5: shl bx, 2 mov [bx-792Eh], ax mov ax, [si+4] - add ax, 0C0h - push ax - call sub_13CE8 + add ax, (12 shl 4) + call scroll_subpixel_y_to_vram_seg3 pascal, ax mov bx, word_2D006 shl bx, 2 mov [bx-792Ch], ax diff --git a/th05_main.asm b/th05_main.asm index 9f99e1f4..da815680 100644 --- a/th05_main.asm +++ b/th05_main.asm @@ -2193,34 +2193,7 @@ loc_BF9C: retn sub_BF46 endp - -; =============== S U B R O U T I N E ======================================= - - -sub_BFB2 proc near - mov bx, sp - mov ax, ss:[bx+2] - sar ax, 4 - cmp _scroll_active, 0 - jz short loc_BFC6 - add ax, _scroll_line - -loc_BFC6: - or ax, ax - jge short loc_BFCF - add ax, RES_Y - jmp short locret_BFD7 -; --------------------------------------------------------------------------- - -loc_BFCF: - cmp ax, RES_Y - jl short locret_BFD7 - sub ax, RES_Y - -locret_BFD7: - retn 2 -sub_BFB2 endp - +include th04/scroll_y_1.asm MOTION_UPDATE_DEF 1 include th03/math/randring_fill.asm RANDRING_NEXT_DEF 1 @@ -2556,9 +2529,8 @@ loc_C214: cmp byte ptr [si], 1 jnz short loc_C234 mov ax, [si+4] - add ax, 0C0h - push ax - call sub_BFB2 + add ax, (12 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] add ax, 1C0h @@ -2802,9 +2774,8 @@ loc_C377: shr bp, 2 sub bp, 2 mov ax, [si+4] - add ax, 0C0h - push ax - call sub_BFB2 + add ax, (12 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax add si, 0Ah add si, bp @@ -2913,9 +2884,8 @@ numerals_draw endp mov al, _scroll_active mov [bp-1], al mov _scroll_active, 1 - lea ax, [di+100h] - push ax - call sub_BFB2 + lea ax, [di+(16 shl 4)] + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov di, ax mov bx, 10h cwd @@ -8088,8 +8058,7 @@ loc_EC1A: sar ax, 4 add ax, 10h mov di, ax - push word ptr [si+4] - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, word ptr [si+4] mov [bp+var_4], ax or di, di jle short loc_EC74 @@ -9442,9 +9411,8 @@ loc_F7B9: cmp word ptr [si+4], 0FF80h jle short loc_F7DF mov ax, [si+4] - add ax, 80h - push ax - call sub_BFB2 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -9524,8 +9492,7 @@ loc_F816: sar ax, 4 add ax, 10h mov si, ax - push di - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, di mov di, ax push si push ax @@ -10112,8 +10079,7 @@ loc_10061: jge short loc_100AD mov ax, _drawpoint.y add ax, (16 shl 4) - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, _drawpoint.x sar ax, 4 @@ -10167,9 +10133,8 @@ loc_100DE: cmp byte ptr [si+12h], 3 ja short loc_10108 mov ax, [si+4] - add ax, 80h - push ax - call sub_BFB2 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -10216,8 +10181,7 @@ loc_10149: cwd idiv bx add di, ax - push word ptr [si+4] - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, word ptr [si+4] mov dx, ax mov ax, [si+2] sar ax, 4 @@ -10251,9 +10215,8 @@ loc_1018A: add ax, 93h mov di, ax mov ax, [si+4] - add ax, 80h - push ax - call sub_BFB2 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -10284,9 +10247,8 @@ loc_101E3: cmp byte ptr [si], 1 jnz short loc_10203 mov ax, [si+4] - add ax, 80h - push ax - call sub_BFB2 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -11028,8 +10990,7 @@ var_2 = word ptr -2 sar ax, 4 add ax, 10h mov di, ax - push _midboss_pos.cur.y - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, _midboss_pos.cur.y mov [bp+var_2], ax mov al, midboss_cur_image mov ah, 0 @@ -11052,8 +11013,7 @@ var_2 = word ptr -2 mov di, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax cmp byte_26331, 2 jnz short loc_108C2 @@ -11223,8 +11183,7 @@ var_2 = word ptr -2 mov di, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax cmp midboss_cur_image, 0CAh jnz short loc_109E3 @@ -11369,8 +11328,7 @@ var_2 = word ptr -2 mov di, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax cmp midboss_cur_image, 0D0h jnz short loc_10ADE @@ -11859,8 +11817,7 @@ var_2 = word ptr -2 mov si, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov di, ax mov al, midboss_cur_image mov ah, 0 @@ -11945,8 +11902,7 @@ loc_10EE8: mov word ptr [si+16h], 0 loc_10EED: - push word ptr [si+4] - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, word ptr [si+4] mov dx, ax mov ax, [si+2] sar ax, 4 @@ -12066,8 +12022,7 @@ loc_10FA3: jz short loc_10FC5 mov ax, [si+12h] mov [bp+var_2], ax - push word ptr [si+4] - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, word ptr [si+4] mov dx, ax mov ax, [si+2] sar ax, 4 @@ -12826,9 +12781,8 @@ loc_115AD: add ax, 18h mov [bp+var_4], ax mov ax, [si+4] - add ax, 80h - push ax - call sub_BFB2 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov cx, [bp+var_4] push di call sub_E318 @@ -12898,8 +12852,7 @@ sub_11630 proc near mov si, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov di, ax cmp byte_26334, 0 jnz short loc_1166D @@ -13204,8 +13157,7 @@ sub_1186C proc near mov si, ax mov ax, _midboss_pos.cur.y add ax, (-16 shl 4) - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov di, ax cmp byte_26334, 0 jnz short loc_118A9 @@ -13463,7 +13415,7 @@ sub_119B1 endp sub_11A1D proc near arg_0 = word ptr 4 -arg_2 = word ptr 6 +@@y = word ptr 6 arg_4 = word ptr 8 push bp @@ -13480,9 +13432,8 @@ arg_4 = word ptr 8 mov ax, 8 imul si mov si, ax - push [bp+arg_2] - call sub_BFB2 - mov [bp+arg_2], ax + call scroll_subpixel_y_to_vram_seg1 pascal, [bp+@@y] + mov [bp+@@y], ax mov ax, GRAM_400 mov es, ax assume es:nothing @@ -13493,7 +13444,7 @@ loc_11A49: mov al, byte_228EC mov ah, 0 mov cx, ax - mov dx, [bp+arg_2] + mov dx, [bp+@@y] mov ax, si call sub_E58C add si, 10h @@ -14328,8 +14279,7 @@ loc_12279: mov di, ax mov ax, player_pos.cur.y add ax, -128 - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax cmp player_pos.velocity.x, 0 jge short loc_1229D @@ -14374,9 +14324,8 @@ loc_122D5: sar ax, 4 mov di, ax mov ax, word ptr dword_2CEB4+2 - add ax, 80h - push ax - call sub_BFB2 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax mov ax, di mov dx, [bp+var_2] @@ -14434,8 +14383,7 @@ loc_12342: mov di, ax mov ax, _drawpoint.y add ax, (-8 shl 4) - push ax - call sub_BFB2 + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov [bp+var_2], ax push di push ax @@ -14773,9 +14721,8 @@ loc_125BB: add al, cl mov cl, al mov ax, [di+2] - add ax, 80h - push ax - call sub_BFB2 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [di] sar ax, 4 @@ -14804,9 +14751,8 @@ loc_12609: mov ch, 0 mov cl, [si+1] mov ax, [si+4] - add ax, 80h - push ax - call sub_BFB2 + add ax, (8 shl 4) + call scroll_subpixel_y_to_vram_seg1 pascal, ax mov dx, ax mov ax, [si+2] sar ax, 4 @@ -19691,54 +19637,7 @@ main_03_TEXT segment byte public 'CODE' use16 ;org 8 assume es:nothing, ss:nothing, ds:_DATA, fs:nothing, gs:nothing -; =============== S U B R O U T I N E ======================================= - - -sub_15288 proc near - mov bx, sp - mov ax, ss:[bx+2] - sar ax, 4 - cmp _scroll_active, 0 - jz short loc_1529C - add ax, _scroll_line - -loc_1529C: - cmp ax, RES_Y - jl short loc_152A6 - sub ax, RES_Y - jmp short locret_152AD -; --------------------------------------------------------------------------- - -loc_152A6: - or ax, ax - jge short locret_152AD - add ax, RES_Y - -locret_152AD: - retn 2 -sub_15288 endp - -; --------------------------------------------------------------------------- - mov bx, sp - mov ax, ss:[bx+2] - sar ax, 4 - add ax, _scroll_line - cmp ax, RES_Y - jl short loc_152C7 - sub ax, RES_Y - jmp short locret_152CE -; --------------------------------------------------------------------------- - -loc_152C7: - or ax, ax - jge short locret_152CE - add ax, RES_Y - -locret_152CE: - retn 2 -; --------------------------------------------------------------------------- - nop - +include th04/scroll_y_3.asm MOTION_UPDATE_DEF 2 ; =============== S U B R O U T I N E ======================================= @@ -22995,8 +22894,7 @@ loc_16B81: jz short loc_16BC3 mov ax, _drawpoint.y add ax, (12 shl 4) - push ax - call sub_15288 + call scroll_subpixel_y_to_vram_seg3 pascal, ax mov dx, ax mov ax, _drawpoint.x sar ax, 4 @@ -25288,9 +25186,8 @@ loc_17E41: shl bx, 2 mov [bx-703Ah], ax mov ax, [si+4] - add ax, 0C0h - push ax - call sub_15288 + add ax, (12 shl 4) + call scroll_subpixel_y_to_vram_seg3 pascal, ax mov bx, word_2C97E shl bx, 2 mov [bx-7038h], ax