|
|
| version 1.14, 2005/03/18 06:49:17 | version 1.16, 2011/02/02 13:50:29 |
|---|---|
| Line 2 | Line 2 |
| ; | ; |
| ; ToDo: egc word-boundary | ; ToDo: egc word-boundary |
| %include 'x86/np2asm.inc' | %include 'np2asm.inc' |
| %include '../io/x86/iocore.inc' | %include 'cpucore.inc' |
| %include 'iocore.inc' | |
| %include 'vram.inc' | |
| section .bss | section .bss |
| Line 21 EXTMEMORY equ 0 | Line 23 EXTMEMORY equ 0 |
| VIDEOMEMORY equ _mem | VIDEOMEMORY equ _mem |
| USERSMEMORY_R equ 0a8000h | USERSMEMORY_R equ 0a8000h |
| USERSMEMORY_W equ 0a0000h | USERSMEMORY_W equ 0a0000h |
| _extmemmng_ptr equ _i286core + i286core_t.ext | _extmemmng_ptr equ _i286core + cpucore_t.ext |
| _extmemmng_size equ _i286core + i286core_t.extsize | _extmemmng_size equ _i286core + cpucore_t.extsize |
| %if 1 | %if 1 |
| _font equ _mem + FONT_ADRS | _font equ _mem + FONT_ADRS |
| Line 94 section .text | Line 96 section .text |
| ; normal memory | ; normal memory |
| align 16 | align 16 |
| @i286_wt: mov ebx, ecx | @i286_wt: mov ebx, ecx |
| and ebx, [_i286core + i286core_t.adrsmask] | and ebx, [_i286core + cpucore_t.adrsmask] |
| mov [MAINMEMORY + ebx], dl | mov [MAINMEMORY + ebx], dl |
| pop ebx | pop ebx |
| ret | ret |
| Line 102 section .text | Line 104 section .text |
| ; tram write | ; tram write |
| align 16 | align 16 |
| @tram_wt: mov ebx, [_vramop + vramop_t.tramwait] | @tram_wt: mov ebx, [_vramop + vramop_t.tramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| mov ebx, ecx | mov ebx, ecx |
| cmp ecx, 000a2000h | cmp ecx, 000a2000h |
| jnc short wtram_a | jnc short wtram_a |
| Line 153 wcgwindow_e: pop ebx | Line 155 wcgwindow_e: pop ebx |
| or byte [_vramupdate + ebx], 1 | or byte [_vramupdate + ebx], 1 |
| or byte [_gdcs + gdcs_t.grphdisp], 1 | or byte [_gdcs + gdcs_t.grphdisp], 1 |
| mov ebx, [_vramop + vramop_t.vramwait] | mov ebx, [_vramop + vramop_t.vramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| ret | ret |
| Line 165 wcgwindow_e: pop ebx | Line 167 wcgwindow_e: pop ebx |
| or byte [_vramupdate + ebx], 2 | or byte [_vramupdate + ebx], 2 |
| or byte [_gdcs + gdcs_t.grphdisp], 2 | or byte [_gdcs + gdcs_t.grphdisp], 2 |
| mov ebx, [_vramop + vramop_t.vramwait] | mov ebx, [_vramop + vramop_t.vramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| ret | ret |
| Line 186 wcgwindow_e: pop ebx | Line 188 wcgwindow_e: pop ebx |
| or byte [_gdcs + gdcs_t.grphdisp], 1 | or byte [_gdcs + gdcs_t.grphdisp], 1 |
| grcg_rmw: mov ebx, [_vramop + vramop_t.grcgwait] | grcg_rmw: mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| mov ebx, dword [_grcg + grcg_t.mode] | mov ebx, dword [_grcg + grcg_t.mode] |
| mov bl, dl | mov bl, dl |
| not bl | not bl |
| Line 235 grcgrmw_end: pop ecx | Line 237 grcgrmw_end: pop ecx |
| or byte [_gdcs + gdcs_t.grphdisp], 1 | or byte [_gdcs + gdcs_t.grphdisp], 1 |
| grcg_tdw: mov ebx, [_vramop + vramop_t.grcgwait] | grcg_tdw: mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| mov bh, [_grcg + grcg_t.modereg] | mov bh, [_grcg + grcg_t.modereg] |
| shr bh, 1 | shr bh, 1 |
| jc short grcgtdw_r | jc short grcgtdw_r |
| Line 261 grcgtdw_end: pop ecx | Line 263 grcgtdw_end: pop ecx |
| align 16 | align 16 |
| @egc_wt: VRAMTRACE | @egc_wt: VRAMTRACE |
| mov ebx, [_vramop + vramop_t.grcgwait] | mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| %if USE_EGCASM | %if USE_EGCASM |
| jmp egc_write | jmp egc_write |
| Line 279 grcgtdw_end: pop ecx | Line 281 grcgtdw_end: pop ecx |
| and ecx, 3fffh | and ecx, 3fffh |
| shr ebx, 12 | shr ebx, 12 |
| and ebx, byte (3*4) | and ebx, byte (3*4) |
| add ecx, [_i286core + i286core_t.ems + ebx] | add ecx, [_i286core + cpucore_t.ems + ebx] |
| mov [EXTMEMORY + ecx], dl | mov [EXTMEMORY + ecx], dl |
| pop ecx | pop ecx |
| pop ebx | pop ebx |
| Line 300 grcgtdw_end: pop ecx | Line 302 grcgtdw_end: pop ecx |
| ; normal memory | ; normal memory |
| align 16 | align 16 |
| @i286_rd: mov ebx, ecx | @i286_rd: mov ebx, ecx |
| and ebx, [_i286core + i286core_t.adrsmask] | and ebx, [_i286core + cpucore_t.adrsmask] |
| mov al, [MAINMEMORY + ebx] | mov al, [MAINMEMORY + ebx] |
| pop ebx | pop ebx |
| ret | ret |
| Line 308 grcgtdw_end: pop ecx | Line 310 grcgtdw_end: pop ecx |
| ; font cg-window | ; font cg-window |
| align 16 | align 16 |
| @tram_rd: mov ebx, [_vramop + vramop_t.tramwait] | @tram_rd: mov ebx, [_vramop + vramop_t.tramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| cmp ecx, 0a4000h | cmp ecx, 0a4000h |
| jnc rcgwindow_s | jnc rcgwindow_s |
| rcgwindow_n: mov al, [MAINMEMORY + ecx] | rcgwindow_n: mov al, [MAINMEMORY + ecx] |
| Line 331 rcgwindow_s: cmp ecx, 0a5000h | Line 333 rcgwindow_s: cmp ecx, 0a5000h |
| align 16 | align 16 |
| @vram_r0: mov al, [VIDEOMEMORY + ecx] | @vram_r0: mov al, [VIDEOMEMORY + ecx] |
| mov ebx, [_vramop + vramop_t.vramwait] | mov ebx, [_vramop + vramop_t.vramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| ret | ret |
| Line 339 rcgwindow_s: cmp ecx, 0a5000h | Line 341 rcgwindow_s: cmp ecx, 0a5000h |
| align 16 | align 16 |
| @vram_r1: mov al, [VIDEOMEMORY + VRAM_STEP + ecx] | @vram_r1: mov al, [VIDEOMEMORY + VRAM_STEP + ecx] |
| mov ebx, [_vramop + vramop_t.vramwait] | mov ebx, [_vramop + vramop_t.vramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| ret | ret |
| Line 354 rcgwindow_s: cmp ecx, 0a5000h | Line 356 rcgwindow_s: cmp ecx, 0a5000h |
| and ecx, 7fffh | and ecx, 7fffh |
| grcg_tcr: mov ebx, [_vramop + vramop_t.grcgwait] | grcg_tcr: mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| mov al, 0 | mov al, 0 |
| mov bh, [_grcg + grcg_t.modereg] | mov bh, [_grcg + grcg_t.modereg] |
| shr bh, 1 | shr bh, 1 |
| Line 384 grcgtcr_end: not al | Line 386 grcgtcr_end: not al |
| ; EGC bridge | ; EGC bridge |
| align 16 | align 16 |
| @egc_rd: mov ebx, [_vramop + vramop_t.grcgwait] | @egc_rd: mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| %if USE_EGCASM | %if USE_EGCASM |
| jmp egc_read | jmp egc_read |
| Line 404 grcgtcr_end: not al | Line 406 grcgtcr_end: not al |
| and ecx, 3fffh | and ecx, 3fffh |
| shr ebx, 12 | shr ebx, 12 |
| and ebx, byte (3*4) | and ebx, byte (3*4) |
| add ecx, [_i286core + i286core_t.ems + ebx] | add ecx, [_i286core + cpucore_t.ems + ebx] |
| mov al, [EXTMEMORY + ecx] | mov al, [EXTMEMORY + ecx] |
| pop ecx | pop ecx |
| pop ebx | pop ebx |
| Line 413 grcgtcr_end: not al | Line 415 grcgtcr_end: not al |
| ; BIOS or ITF | ; BIOS or ITF |
| align 16 | align 16 |
| @i286_rb: pop ebx | @i286_rb: pop ebx |
| cmp byte [_i286core + i286core_t.itfbank], 0 | cmp byte [_i286core + cpucore_t.itfbank], 0 |
| jne readmem_itf | jne readmem_itf |
| mov al, [MAINMEMORY + ecx] | mov al, [MAINMEMORY + ecx] |
| ret | ret |
| Line 425 readmem_itf: mov al, [MAINMEMORY + VRA | Line 427 readmem_itf: mov al, [MAINMEMORY + VRA |
| ; normal memory | ; normal memory |
| align 16 | align 16 |
| @i286w_wt: mov ebx, ecx | @i286w_wt: mov ebx, ecx |
| and ebx, [_i286core + i286core_t.adrsmask] | and ebx, [_i286core + cpucore_t.adrsmask] |
| mov [MAINMEMORY + ebx], dx | mov [MAINMEMORY + ebx], dx |
| pop ebx | pop ebx |
| ret | ret |
| Line 433 readmem_itf: mov al, [MAINMEMORY + VRA | Line 435 readmem_itf: mov al, [MAINMEMORY + VRA |
| ; tram write | ; tram write |
| align 16 | align 16 |
| @tramw_wt: mov ebx, [_vramop + vramop_t.tramwait] | @tramw_wt: mov ebx, [_vramop + vramop_t.tramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| mov ebx, ecx | mov ebx, ecx |
| cmp ecx, 000a1fffh | cmp ecx, 000a1fffh |
| jnc short wtramw_a | jnc short wtramw_a |
| Line 510 wcgwinw_odd: add ebx, dword [_cgwindow | Line 512 wcgwinw_odd: add ebx, dword [_cgwindow |
| or word [_vramupdate + ebx], 0101h | or word [_vramupdate + ebx], 0101h |
| or byte [_gdcs + gdcs_t.grphdisp], 1 | or byte [_gdcs + gdcs_t.grphdisp], 1 |
| mov ebx, [_vramop + vramop_t.vramwait] | mov ebx, [_vramop + vramop_t.vramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| ret | ret |
| Line 522 wcgwinw_odd: add ebx, dword [_cgwindow | Line 524 wcgwinw_odd: add ebx, dword [_cgwindow |
| or word [_vramupdate + ebx], 0202h | or word [_vramupdate + ebx], 0202h |
| or byte [_gdcs + gdcs_t.grphdisp], 2 | or byte [_gdcs + gdcs_t.grphdisp], 2 |
| mov ebx, [_vramop + vramop_t.vramwait] | mov ebx, [_vramop + vramop_t.vramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| ret | ret |
| Line 543 wcgwinw_odd: add ebx, dword [_cgwindow | Line 545 wcgwinw_odd: add ebx, dword [_cgwindow |
| or byte [_gdcs + gdcs_t.grphdisp], 1 | or byte [_gdcs + gdcs_t.grphdisp], 1 |
| grcgw_rmw: mov ebx, [_vramop + vramop_t.grcgwait] | grcgw_rmw: mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| push eax | push eax |
| mov ebx, dword [_grcg + grcg_t.mode] | mov ebx, dword [_grcg + grcg_t.mode] |
| mov bx, dx | mov bx, dx |
| Line 594 grcgwrmw_end: pop eax | Line 596 grcgwrmw_end: pop eax |
| or byte [_gdcs + gdcs_t.grphdisp], 1 | or byte [_gdcs + gdcs_t.grphdisp], 1 |
| grcgw_tdw: mov ebx, [_vramop + vramop_t.grcgwait] | grcgw_tdw: mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| mov ebx, [_grcg + grcg_t.mode] | mov ebx, [_grcg + grcg_t.mode] |
| test ebx, 010000h | test ebx, 010000h |
| jne short grcgwtdw_r | jne short grcgwtdw_r |
| Line 620 grcgwtdw_end: pop ecx | Line 622 grcgwtdw_end: pop ecx |
| align 16 | align 16 |
| @egcw_wt: VRAMTRACE_W | @egcw_wt: VRAMTRACE_W |
| mov ebx, [_vramop + vramop_t.grcgwait] | mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| %if USE_EGCASM | %if USE_EGCASM |
| jmp egc_write_w | jmp egc_write_w |
| Line 638 grcgwtdw_end: pop ecx | Line 640 grcgwtdw_end: pop ecx |
| and ecx, 3fffh | and ecx, 3fffh |
| shr ebx, 12 | shr ebx, 12 |
| and ebx, byte (3*4) | and ebx, byte (3*4) |
| add ecx, [_i286core + i286core_t.ems + ebx] | add ecx, [_i286core + cpucore_t.ems + ebx] |
| mov [EXTMEMORY + ecx], dx | mov [EXTMEMORY + ecx], dx |
| pop ecx | pop ecx |
| pop ebx | pop ebx |
| Line 653 grcgwtdw_end: pop ecx | Line 655 grcgwtdw_end: pop ecx |
| ; normal memory | ; normal memory |
| align 16 | align 16 |
| @i286w_rd: mov ebx, ecx | @i286w_rd: mov ebx, ecx |
| and ebx, [_i286core + i286core_t.adrsmask] | and ebx, [_i286core + cpucore_t.adrsmask] |
| mov ax, [MAINMEMORY + ebx] | mov ax, [MAINMEMORY + ebx] |
| pop ebx | pop ebx |
| ret | ret |
| Line 661 grcgwtdw_end: pop ecx | Line 663 grcgwtdw_end: pop ecx |
| ; font cg-window | ; font cg-window |
| align 16 | align 16 |
| @tramw_rd: mov ebx, [_vramop + vramop_t.tramwait] | @tramw_rd: mov ebx, [_vramop + vramop_t.tramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| cmp ecx, 0a3fffh | cmp ecx, 0a3fffh |
| jnc rcgwwindow_s | jnc rcgwwindow_s |
| mov ax, [MAINMEMORY + ecx] | mov ax, [MAINMEMORY + ecx] |
| Line 715 rcgwwindow_a4fff: mov ebx, dword [_cgwi | Line 717 rcgwwindow_a4fff: mov ebx, dword [_cgwi |
| align 16 | align 16 |
| @vramw_r0: mov ax, [VIDEOMEMORY + ecx] | @vramw_r0: mov ax, [VIDEOMEMORY + ecx] |
| mov ebx, [_vramop + vramop_t.vramwait] | mov ebx, [_vramop + vramop_t.vramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| ret | ret |
| Line 723 rcgwwindow_a4fff: mov ebx, dword [_cgwi | Line 725 rcgwwindow_a4fff: mov ebx, dword [_cgwi |
| align 16 | align 16 |
| @vramw_r1: mov ax, [VIDEOMEMORY + VRAM_STEP + ecx] | @vramw_r1: mov ax, [VIDEOMEMORY + VRAM_STEP + ecx] |
| mov ebx, [_vramop + vramop_t.vramwait] | mov ebx, [_vramop + vramop_t.vramwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| ret | ret |
| Line 738 rcgwwindow_a4fff: mov ebx, dword [_cgwi | Line 740 rcgwwindow_a4fff: mov ebx, dword [_cgwi |
| and ecx, 7fffh | and ecx, 7fffh |
| grcgw_tcr: mov ebx, [_vramop + vramop_t.grcgwait] | grcgw_tcr: mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| mov ax, 0 | mov ax, 0 |
| mov ebx, [_grcg + grcg_t.mode] | mov ebx, [_grcg + grcg_t.mode] |
| test ebx, 010000h | test ebx, 010000h |
| Line 768 grcgwtcr_end: not ax | Line 770 grcgwtcr_end: not ax |
| ; EGC bridge | ; EGC bridge |
| align 16 | align 16 |
| @egcw_rd: mov ebx, [_vramop + vramop_t.grcgwait] | @egcw_rd: mov ebx, [_vramop + vramop_t.grcgwait] |
| sub [_i286core + i286core_t.remainclock], ebx | sub [_i286core + cpucore_t.remainclock], ebx |
| pop ebx | pop ebx |
| %if USE_EGCASM | %if USE_EGCASM |
| jmp egc_read_w | jmp egc_read_w |
| Line 788 grcgwtcr_end: not ax | Line 790 grcgwtcr_end: not ax |
| and ecx, 3fffh | and ecx, 3fffh |
| shr ebx, 12 | shr ebx, 12 |
| and ebx, byte (3*4) | and ebx, byte (3*4) |
| add ecx, [_i286core + i286core_t.ems + ebx] | add ecx, [_i286core + cpucore_t.ems + ebx] |
| mov ax, [EXTMEMORY + ecx] | mov ax, [EXTMEMORY + ecx] |
| pop ecx | pop ecx |
| pop ebx | pop ebx |
| Line 797 grcgwtcr_end: not ax | Line 799 grcgwtcr_end: not ax |
| ; BIOS or ITF | ; BIOS or ITF |
| align 16 | align 16 |
| @i286w_rb: pop ebx | @i286w_rb: pop ebx |
| cmp byte [_i286core + i286core_t.itfbank], 0 | cmp byte [_i286core + cpucore_t.itfbank], 0 |
| jne readwmem_itf | jne readwmem_itf |
| mov ax, [MAINMEMORY + ecx] | mov ax, [MAINMEMORY + ecx] |
| ret | ret |
| Line 1341 memxwrite_lp: mov dl, [esi] | Line 1343 memxwrite_lp: mov dl, [esi] |
| memxwrite_ed: pop ebx | memxwrite_ed: pop ebx |
| ret 4 | ret 4 |
| ends | |