⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 m716text.asm

📁 linux下的任天堂模拟器代码。供大家参考。
💻 ASM
📖 第 1 页 / 共 2 页
字号:
;Copyright (C) 1997-2007 ZSNES Team ( zsKnight, _Demo_, pagefault, Nach );;http://www.zsnes.com;http://sourceforge.net/projects/zsnes;https://zsnes.bountysource.com;;This program is free software; you can redistribute it and/or;modify it under the terms of the GNU General Public License;version 2 as published by the Free Software Foundation.;;This program is distributed in the hope that it will be useful,;but WITHOUT ANY WARRANTY; without even the implied warranty of;MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the;GNU General Public License for more details.;;You should have received a copy of the GNU General Public License;along with this program; if not, write to the Free Software;Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.%include "macros.mac"EXTSYM coladdr,curmosaicsz,curvidoffset,domosaic16b,mode7A,mode7B,mode7C,mode7DEXTSYM mode7X0,mode7Y0,mode7set,mode7tab,pal16b,pal16bcl,pal16bxcl,scaddtypeEXTSYM scrnon,transpbuf,vesa2_clbit,vram,vrama,winon,xtravbuf,winptrrefEXTSYM fulladdtab,cwinptr;*******************************************************; Processes & Draws Mode 7;*******************************************************%macro mode7halfadd 0    mov [esi+288*2],dl    test dl,80h    jnz %%nodraw    or dl,dl    jz %%nodraw    mov ecx,[ebp]    mov ebx,[pal16bcl+edx*4]    cmp cx,0    je %%noadd    and ebx,[vesa2_clbit]    and ecx,[vesa2_clbit]    add ebx,ecx    shr ebx,1%%noadd    mov [esi],bx    xor ecx,ecx%%nodraw%endmacro%macro mode7fulladd 0    mov [esi+288*2],dl    test dl,80h    jnz %%nodraw    or dl,dl    jz %%nodraw    mov ecx,[ebp]    mov ebx,[pal16bcl+edx*4]    and ecx,[vesa2_clbit]    add ebx,ecx    shr ebx,1    mov ebx,[fulladdtab+ebx*2]    mov [esi],bx%%nodraw%endmacro%macro mode7fullsub 0    mov [esi+288*2],dl    test dl,80h    jnz %%nodraw    or dl,dl    jz %%nodraw    mov ecx,[ebp]    mov ebx,[pal16bxcl+edx*4]    and ecx,[vesa2_clbit]    add ebx,ecx    shr ebx,1    mov ebx,[fulladdtab+ebx*2]    xor ebx,0FFFFh    mov [esi],bx%%nodraw%endmacro%macro mode7mainsub 0    mov [esi+288*2],dl    test dl,80h    jnz %%nodraw    or dl,dl    jz %%nodraw    mov ecx,[pal16b+edx*4]    mov [esi],cx    mov [ebp],cx%%nodraw%endmacro%macro mode7halfaddwinon 0    mov [esi+288*2],dl    mov eax,[cwinptr]    test dl,80h    jnz %%nodraw    or dl,dl    jz %%nodraw    test byte[eax],0FFh    jnz %%nodraw    mov ecx,[ebp]    mov ebx,[pal16bcl+edx*4]    cmp cx,0    je %%noadd    and ebx,[vesa2_clbit]    and ecx,[vesa2_clbit]    add ebx,ecx    shr ebx,1%%noadd    mov [esi],bx    xor ecx,ecx%%nodraw    inc dword[cwinptr]%endmacro%macro mode7fulladdwinon 0    mov [esi+288*2],dl    mov eax,[cwinptr]    test dl,80h    jnz %%nodraw    or dl,dl    jz %%nodraw    test byte[eax],0FFh    jnz %%nodraw    mov ecx,[ebp]    mov ebx,[pal16bcl+edx*4]    and ecx,[vesa2_clbit]    add ebx,ecx    shr ebx,1    mov ebx,[fulladdtab+ebx*2]    mov [esi],bx%%nodraw    inc dword[cwinptr]%endmacro%macro mode7fullsubwinon 0    mov [esi+288*2],dl    mov eax,[cwinptr]    test dl,80h    jnz %%nodraw    or dl,dl    jz %%nodraw    test byte[eax],0FFh    jnz %%nodraw    mov ecx,[ebp]    mov ebx,[pal16bxcl+edx*4]    and ecx,[vesa2_clbit]    add ebx,ecx    shr ebx,1    mov ebx,[fulladdtab+ebx*2]    xor ebx,0FFFFh    mov [esi],bx%%nodraw    inc dword[cwinptr]%endmacro%macro mode7mainsubwinon 0    mov [esi+288*2],dl    mov eax,[cwinptr]    test dl,80h    jnz %%nodraw    or dl,dl    jz %%nodraw    test byte[eax],0FFh    jnz %%nodraw    mov ecx,[pal16b+edx*4]    mov [esi],cx    mov [ebp],cx%%nodraw    inc dword[cwinptr]%endmacro%macro mode716tmacro 1    ; mode 7, ax = curyposition, dx = curxposition (left side)    ; draw center map coordinates at (X0-bg1scrolx,Y0-bg1scroly) on screen    ; center map coordinates = (X0,Y0)    ; 1.) cx=X0-bg1scrolx, cy =Y0-ax    mov bx,[mode7X0]    and bx,0001111111111111b    ; 13 -> 16 bit signed value    test bx,0001000000000000b    jz .nonega    or bx,1110000000000000b.nonega    mov [.cxloc],bx    mov bx,dx    and bx,0001111111111111b    ; 13 -> 16 bit signed value    test bx,0001000000000000b    jz .nonegb    or bx,1110000000000000b.nonegb    sub [.cxloc],bx    mov bx,ax    and bx,0001111111111111b    ; 13 -> 16 bit signed value    test bx,0001000000000000b    jz .nonegc    or bx,1110000000000000b.nonegc    mov [.cyloc],bx    mov bx,[mode7Y0]    and bx,0001111111111111b    ; 13 -> 16 bit signed value    test bx,0001000000000000b    jz .nonegd    or bx,1110000000000000b.nonegd    sub word[.cyloc],bx    ; 2.) Find position at scaled y, centered x at SCX=X0-(cy*C),SCY=Y0-(cy*D)    movsx ebx,word[.cyloc]    movsx eax,word[mode7C]    imul eax,ebx    neg eax    mov [.mode7xpos],eax    mov bx,[mode7X0]    add [.mode7xpos+1],bx    movsx ebx,word[.cyloc]    movsx eax,word[mode7D]    imul eax,ebx;    neg ax    mov [.mode7ypos],eax    mov bx,[mode7Y0]    add [.mode7ypos+1],bx    ; 3.) Find left scaled location : SCX=SCX-(cx*A),SCY=SCY-(cx*B)    movsx ebx,word[.cxloc]    movsx eax,word[mode7A]    mov [.mode7xadder],eax    imul eax,ebx    neg eax    add [.mode7xpos],eax    movsx ebx,word[.cxloc]    movsx eax,word[mode7B]    mov [.mode7yadder],eax    imul eax,ebx    add [.mode7ypos],eax    ; esi = pointer to video buffer    mov esi,[curvidoffset]       ; esi = [vidbuffer] + curypos * 288 + 16    mov edi,[vram]    cmp byte[curmosaicsz],1    je .nomosaic    mov esi,xtravbuf+32    mov ecx,128.clearnext    mov dword[esi],0    add esi,4    dec ecx    jnz .clearnext    mov esi,xtravbuf+32.nomosaic    mov ebp,transpbuf+32    ; esi = pointer to video buffer    ; edi = pointer to vram    ; [.mode7xadder] = dword value to add to x value (decimal between 7 & 8bit)    ; [.mode7yadder] = dword value to add to y value (decimal between 7 & 8bit)    ; [.mode7xpos]   = dword value of x position, decimal between 7 & 8bit    ; [.mode7xpos+1] = word value of x position    ; [.mode7ypos]   = dword value of y position, decimal between 7 & 8bit    ; [.mode7ypos+1] = word value of y position    mov byte[.temp],0    xor ebx,ebx    xor edx,edx    xor ecx,ecx    mov dword[.mode7xadd2],800h    mov byte[.mode7xinc],2    test dword[.mode7xadder],80000000h    jz .noneg    mov dword[.mode7xadd2],-800h    mov byte[.mode7xinc],-2.noneg    mov dword[.mode7yadd2],800h    mov byte[.mode7yinc],1    test dword[.mode7yadder],80000000h    jz .noneg2    mov dword[.mode7yadd2],-800h    mov byte[.mode7yinc],-1.noneg2    mov edi,[vram]    cmp dword[.mode7xadder],7F0h    jg near .nextval3    cmp dword[.mode7xadder],-7F0h    jl near .nextval3    cmp dword[.mode7yadder],7F0h    jg near .nextval3    cmp dword[.mode7yadder],-7F0h    jl near .nextval3    test byte[mode7set],80h    jnz near .norep2    mov eax,[.mode7xpos]    and eax,7FFh    mov [.mode7xrpos],eax    mov eax,[.mode7ypos]    and eax,7FFh    mov [.mode7yrpos],eax    ; get tile data offset into edi    mov ebx,[.mode7ypos+1]    mov eax,[.mode7xpos+1]    shl ebx,5    shr eax,3    and ebx,07FF8h    shl al,1    mov bl,al    mov edi,[vram]    xor ch,ch    mov [.mode7ptr],ebx    mov cl,[edi+ebx]    shl ecx,7    add edi,ecx.nextval    test byte[.mode7xrpos+1],08h    jnz near .rposoffx.nextposx    test byte[.mode7yrpos+1],08h    jnz near .rposoffy.nextposy    mov cl,[.mode7yrpos+1]    mov eax,[.mode7xadder]    mov ch,[.mode7xrpos+1]    add [.mode7xrpos],eax    mov dl,[mode7tab+ecx]    mov eax,[.mode7yadder]    mov dl,[edi+edx]    sub [.mode7yrpos],eax    %1    add esi,2    add ebp,2    dec byte[.temp]    jnz near .nextval    jmp .finishmode7.rposoffx    mov al,[.mode7xinc]    mov edi,[vram]    add [.mode7ptr],al    mov ebx,[.mode7ptr]    xor ecx,ecx    mov cl,[edi+ebx]    mov eax,[.mode7xadd2]    shl ecx,7    sub [.mode7xrpos],eax    add edi,ecx    jmp .nextposx.rposoffy    mov al,[.mode7yinc]    mov edi,[vram]    sub [.mode7ptr+1],al    and byte[.mode7ptr+1],7Fh    mov ebx,[.mode7ptr]    xor ecx,ecx    mov cl,[edi+ebx]    mov eax,[.mode7yadd2]    shl ecx,7    add [.mode7yrpos],eax    add edi,ecx    jmp .nextposy.finishmode7    xor eax,eax    mov dh,[curmosaicsz]    cmp dh,1    jne near domosaic16b    ret;**********************************************************; Mode 7, no repetition mode;**********************************************************.norep2    test byte[mode7set],40h    jnz .tilerep2.nextvalb2    cmp byte[.mode7ypos+2],3    ja .offscr2    cmp byte[.mode7xpos+2],3    jbe near .offscr3.offscr2    mov eax,[.mode7xadder]    mov ebx,[.mode7yadder]    add [.mode7xpos],eax    sub [.mode7ypos],ebx    add esi,2    add ebp,2    dec byte[.temp]    jnz near .nextvalb2    jmp .finishmode7.tilerep2.nextvalb3    cmp byte[.mode7ypos+2],3    ja .offscr2b    cmp byte[.mode7xpos+2],3    jbe near .offscr3.offscr2b    mov ch,[.mode7xpos+1]    mov eax,[.mode7xadder]    mov cl,[.mode7ypos+1]    mov ebx,[.mode7yadder]    mov dl,[mode7tab+ecx]    add [.mode7xpos],eax    mov dl,[vrama+edx]    sub [.mode7ypos],ebx    %1    add esi,2    add ebp,2    dec byte[.temp]    jnz near .nextvalb3    jmp .finishmode7.offscr3    mov eax,[.mode7xpos]    and eax,7FFh    mov [.mode7xrpos],eax    mov eax,[.mode7ypos]    and eax,7FFh    mov [.mode7yrpos],eax    ; get tile data offset into edi    mov ebx,[.mode7ypos+1]    mov eax,[.mode7xpos+1]    shl ebx,5    shr eax,3    and ebx,07FF8h    shl al,1    mov bl,al    mov edi,[vram]    xor ch,ch    mov [.mode7ptr],ebx    mov cl,[edi+ebx]    shl ecx,7    add edi,ecx.nextvalr    test byte[.mode7xrpos+1],08h    jnz near .rposoffxr.nextposxr    test byte[.mode7yrpos+1],08h    jnz near .rposoffyr.nextposyr    mov cl,[.mode7yrpos+1]    mov eax,[.mode7xadder]    mov ch,[.mode7xrpos+1]    add [.mode7xrpos],eax    mov dl,[mode7tab+ecx]    mov eax,[.mode7yadder]    mov dl,[edi+edx]    sub [.mode7yrpos],eax    %1    add esi,2    add ebp,2    dec byte[.temp]    jnz near .nextvalr    jmp .finishmode7.rposoffxr    mov al,[.mode7xinc]    mov edi,[vram]    add [.mode7ptr],al    jz .roff    cmp byte[.mode7ptr],0FEh    je .roff.roffxretb    mov ebx,[.mode7ptr]    xor ecx,ecx    mov cl,[edi+ebx]    mov eax,[.mode7xadd2]    shl ecx,7    sub [.mode7xrpos],eax    add edi,ecx    jmp .nextposxr.rposoffyr    mov al,[.mode7yinc]    mov edi,[vram]    sub [.mode7ptr+1],al    js .roff.roffyretb    mov ebx,[.mode7ptr]    xor ecx,ecx    mov cl,[edi+ebx]    mov eax,[.mode7yadd2]    shl ecx,7    add [.mode7yrpos],eax    add edi,ecx    jmp .nextposyr.roff    test byte[mode7set],40h    jnz .tilerep3    jmp .finishmode7.tilerep3    and byte[.mode7yrpos+1],07h

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -