|
|
| version 1.35, 2005/05/20 13:59:47 | version 1.38, 2012/01/23 10:50:55 |
|---|---|
| Line 552 void MEMCALL memp_reads(UINT32 address, | Line 552 void MEMCALL memp_reads(UINT32 address, |
| void MEMCALL memp_writes(UINT32 address, const void *dat, UINT leng) { | void MEMCALL memp_writes(UINT32 address, const void *dat, UINT leng) { |
| const UINT8 *out = (UINT8 *)dat; | const UINT8 *out = dat; |
| UINT diff; | UINT diff; |
| /* fast memory access */ | /* fast memory access */ |
| Line 582 void MEMCALL memp_writes(UINT32 address, | Line 582 void MEMCALL memp_writes(UINT32 address, |
| // ---- Logical Space (BIOS) | // ---- Logical Space (BIOS) |
| static UINT32 physicaladdr(UINT32 addr, BOOL wr) { | |
| UINT32 a; | |
| UINT32 pde; | |
| UINT32 pte; | |
| a = CPU_STAT_PDE_BASE + ((addr >> 20) & 0xffc); | |
| pde = memp_read32(a); | |
| if (!(pde & CPU_PDE_PRESENT)) { | |
| goto retdummy; | |
| } | |
| if (!(pde & CPU_PDE_ACCESS)) { | |
| memp_write8(a, (UINT8)(pde | CPU_PDE_ACCESS)); | |
| } | |
| a = (pde & CPU_PDE_BASEADDR_MASK) + ((addr >> 10) & 0xffc); | |
| pte = cpu_memoryread_d(a); | |
| if (!(pte & CPU_PTE_PRESENT)) { | |
| goto retdummy; | |
| } | |
| if (!(pte & CPU_PTE_ACCESS)) { | |
| memp_write8(a, (UINT8)(pte | CPU_PTE_ACCESS)); | |
| } | |
| if ((wr) && (!(pte & CPU_PTE_DIRTY))) { | |
| memp_write8(a, (UINT8)(pte | CPU_PTE_DIRTY)); | |
| } | |
| addr = (pte & CPU_PTE_BASEADDR_MASK) + (addr & 0x00000fff); | |
| return(addr); | |
| retdummy: | |
| return(0x01000000); // てきとーにメモリが存在しない場所 | |
| } | |
| void MEMCALL meml_reads(UINT32 address, void *dat, UINT leng) { | void MEMCALL meml_reads(UINT32 address, void *dat, UINT leng) { |
| UINT size; | if (!CPU_STAT_PM) { |
| if (!CPU_STAT_PAGING) { | |
| memp_reads(address, dat, leng); | memp_reads(address, dat, leng); |
| } | } |
| else if (CPU_STAT_VM86) { | |
| cpu_memory_access_la_region(address, leng, | |
| CPU_PAGE_READ_DATA | CPU_PAGE_USER_MODE, dat); | |
| } | |
| else { | else { |
| while(leng) { | ia32_panic("meml_reads: call from BIOS, but protected mode"); |
| size = 0x1000 - (address & 0xfff); | |
| size = min(size, leng); | |
| memp_reads(physicaladdr(address, FALSE), dat, size); | |
| address += size; | |
| dat = ((UINT8 *)dat) + size; | |
| leng -= size; | |
| } | |
| } | } |
| } | } |
| void MEMCALL meml_writes(UINT32 address, const void *dat, UINT leng) { | void MEMCALL meml_writes(UINT32 address, const void *dat, UINT leng) { |
| UINT size; | if (!CPU_STAT_PM) { |
| if (!CPU_STAT_PAGING) { | |
| memp_writes(address, dat, leng); | memp_writes(address, dat, leng); |
| } | } |
| else if (CPU_STAT_VM86) { | |
| cpu_memory_access_la_region(address, leng, | |
| CPU_PAGE_WRITE_DATA | CPU_PAGE_USER_MODE, (UINT8 *)dat); | |
| } | |
| else { | else { |
| while(leng) { | ia32_panic("meml_writes: call from BIOS, but protected mode"); |
| size = 0x1000 - (address & 0xfff); | |
| size = min(size, leng); | |
| memp_writes(physicaladdr(address, TRUE), dat, size); | |
| address += size; | |
| dat = ((UINT8 *)dat) + size; | |
| leng -= size; | |
| } | |
| } | } |
| } | } |
| Line 659 REG8 MEMCALL memr_read8(UINT seg, UINT o | Line 616 REG8 MEMCALL memr_read8(UINT seg, UINT o |
| UINT32 addr; | UINT32 addr; |
| addr = (seg << 4) + LOW16(off); | addr = (seg << 4) + LOW16(off); |
| if (CPU_STAT_PAGING) { | if (!CPU_STAT_PM) { |
| addr = physicaladdr(addr, FALSE); | return(memp_read8(addr)); |
| } | |
| else if (CPU_STAT_VM86) { | |
| return(cpu_linear_memory_read_b(addr, | |
| CPU_PAGE_READ_DATA | CPU_PAGE_USER_MODE)); | |
| } | |
| else { | |
| ia32_panic("memr_read8: call from BIOS, but protected mode"); | |
| return(0xff); | |
| } | } |
| return(memp_read8(addr)); | |
| } | } |
| REG16 MEMCALL memr_read16(UINT seg, UINT off) { | REG16 MEMCALL memr_read16(UINT seg, UINT off) { |
| Line 670 REG16 MEMCALL memr_read16(UINT seg, UINT | Line 634 REG16 MEMCALL memr_read16(UINT seg, UINT |
| UINT32 addr; | UINT32 addr; |
| addr = (seg << 4) + LOW16(off); | addr = (seg << 4) + LOW16(off); |
| if (!CPU_STAT_PAGING) { | if (!CPU_STAT_PM) { |
| return(memp_read16(addr)); | return(memp_read16(addr)); |
| } | } |
| else if ((addr + 1) & 0xfff) { | else if (CPU_STAT_VM86) { |
| return(memp_read16(physicaladdr(addr, FALSE))); | return(cpu_linear_memory_read_w(addr, |
| CPU_PAGE_READ_DATA | CPU_PAGE_USER_MODE)); | |
| } | |
| else { | |
| ia32_panic("memr_read16: call from BIOS, but protected mode"); | |
| return(0xffff); | |
| } | } |
| return(memr_read8(seg, off) + (memr_read8(seg, off + 1) << 8)); | |
| } | } |
| void MEMCALL memr_write8(UINT seg, UINT off, REG8 dat) { | void MEMCALL memr_write8(UINT seg, UINT off, REG8 dat) { |
| Line 684 void MEMCALL memr_write8(UINT seg, UINT | Line 652 void MEMCALL memr_write8(UINT seg, UINT |
| UINT32 addr; | UINT32 addr; |
| addr = (seg << 4) + LOW16(off); | addr = (seg << 4) + LOW16(off); |
| if (CPU_STAT_PAGING) { | if (!CPU_STAT_PM) { |
| addr = physicaladdr(addr, TRUE); | memp_write8(addr, dat); |
| } | |
| else if (CPU_STAT_VM86) { | |
| cpu_linear_memory_write_b(addr, dat, | |
| CPU_PAGE_WRITE_DATA | CPU_PAGE_USER_MODE); | |
| } | |
| else { | |
| ia32_panic("memr_write8: call from BIOS, but protected mode"); | |
| } | } |
| memp_write8(addr, dat); | |
| } | } |
| void MEMCALL memr_write16(UINT seg, UINT off, REG16 dat) { | void MEMCALL memr_write16(UINT seg, UINT off, REG16 dat) { |
| Line 695 void MEMCALL memr_write16(UINT seg, UINT | Line 669 void MEMCALL memr_write16(UINT seg, UINT |
| UINT32 addr; | UINT32 addr; |
| addr = (seg << 4) + LOW16(off); | addr = (seg << 4) + LOW16(off); |
| if (!CPU_STAT_PAGING) { | if (!CPU_STAT_PM) { |
| memp_write16(addr, dat); | memp_write16(addr, dat); |
| } | } |
| else if ((addr + 1) & 0xfff) { | else if (CPU_STAT_VM86) { |
| memp_write16(physicaladdr(addr, TRUE), dat); | cpu_linear_memory_write_w(addr, dat, |
| CPU_PAGE_WRITE_DATA | CPU_PAGE_USER_MODE); | |
| } | } |
| else { | else { |
| memr_write8(seg, off, (REG8)dat); | ia32_panic("memr_write16: call from BIOS, but protected mode"); |
| memr_write8(seg, off + 1, (REG8)(dat >> 8)); | |
| } | } |
| } | } |
| void MEMCALL memr_reads(UINT seg, UINT off, void *dat, UINT leng) { | void MEMCALL memr_reads(UINT seg, UINT off, void *dat, UINT leng) { |
| UINT8 *in = dat; | |
| UINT32 addr; | UINT32 addr; |
| UINT rem; | UINT rem; |
| UINT size; | UINT size; |
| if (CPU_STAT_PM && !CPU_STAT_VM86) { | |
| ia32_panic("memr_reads: call from BIOS, but protected mode"); | |
| return; | |
| } | |
| while(leng) { | while(leng) { |
| off = LOW16(off); | off = LOW16(off); |
| addr = (seg << 4) + off; | addr = (seg << 4) + off; |
| rem = 0x10000 - off; | rem = 0x10000 - off; |
| size = min(leng, rem); | size = min(leng, rem); |
| if (CPU_STAT_PAGING) { | if (!CPU_STAT_PM) { |
| rem = 0x1000 - (addr & 0xfff); | memp_reads(addr, in, size); |
| } | |
| else { | |
| /* VM86 */ | |
| rem = CPU_PAGE_SIZE - (addr & CPU_PAGE_MASK); | |
| size = min(size, rem); | size = min(size, rem); |
| addr = physicaladdr(addr, FALSE); | cpu_memory_access_la_region(addr, size, |
| CPU_PAGE_READ_DATA | CPU_PAGE_USER_MODE, in); | |
| } | } |
| memp_reads(addr, dat, size); | |
| off += size; | off += size; |
| dat = ((UINT8 *)dat) + size; | in += size; |
| leng -= size; | leng -= size; |
| } | } |
| } | } |
| void MEMCALL memr_writes(UINT seg, UINT off, const void *dat, UINT leng) { | void MEMCALL memr_writes(UINT seg, UINT off, const void *dat, UINT leng) { |
| UINT32 addr; | const UINT8 *out = dat; |
| UINT rem; | UINT32 addr; |
| UINT size; | UINT rem; |
| UINT size; | |
| if (CPU_STAT_PM && !CPU_STAT_VM86) { | |
| ia32_panic("memr_writes: call from BIOS, but protected mode"); | |
| return; | |
| } | |
| while(leng) { | while(leng) { |
| off = LOW16(off); | off = LOW16(off); |
| addr = (seg << 4) + off; | addr = (seg << 4) + off; |
| rem = 0x10000 - off; | rem = 0x10000 - off; |
| size = min(leng, rem); | size = min(leng, rem); |
| if (CPU_STAT_PAGING) { | if (!CPU_STAT_PM) { |
| rem = 0x1000 - (addr & 0xfff); | memp_writes(addr, out, size); |
| } | |
| else { | |
| /* VM86 */ | |
| rem = CPU_PAGE_SIZE - (addr & CPU_PAGE_MASK); | |
| size = min(size, rem); | size = min(size, rem); |
| addr = physicaladdr(addr, TRUE); | cpu_memory_access_la_region(addr, size, |
| CPU_PAGE_WRITE_DATA | CPU_PAGE_USER_MODE, (UINT8 *)out); | |
| } | } |
| memp_writes(addr, dat, size); | |
| off += size; | off += size; |
| dat = ((UINT8 *)dat) + size; | out += size; |
| leng -= size; | leng -= size; |
| } | } |
| } | } |
| #endif | #endif |