Rename cpu_physical_memory_write_rom() to address_space_write_rom()

The API of cpu_physical_memory_write_rom() is odd, because it
takes an AddressSpace, unlike all the other cpu_physical_memory_*
access functions. Rename it to address_space_write_rom(), and
bring its API into line with address_space_write().

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Acked-by: Michael S. Tsirkin <mst@redhat.com>
Message-id: 20181122133507.30950-3-peter.maydell@linaro.org
This commit is contained in:
Peter Maydell 2018-12-14 13:30:48 +00:00
parent 75693e1411
commit 3c8133f973
8 changed files with 60 additions and 35 deletions

View File

@ -253,6 +253,22 @@ Regexes for git grep
- ``\<address_space_ldu\?[bwql]\(_[lb]e\)\?\>`` - ``\<address_space_ldu\?[bwql]\(_[lb]e\)\?\>``
- ``\<address_space_st[bwql]\(_[lb]e\)\?\>`` - ``\<address_space_st[bwql]\(_[lb]e\)\?\>``
``address_space_write_rom``
~~~~~~~~~~~~~~~~~~~~~~~~~~~
This function performs a write by physical address like
``address_space_write``, except that if the write is to a ROM then
the ROM contents will be modified, even though a write by the guest
CPU to the ROM would be ignored. This is used for non-guest writes
like writes from the gdb debug stub or initial loading of ROM contents.
Note that portions of the write which attempt to write data to a
device will be silently ignored -- only real RAM and ROM will
be written to.
Regexes for git grep
- ``address_space_write_rom``
``{ld,st}*_phys`` ``{ld,st}*_phys``
~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~
@ -315,25 +331,6 @@ For new code they are better avoided:
Regexes for git grep Regexes for git grep
- ``\<cpu_physical_memory_\(read\|write\|rw\)\>`` - ``\<cpu_physical_memory_\(read\|write\|rw\)\>``
``cpu_physical_memory_write_rom``
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
This function performs a write by physical address like
``address_space_write``, except that if the write is to a ROM then
the ROM contents will be modified, even though a write by the guest
CPU to the ROM would be ignored.
Note that unlike ``cpu_physical_memory_write()`` this function takes
an AddressSpace argument, but unlike ``address_space_write()`` this
function does not take a ``MemTxAttrs`` or return a ``MemTxResult``.
**TODO**: we should probably clean up this inconsistency and
turn the function into ``address_space_write_rom`` with an API
matching ``address_space_write``.
``cpu_physical_memory_write_rom``
``cpu_memory_rw_debug`` ``cpu_memory_rw_debug``
~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~

10
exec.c
View File

@ -3430,10 +3430,11 @@ static inline MemTxResult address_space_write_rom_internal(AddressSpace *as,
} }
/* used for ROM loading : can write in RAM and ROM */ /* used for ROM loading : can write in RAM and ROM */
void cpu_physical_memory_write_rom(AddressSpace *as, hwaddr addr, MemTxResult address_space_write_rom(AddressSpace *as, hwaddr addr,
MemTxAttrs attrs,
const uint8_t *buf, int len) const uint8_t *buf, int len)
{ {
address_space_write_rom_internal(as, addr, MEMTXATTRS_UNSPECIFIED, return address_space_write_rom_internal(as, addr, attrs,
buf, len, WRITE_DATA); buf, len, WRITE_DATA);
} }
@ -3879,8 +3880,9 @@ int cpu_memory_rw_debug(CPUState *cpu, target_ulong addr,
l = len; l = len;
phys_addr += (addr & ~TARGET_PAGE_MASK); phys_addr += (addr & ~TARGET_PAGE_MASK);
if (is_write) { if (is_write) {
cpu_physical_memory_write_rom(cpu->cpu_ases[asidx].as, address_space_write_rom(cpu->cpu_ases[asidx].as, phys_addr,
phys_addr, buf, l); MEMTXATTRS_UNSPECIFIED,
buf, l);
} else { } else {
address_space_rw(cpu->cpu_ases[asidx].as, phys_addr, address_space_rw(cpu->cpu_ases[asidx].as, phys_addr,
MEMTXATTRS_UNSPECIFIED, MEMTXATTRS_UNSPECIFIED,

View File

@ -1103,8 +1103,8 @@ static void rom_reset(void *unused)
void *host = memory_region_get_ram_ptr(rom->mr); void *host = memory_region_get_ram_ptr(rom->mr);
memcpy(host, rom->data, rom->datasize); memcpy(host, rom->data, rom->datasize);
} else { } else {
cpu_physical_memory_write_rom(rom->as, rom->addr, rom->data, address_space_write_rom(rom->as, rom->addr, MEMTXATTRS_UNSPECIFIED,
rom->datasize); rom->data, rom->datasize);
} }
if (rom->isrom) { if (rom->isrom) {
/* rom needs to be written only once */ /* rom needs to be written only once */

View File

@ -122,8 +122,9 @@ static void apic_sync_vapic(APICCommonState *s, int sync_type)
} }
vapic_state.irr = vector & 0xff; vapic_state.irr = vector & 0xff;
cpu_physical_memory_write_rom(&address_space_memory, address_space_write_rom(&address_space_memory,
s->vapic_paddr + start, s->vapic_paddr + start,
MEMTXATTRS_UNSPECIFIED,
((void *)&vapic_state) + start, length); ((void *)&vapic_state) + start, length);
} }
} }

