mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-03 07:43:54 -06:00
exec/ioport: Resolve redundant .base attribute in struct MemoryRegionPortio
portio_list_add_1() creates a MemoryRegionPortioList instance which holds a MemoryRegion `mr` and an array of MemoryRegionPortio elements named `ports`. Each element in the array gets assigned the same value for its .base attribute. The same value also ends up as the .addr attribute of `mr` due to the memory_region_add_subregion() call. This means that all .base attributes are the same as `mr.addr`. The only usages of MemoryRegionPortio::base were in portio_read() and portio_write(). Both functions get above MemoryRegionPortioList as their opaque parameter. In both cases find_portio() can only return one of the MemoryRegionPortio elements of the `ports` array. Due to above observation any element will have the same .base value equal to `mr.addr` which is also accessible. Hence, `mrpio->mr.addr` is equivalent to `mrp->base` and MemoryRegionPortio::base is redundant and can be removed. Signed-off-by: Bernhard Beschow <shentey@gmail.com> Message-Id: <20240114123911.4877-5-shentey@gmail.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
ee3d1f1b46
commit
4edee342f8
2 changed files with 6 additions and 8 deletions
|
@ -35,7 +35,6 @@ typedef struct MemoryRegionPortio {
|
|||
unsigned size;
|
||||
uint32_t (*read)(void *opaque, uint32_t address);
|
||||
void (*write)(void *opaque, uint32_t address, uint32_t data);
|
||||
uint32_t base; /* private field */
|
||||
} MemoryRegionPortio;
|
||||
|
||||
#define PORTIO_END_OF_LIST() { }
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue