Diff for /np2/i286x/memory.x86 between versions 1.12 and 1.15

version 1.12, 2004/02/18 02:03:37 version 1.15, 2005/05/20 13:59:47
Line 2 Line 2
 ;  ;
 ; ToDo: egc word-boundary  ; ToDo: egc word-boundary
   
 %include 'x86/np2asm.inc'  %include 'np2asm.inc'
   %include 'cpucore.inc'
   %include 'iocore.inc'
   %include 'vram.inc'
   
 section .bss  section .bss
   
         global  _mem          global  _mem
         extern  _i286core          extern  _i286core
         extern  _grcg  
         extern  _gdcs  
         extern  _tramupdate          extern  _tramupdate
         extern  _vramupdate          extern  _vramupdate
         extern  _cgwindow  
         extern  _vramop          extern  _vramop
   
 _mem    resb    0x200000  _mem    resb    0x200000
Line 23  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 87  section .text Line 87  section .text
         extern  egc_write          extern  egc_write
         extern  egc_write_w          extern  egc_write_w
 %else  %else
         extern  @egc_read@4          extern  @memegc_rd8@4
         extern  @egc_read_w@4          extern  @memegc_rd16@4
         extern  @egc_write@8          extern  @memegc_wr8@8
         extern  @egc_write_w@8          extern  @memegc_wr16@8
 %endif  %endif
   
 ; 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 104  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 155  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 167  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 188  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 237  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 263  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
 %else  %else
                                         pushad                                          pushad
                                         call    @egc_write@8                                          call    @memegc_wr8@8
                                         popad                                          popad
                                         ret                                          ret
 %endif  %endif
Line 281  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 302  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 310  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 333  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 341  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 356  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 386  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
 %else  %else
                                         pushad                                          pushad
                                         call    @egc_read@4                                          call    @memegc_rd8@4
                                         mov             [esp + 28], al                                          mov             [esp + 28], al
                                         popad                                          popad
                                         ret                                          ret
Line 406  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 415  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 427  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 435  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 512  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 524  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 545  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 596  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 622  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
 %else  %else
                                         pushad                                          pushad
                                         call    @egc_write_w@8                                          call    @memegc_wr16@8
                                         popad                                          popad
                                         ret                                          ret
 %endif  %endif
Line 640  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 655  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 663  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 717  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 725  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 740  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 770  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
 %else  %else
                                         pushad                                          pushad
                                         call    @egc_read_w@4                                          call    @memegc_rd16@4
                                         mov             [esp + 28], ax                                          mov             [esp + 28], ax
                                         popad                                          popad
                                         ret                                          ret
Line 790  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 799  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

Removed from v.1.12  
changed lines
  Added in v.1.15


RetroPC.NET-CVS <cvs@retropc.net>