View File

@ -448,7 +448,7 @@ static int tz_mpc_attrs_to_index(IOMMUMemoryRegion *iommu, MemTxAttrs attrs)
{ {
/* We treat unspecified attributes like secure. Transactions with /* We treat unspecified attributes like secure. Transactions with
* unspecified attributes come from places like * unspecified attributes come from places like
* cpu_physical_memory_write_rom() for initial image load, and we want * rom_reset() for initial image load, and we want
* those to pass through the from-reset "everything is secure" config. * those to pass through the from-reset "everything is secure" config.
* All the real during-emulation transactions from the CPU will * All the real during-emulation transactions from the CPU will
* specify attributes. * specify attributes.

View File

@ -559,8 +559,9 @@ static void idreg_init(hwaddr addr)
s = SYS_BUS_DEVICE(dev); s = SYS_BUS_DEVICE(dev);
sysbus_mmio_map(s, 0, addr); sysbus_mmio_map(s, 0, addr);
cpu_physical_memory_write_rom(&address_space_memory, address_space_write_rom(&address_space_memory, addr,
addr, idreg_data, sizeof(idreg_data)); MEMTXATTRS_UNSPECIFIED,
idreg_data, sizeof(idreg_data));
} }
#define MACIO_ID_REGISTER(obj) \ #define MACIO_ID_REGISTER(obj) \

View File

@ -111,8 +111,6 @@ bool cpu_physical_memory_is_io(hwaddr phys_addr);
*/ */
void qemu_flush_coalesced_mmio_buffer(void); void qemu_flush_coalesced_mmio_buffer(void);
void cpu_physical_memory_write_rom(AddressSpace *as, hwaddr addr,
const uint8_t *buf, int len);
void cpu_flush_icache_range(hwaddr start, int len); void cpu_flush_icache_range(hwaddr start, int len);
extern struct MemoryRegion io_mem_rom; extern struct MemoryRegion io_mem_rom;

View File

@ -1792,6 +1792,32 @@ MemTxResult address_space_write(AddressSpace *as, hwaddr addr,
MemTxAttrs attrs, MemTxAttrs attrs,
const uint8_t *buf, int len); const uint8_t *buf, int len);
/**
* address_space_write_rom: write to address space, including ROM.
*
* This function writes to the specified address space, but will
* write data to both ROM and RAM. This is used for non-guest
* writes like writes from the gdb debug stub or initial loading
* of ROM contents.
*
* Note that portions of the write which attempt to write data to
* a device will be silently ignored -- only real RAM and ROM will
* be written to.
*
* Return a MemTxResult indicating whether the operation succeeded
* or failed (eg unassigned memory, device rejected the transaction,
* IOMMU fault).
*
* @as: #AddressSpace to be accessed
* @addr: address within that address space
* @attrs: memory transaction attributes
* @buf: buffer with the data transferred
* @len: the number of bytes to write
*/
MemTxResult address_space_write_rom(AddressSpace *as, hwaddr addr,
MemTxAttrs attrs,
const uint8_t *buf, int len);
/* address_space_ld*: load from an address space /* address_space_ld*: load from an address space
* address_space_st*: store to an address space * address_space_st*: store to an address space
* *