|
|
| version 1.4, 2003/12/08 00:55:31 | version 1.10, 2004/01/28 23:36:13 |
|---|---|
| Line 6 | Line 6 |
| section .bss | section .bss |
| extern _mem | global _mem |
| extern _i286core | extern _i286core |
| extern _grcg | extern _grcg |
| extern _extmem | |
| extern _gdcs | extern _gdcs |
| extern _tramupdate | extern _tramupdate |
| extern _vramupdate | extern _vramupdate |
| extern _cgwindow | extern _cgwindow |
| ; extern ___font | |
| extern _vramop | extern _vramop |
| _mem resb 0x200000 | |
| MAINMEMORY equ _mem | MAINMEMORY equ _mem |
| EXTMEMORY equ 0 | EXTMEMORY equ 0 |
| Line 76 extern @tracevramwrite_w@8 | Line 76 extern @tracevramwrite_w@8 |
| %endmacro | %endmacro |
| %endif | %endif |
| section .text | section .text |
| ; ----------------------------------------------------------------- write byte | ; ----------------------------------------------------------------- write byte |
| Line 121 wtram_a: cmp ecx, 000a3fe0h | Line 120 wtram_a: cmp ecx, 000a3fe0h |
| jc short wtram_m | jc short wtram_m |
| cmp ecx, 000a4000h | cmp ecx, 000a4000h |
| jnc wcgwindow_s | jnc wcgwindow_s |
| test ecx, 2 | |
| je short wtram_m | |
| cmp byte [_gdcs + gdcs_t.msw_accessable], 0 | cmp byte [_gdcs + gdcs_t.msw_accessable], 0 |
| je short wtram_e | je short wtram_e |
| wtram_m: shr ebx, 1 | wtram_m: shr ebx, 1 |
| Line 263 grcgtdw_end: pop ecx | Line 264 grcgtdw_end: pop ecx |
| @egc_wt: VRAMTRACE | @egc_wt: VRAMTRACE |
| pop ebx | pop ebx |
| %if USE_EGCASM | %if USE_EGCASM |
| jmp _egca_write ; ver0.26 | jmp _egca_write |
| %else | %else |
| pushad | pushad |
| call @egc_write@8 | call @egc_write@8 |
| Line 278 grcgtdw_end: pop ecx | Line 279 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, [_extmem + extmem_t.pageptr + ebx] | add ecx, [_i286core + i286core_t.ems + ebx] |
| mov [EXTMEMORY + ecx], dl ; ver0.28 | mov [EXTMEMORY + ecx], dl |
| pop ecx | pop ecx |
| pop ebx | pop ebx |
| ret | ret |
| @i286_wb: mov [MAINMEMORY + 1c8000h - 0e8000h + ecx], dl | |
| pop ebx | |
| ret | |
| ; non writable memory | ; non writable memory |
| align 16 | align 16 |
| @i286_wn: pop ebx | @i286_wn: pop ebx |
| Line 380 grcgtcr_end: not al | Line 385 grcgtcr_end: not al |
| align 16 | align 16 |
| @egc_rd: pop ebx | @egc_rd: pop ebx |
| %if USE_EGCASM | %if USE_EGCASM |
| jmp _egca_read ; ver0.26 | jmp _egca_read |
| %else | %else |
| pushad | pushad |
| call @egc_read@4 | call @egc_read@4 |
| Line 397 grcgtcr_end: not al | Line 402 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, [_extmem + extmem_t.pageptr + ebx] | add ecx, [_i286core + i286core_t.ems + ebx] |
| mov al, [EXTMEMORY + ecx] ; ver0.28 | mov al, [EXTMEMORY + ecx] |
| pop ecx | pop ecx |
| pop ebx | pop ebx |
| ret | ret |
| ; BIOS or ITF | ; BIOS or ITF |
| align 16 | align 16 |
| @i286_itf: cmp byte [_i286core + i286core_t.itfbank], 0 | @i286_rb: pop ebx |
| jne readmem_itr | cmp byte [_i286core + i286core_t.itfbank], 0 |
| jne readmem_itf | |
| mov al, [MAINMEMORY + ecx] | mov al, [MAINMEMORY + ecx] |
| pop ebx | |
| ret | ret |
| align 16 | readmem_itf: mov al, [MAINMEMORY + VRAM_STEP + ecx] |
| readmem_itr: mov ebx, ecx | |
| and ebx, 00007fffh | |
| mov al, [MAINMEMORY + ITF_ADRS + ebx] | |
| pop ebx | |
| ret | ret |
| ; ----------------------------------------------------------------- write word | ; ----------------------------------------------------------------- write word |
| Line 453 wtramw_a: je short wword_a1fffh | Line 454 wtramw_a: je short wword_a1fffh |
| jc short wtramw_m | jc short wtramw_m |
| cmp ecx, 000a3fffh | cmp ecx, 000a3fffh |
| jnc wcgwindoww_s | jnc wcgwindoww_s |
| test ecx, 2 | |
| je short wtramw_m | |
| cmp byte [_gdcs + gdcs_t.msw_accessable], 0 | cmp byte [_gdcs + gdcs_t.msw_accessable], 0 |
| je short wtramw_e | je short wtramw_e |
| wtramw_m: and ebx, 1fffh | wtramw_m: and ebx, 1fffh |
| Line 616 grcgwtdw_end: pop ecx | Line 619 grcgwtdw_end: pop ecx |
| @egcw_wt: VRAMTRACE_W | @egcw_wt: VRAMTRACE_W |
| pop ebx | pop ebx |
| %if USE_EGCASM | %if USE_EGCASM |
| jmp _egca_write_w ; ver0.26 | jmp _egca_write_w |
| %else | %else |
| test ecx, 1 | test ecx, 1 |
| jne short egcw_wtodd | jne short egcw_wtodd |
| Line 645 egcw_wtodd: | Line 648 egcw_wtodd: |
| and ecx, 3fffh | and ecx, 3fffh |
| shr ebx, 12 | shr ebx, 12 |
| and ebx, byte (3*4) | and ebx, byte (3*4) |
| add ecx, [_extmem + extmem_t.pageptr + ebx] | add ecx, [_i286core + i286core_t.ems + ebx] |
| mov [EXTMEMORY + ecx], dx ; ver0.28 | mov [EXTMEMORY + ecx], dx |
| pop ecx | pop ecx |
| pop ebx | pop ebx |
| ret | ret |
| @i286w_wb: mov [MAINMEMORY + 1c8000h - 0e8000h + ecx], dx | |
| pop ebx | |
| ret | |
| ; ------------------------------------------------------------------ read word | ; ------------------------------------------------------------------ read word |
| ; normal memory | ; normal memory |
| Line 774 grcgwtcr_end: not ax | Line 781 grcgwtcr_end: not ax |
| test ecx, 1 | test ecx, 1 |
| jne short egcw_rdodd | jne short egcw_rdodd |
| %if USE_EGCASM | %if USE_EGCASM |
| jmp _egca_read_w ; ver0.26 | jmp _egca_read_w |
| %else | %else |
| pushad | pushad |
| call @egc_read_w@4 | call @egc_read_w@4 |
| Line 784 grcgwtcr_end: not ax | Line 791 grcgwtcr_end: not ax |
| %endif | %endif |
| egcw_rdodd: | egcw_rdodd: |
| %if USE_EGCASM ; ver0.26 | %if USE_EGCASM |
| inc ecx | inc ecx |
| call _egca_read | call _egca_read |
| mov ah, al | mov ah, al |
| Line 810 egcw_rdodd: | Line 817 egcw_rdodd: |
| and ecx, 3fffh | and ecx, 3fffh |
| shr ebx, 12 | shr ebx, 12 |
| and ebx, byte (3*4) | and ebx, byte (3*4) |
| add ecx, [_extmem + extmem_t.pageptr + ebx] | add ecx, [_i286core + i286core_t.ems + ebx] |
| mov ax, [EXTMEMORY + ecx] ; ver0.28 | mov ax, [EXTMEMORY + ecx] |
| pop ecx | pop ecx |
| pop ebx | pop ebx |
| ret | ret |
| ; BIOS or ITF | ; BIOS or ITF |
| align 16 | align 16 |
| @i286w_itf: cmp byte [_i286core + i286core_t.itfbank], 0 | @i286w_rb: pop ebx |
| jne readwmem_itr | cmp byte [_i286core + i286core_t.itfbank], 0 |
| jne readwmem_itf | |
| mov ax, [MAINMEMORY + ecx] | mov ax, [MAINMEMORY + ecx] |
| pop ebx | |
| ret | ret |
| align 16 | readwmem_itf: mov ax, [MAINMEMORY + VRAM_STEP + ecx] |
| readwmem_itr: mov ebx, ecx | |
| and ebx, 00007fffh | |
| mov ax, [MAINMEMORY + ITF_ADRS + ebx] | |
| pop ebx | |
| ret | ret |
| section .data | section .data |
| ; ---------------------------------------------------------------------- table | ; ---------------------------------------------------------------------- table |
| global _memory_write | |
| global _memory_read | global _memory_read |
| global _memory_write | |
| _memory_read dd @i286_rd, @i286_rd ; 00 | |
| dd @i286_rd, @i286_rd ; 10 | |
| dd @i286_rd, @i286_rd ; 20 | |
| dd @i286_rd, @i286_rd ; 30 | |
| dd @i286_rd, @i286_rd ; 40 | |
| dd @i286_rd, @i286_rd ; 50 | |
| dd @i286_rd, @i286_rd ; 60 | |
| dd @i286_rd, @i286_rd ; 70 | |
| dd @i286_rd, @i286_rd ; 80 | |
| dd @i286_rd, @i286_rd ; 90 | |
| dd @tram_rd, @vram_r0 ; a0 | |
| dd @vram_r0, @vram_r0 ; b0 | |
| dd @emmc_rd, @emmc_rd ; c0 | |
| dd @i286_rd, @i286_rd ; d0 | |
| dd @vram_r0, @i286_rd ; e0 | |
| dd @i286_rd, @i286_rb ; f0 | |
| _memory_write dd @i286_wt, @i286_wt ; 00 | _memory_write dd @i286_wt, @i286_wt ; 00 |
| dd @i286_wt, @i286_wt ; 10 | dd @i286_wt, @i286_wt ; 10 |
| Line 854 _memory_write dd @i286_wt, @i286_wt ; | Line 875 _memory_write dd @i286_wt, @i286_wt ; |
| dd @vram_w0, @i286_wn ; e0 | dd @vram_w0, @i286_wn ; e0 |
| dd @i286_wn, @i286_wn ; f0 | dd @i286_wn, @i286_wn ; f0 |
| _memory_read dd @i286_rd, @i286_rd ; 00 | _memword_read dd @i286w_rd, @i286w_rd ; 00 |
| dd @i286_rd, @i286_rd ; 10 | dd @i286w_rd, @i286w_rd ; 10 |
| dd @i286_rd, @i286_rd ; 20 | dd @i286w_rd, @i286w_rd ; 20 |
| dd @i286_rd, @i286_rd ; 30 | dd @i286w_rd, @i286w_rd ; 30 |
| dd @i286_rd, @i286_rd ; 40 | dd @i286w_rd, @i286w_rd ; 40 |
| dd @i286_rd, @i286_rd ; 50 | dd @i286w_rd, @i286w_rd ; 50 |
| dd @i286_rd, @i286_rd ; 60 | dd @i286w_rd, @i286w_rd ; 60 |
| dd @i286_rd, @i286_rd ; 70 | dd @i286w_rd, @i286w_rd ; 70 |
| dd @i286_rd, @i286_rd ; 80 | dd @i286w_rd, @i286w_rd ; 80 |
| dd @i286_rd, @i286_rd ; 90 | dd @i286w_rd, @i286w_rd ; 90 |
| dd @tram_rd, @vram_r0 ; a0 | dd @tramw_rd, @vramw_r0 ; a0 |
| dd @vram_r0, @vram_r0 ; b0 | dd @vramw_r0, @vramw_r0 ; b0 |
| dd @emmc_rd, @emmc_rd ; c0 | dd @emmcw_rd, @emmcw_rd ; c0 |
| dd @i286_rd, @i286_rd ; d0 | dd @i286w_rd, @i286w_rd ; d0 |
| dd @vram_r0, @i286_rd ; e0 | dd @vramw_r0, @i286w_rd ; e0 |
| dd @i286_rd, @i286_itf ; f0 | dd @i286w_rd, @i286w_rb ; f0 |
| _memword_write dd @i286w_wt, @i286w_wt ; 00 | _memword_write dd @i286w_wt, @i286w_wt ; 00 |
| dd @i286w_wt, @i286w_wt ; 10 | dd @i286w_wt, @i286w_wt ; 10 |
| Line 888 _memword_write dd @i286w_wt, @i286w_wt | Line 909 _memword_write dd @i286w_wt, @i286w_wt |
| dd @vramw_w0, @i286_wn ; e0 | dd @vramw_w0, @i286_wn ; e0 |
| dd @i286_wn, @i286_wn ; f0 | dd @i286_wn, @i286_wn ; f0 |
| _memword_read dd @i286w_rd, @i286w_rd ; 00 | section .rdata |
| dd @i286w_rd, @i286w_rd ; 10 | |
| dd @i286w_rd, @i286w_rd ; 20 | |
| dd @i286w_rd, @i286w_rd ; 30 | |
| dd @i286w_rd, @i286w_rd ; 40 | |
| dd @i286w_rd, @i286w_rd ; 50 | |
| dd @i286w_rd, @i286w_rd ; 60 | |
| dd @i286w_rd, @i286w_rd ; 70 | |
| dd @i286w_rd, @i286w_rd ; 80 | |
| dd @i286w_rd, @i286w_rd ; 90 | |
| dd @tramw_rd, @vramw_r0 ; a0 | |
| dd @vramw_r0, @vramw_r0 ; b0 | |
| dd @emmcw_rd, @emmcw_rd ; c0 | |
| dd @i286w_rd, @i286w_rd ; d0 | |
| dd @vramw_r0, @i286w_rd ; e0 | |
| dd @i286w_rd, @i286w_itf ; f0 | |
| _vram_write dd @vram_w0, @vram_w1 ; 00 | memmap dd @i286_rd, @i286_rb ; NEC |
| dd @vram_w0, @vram_w1 | dd @i286_wn, @i286_wn |
| dd @vram_w0, @vram_w1 ; 40 | dd @i286w_rd, @i286w_rb |
| dd @vram_w0, @vram_w1 | dd @i286_wn, @i286_wn |
| dd @grcg_tdw0, @grcg_tdw1 ; 80 tdw/tcr | |
| dd @egc_wt, @egc_wt | |
| dd @grcg_rmw0, @grcg_rmw1 ; c0 rmw | |
| dd @egc_wt, @egc_wt | |
| _vram_read dd @vram_r0, @vram_r1 ; 00 | dd @i286_rb, @i286_rb ; EPSON |
| dd @i286_wt, @i286_wb | |
| dd @i286w_rb, @i286w_rb | |
| dd @i286w_wt, @i286w_wb | |
| vram_read dd @vram_r0, @vram_r1 ; 00 | |
| dd @vram_r0, @vram_r1 | dd @vram_r0, @vram_r1 |
| dd @vram_r0, @vram_r1 ; 40 | dd @vram_r0, @vram_r1 ; 40 |
| dd @vram_r0, @vram_r1 | dd @vram_r0, @vram_r1 |
| Line 923 _vram_read dd @vram_r0, @vram_r1 ; 00 | Line 931 _vram_read dd @vram_r0, @vram_r1 ; 00 |
| dd @vram_r0, @vram_r1 ; c0 rmw | dd @vram_r0, @vram_r1 ; c0 rmw |
| dd @egc_rd, @egc_rd | dd @egc_rd, @egc_rd |
| _vramw_write dd @vramw_w0, @vramw_w1 ; 00 | vram_write dd @vram_w0, @vram_w1 ; 00 |
| dd @vramw_w0, @vramw_w1 | dd @vram_w0, @vram_w1 |
| dd @vramw_w0, @vramw_w1 ; 40 | dd @vram_w0, @vram_w1 ; 40 |
| dd @vramw_w0, @vramw_w1 | dd @vram_w0, @vram_w1 |
| dd @grcgw_tdw0, @grcgw_tdw1 ; 80 tdw/tcr | dd @grcg_tdw0, @grcg_tdw1 ; 80 tdw/tcr |
| dd @egcw_wt, @egcw_wt | dd @egc_wt, @egc_wt |
| dd @grcgw_rmw0, @grcgw_rmw1 ; c0 rmw | dd @grcg_rmw0, @grcg_rmw1 ; c0 rmw |
| dd @egcw_wt, @egcw_wt | dd @egc_wt, @egc_wt |
| _vramw_read dd @vramw_r0, @vramw_r1 ; 00 | vramw_read dd @vramw_r0, @vramw_r1 ; 00 |
| dd @vramw_r0, @vramw_r1 | dd @vramw_r0, @vramw_r1 |
| dd @vramw_r0, @vramw_r1 ; 40 | dd @vramw_r0, @vramw_r1 ; 40 |
| dd @vramw_r0, @vramw_r1 | dd @vramw_r0, @vramw_r1 |
| Line 941 _vramw_read dd @vramw_r0, @vramw_r1 ; | Line 949 _vramw_read dd @vramw_r0, @vramw_r1 ; |
| dd @vramw_r0, @vramw_r1 ; c0 rmw | dd @vramw_r0, @vramw_r1 ; c0 rmw |
| dd @egcw_rd, @egcw_rd | dd @egcw_rd, @egcw_rd |
| vramw_write dd @vramw_w0, @vramw_w1 ; 00 | |
| dd @vramw_w0, @vramw_w1 | |
| dd @vramw_w0, @vramw_w1 ; 40 | |
| dd @vramw_w0, @vramw_w1 | |
| dd @grcgw_tdw0, @grcgw_tdw1 ; 80 tdw/tcr | |
| dd @egcw_wt, @egcw_wt | |
| dd @grcgw_rmw0, @grcgw_rmw1 ; c0 rmw | |
| dd @egcw_wt, @egcw_wt | |
| section .text | section .text |
| global @i286_memorymap@4 | |
| global @i286_vram_dispatch@4 | global @i286_vram_dispatch@4 |
| global @i286_memorywrite@8 | global @i286_memorywrite@8 |
| Line 969 section .text | Line 988 section .text |
| align 16 | align 16 |
| writeextmem_w: | writeextmem_w: |
| %if USE_HIMEM | %if USE_HIMEM |
| cmp ecx, 10ffefh ; HIMEM | cmp ecx, (USE_HIMEM - 1) |
| jae near writehimem_w | jae near writehimem_w |
| %endif | %endif |
| push ebx | push ebx |
| Line 1007 writemain_b: mov [MAINMEMORY + ecx], d | Line 1026 writemain_b: mov [MAINMEMORY + ecx], d |
| align 16 | align 16 |
| writeextmem_b: | writeextmem_b: |
| %if USE_HIMEM | %if USE_HIMEM |
| cmp ecx, 10fff0h ; HIMEM | cmp ecx, USE_HIMEM |
| jae near writehimem | jae near writehimem |
| %endif | %endif |
| push ebx | push ebx |
| Line 1024 writeextmem_b: | Line 1043 writeextmem_b: |
| align 16 | align 16 |
| readmemory_w: | readmemory_w: |
| %if USE_HIMEM | %if USE_HIMEM |
| cmp ecx, 10ffefh ; HIMEM | cmp ecx, (USE_HIMEM - 1) |
| jae near readhimem_w | jae near readhimem_w |
| %endif | %endif |
| push ebx | push ebx |
| Line 1059 readmain_b: mov al, [MAINMEMORY + ecx | Line 1078 readmain_b: mov al, [MAINMEMORY + ecx |
| align 16 | align 16 |
| readmemory_b: | readmemory_b: |
| %if USE_HIMEM | %if USE_HIMEM |
| cmp ecx, 10fff0h ; HIMEM | cmp ecx, USE_HIMEM |
| jae near readhimem | jae near readhimem |
| %endif | %endif |
| push ebx | push ebx |
| Line 1082 readmemory_b: | Line 1101 readmemory_b: |
| mov ax, 0ffffh | mov ax, 0ffffh |
| ret | ret |
| align 16 | |
| @i286_memorymap@4: and ecx, 1 | |
| shl ecx, 5 | |
| lea ecx, [memmap + ecx] | |
| mov edx, _memory_read | |
| mov eax, [ecx] | |
| mov [edx + 74h], eax | |
| mov [edx + 78h], eax | |
| mov eax, [ecx+4] | |
| mov [edx + 7ch], eax | |
| mov eax, [ecx+8] | |
| mov edx, _memory_write | |
| mov [edx + 68h], eax | |
| mov [edx + 6ch], eax | |
| mov eax, [ecx+12] | |
| mov [edx + 74h], eax | |
| mov [edx + 78h], eax | |
| mov [edx + 7ch], eax | |
| mov eax, [ecx+16] | |
| mov edx, _memword_read | |
| mov [edx + 74h], eax | |
| mov [edx + 78h], eax | |
| mov eax, [ecx+20] | |
| mov [edx + 7ch], eax | |
| mov eax, [ecx+24] | |
| mov edx, _memword_write | |
| mov [edx + 68h], eax | |
| mov [edx + 6ch], eax | |
| mov eax, [ecx+28] | |
| mov [edx + 74h], eax | |
| mov [edx + 78h], eax | |
| mov [edx + 7ch], eax | |
| ret | |
| align 16 | align 16 |
| @i286_vram_dispatch@4: | @i286_vram_dispatch@4: |
| mov edx, ecx | mov edx, ecx |
| and edx, byte 15 | and edx, byte 15 |
| mov eax, [_vram_write + edx*4] | mov eax, [vram_read + edx*4] |
| mov [_memory_write + 54h], eax ; VRAM_B | |
| mov [_memory_write + 58h], eax ; VRAM_R | |
| mov [_memory_write + 5ch], eax ; VRAM_G | |
| mov [_memory_write + 70h], eax ; VRAM_E | |
| mov eax, [_vram_read + edx*4] | |
| mov [_memory_read + 54h], eax ; VRAM_B | mov [_memory_read + 54h], eax ; VRAM_B |
| mov [_memory_read + 58h], eax ; VRAM_R | mov [_memory_read + 58h], eax ; VRAM_R |
| mov [_memory_read + 5ch], eax ; VRAM_G | mov [_memory_read + 5ch], eax ; VRAM_G |
| mov [_memory_read + 70h], eax ; VRAM_E | mov [_memory_read + 70h], eax ; VRAM_E |
| mov eax, [_vramw_write + edx*4] | mov eax, [vram_write + edx*4] |
| mov [_memword_write + 54h], eax ; VRAM_B | mov [_memory_write + 54h], eax ; VRAM_B |
| mov [_memword_write + 58h], eax ; VRAM_R | mov [_memory_write + 58h], eax ; VRAM_R |
| mov [_memword_write + 5ch], eax ; VRAM_G | mov [_memory_write + 5ch], eax ; VRAM_G |
| mov [_memword_write + 70h], eax ; VRAM_E | mov [_memory_write + 70h], eax ; VRAM_E |
| mov eax, [_vramw_read + edx*4] | mov eax, [vramw_read + edx*4] |
| mov [_memword_read + 54h], eax ; VRAM_B | mov [_memword_read + 54h], eax ; VRAM_B |
| mov [_memword_read + 58h], eax ; VRAM_R | mov [_memword_read + 58h], eax ; VRAM_R |
| mov [_memword_read + 5ch], eax ; VRAM_G | mov [_memword_read + 5ch], eax ; VRAM_G |
| mov [_memword_read + 70h], eax ; VRAM_E | mov [_memword_read + 70h], eax ; VRAM_E |
| mov eax, [vramw_write + edx*4] | |
| mov [_memword_write + 54h], eax ; VRAM_B | |
| mov [_memword_write + 58h], eax ; VRAM_R | |
| mov [_memword_write + 5ch], eax ; VRAM_G | |
| mov [_memword_write + 70h], eax ; VRAM_E | |
| test ecx, 10h | test ecx, 10h |
| jne short degtaldispatch_e | jne short degtaldispatch_e |
| mov eax, @i286_nonram_w@8 | mov eax, @i286_nonram_w@8 |