mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-11 18:35:28 +00:00
cputlb: Fix io_readx() to respect the access_type
This change adapts io_readx() to its input access_type. Currently io_readx() treats any memory access as a read, although it has an input argument "MMUAccessType access_type". This results in: 1) Calling the tlb_fill() only with MMU_DATA_LOAD 2) Considering only entry->addr_read as the tlb_addr Buglink: https://bugs.launchpad.net/qemu/+bug/1825359 Backports commit ef5dae6805cce7b59d129d801bdc5db71bcbd60d from qemu
This commit is contained in:
parent
5847d833b2
commit
7f59d62f4a
|
@ -586,10 +586,11 @@ static uint64_t io_readx(CPUArchState *env, CPUIOTLBEntry *iotlbentry,
|
||||||
CPUTLBEntry *entry;
|
CPUTLBEntry *entry;
|
||||||
target_ulong tlb_addr;
|
target_ulong tlb_addr;
|
||||||
|
|
||||||
tlb_fill(cpu, addr, size, MMU_DATA_LOAD, mmu_idx, retaddr);
|
tlb_fill(cpu, addr, size, access_type, mmu_idx, retaddr);
|
||||||
|
|
||||||
entry = tlb_entry(env, mmu_idx, addr);
|
entry = tlb_entry(env, mmu_idx, addr);
|
||||||
tlb_addr = entry->addr_read;
|
tlb_addr = (access_type == MMU_DATA_LOAD ?
|
||||||
|
entry->addr_read : entry->addr_code);
|
||||||
if (!(tlb_addr & ~(TARGET_PAGE_MASK | TLB_RECHECK))) {
|
if (!(tlb_addr & ~(TARGET_PAGE_MASK | TLB_RECHECK))) {
|
||||||
/* RAM access */
|
/* RAM access */
|
||||||
uintptr_t haddr = addr + entry->addend;
|
uintptr_t haddr = addr + entry->addend;
|
||||||
|
|
Loading…
Reference in a new issue