mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-08 10:13:56 -06:00
Clean up MMIO TLB handling.
The IO index is now stored in its own field, instead of being wedged into the vaddr field. This eliminates the ROMD and watchpoint host pointer weirdness. The IO index space is expanded by 1 bit, and several additional bits are made available in the TLB vaddr field. git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4704 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
f227f17d1b
commit
0f459d16c3
7 changed files with 194 additions and 175 deletions
|
@ -112,13 +112,12 @@ static uint32_t pflash_read (pflash_t *pfl, uint32_t offset, int width)
|
|||
|
||||
DPRINTF("%s: offset " TARGET_FMT_lx "\n", __func__, offset);
|
||||
ret = -1;
|
||||
offset -= pfl->base;
|
||||
if (pfl->rom_mode) {
|
||||
offset -= (uint32_t)(long)pfl->storage;
|
||||
/* Lazy reset of to ROMD mode */
|
||||
if (pfl->wcycle == 0)
|
||||
pflash_register_memory(pfl, 1);
|
||||
} else
|
||||
offset -= pfl->base;
|
||||
}
|
||||
offset &= pfl->chip_len - 1;
|
||||
boff = offset & 0xFF;
|
||||
if (pfl->width == 2)
|
||||
|
@ -242,12 +241,7 @@ static void pflash_write (pflash_t *pfl, uint32_t offset, uint32_t value,
|
|||
}
|
||||
DPRINTF("%s: offset " TARGET_FMT_lx " %08x %d %d\n", __func__,
|
||||
offset, value, width, pfl->wcycle);
|
||||
/* WARNING: when the memory area is in ROMD mode, the offset is a
|
||||
ram offset, not a physical address */
|
||||
if (pfl->rom_mode)
|
||||
offset -= (uint32_t)(long)pfl->storage;
|
||||
else
|
||||
offset -= pfl->base;
|
||||
offset -= pfl->base;
|
||||
offset &= pfl->chip_len - 1;
|
||||
|
||||
DPRINTF("%s: offset " TARGET_FMT_lx " %08x %d\n", __func__,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue