mirror of https://gitee.com/openkylin/qemu.git
pci: typedef pcibus_t as uint64_t instead of uint32_t.
This patch is preliminary for 64bit bar. For 64bit bar support, change pcibus_t which represents pci bus addr/size from uint32_t to uint64_t. And also change FMT_pcibus for printf. In pci_update_mapping() checks 32bit overflow. So the check must be updated too. Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
89e8b13c53
commit
4f8589e115
9
hw/pci.c
9
hw/pci.c
|
@ -524,7 +524,14 @@ static void pci_update_mappings(PCIDevice *d)
|
|||
mappings, we handle specific values as invalid
|
||||
mappings. */
|
||||
if (last_addr <= new_addr || new_addr == 0 ||
|
||||
last_addr == PCI_BAR_UNMAPPED) {
|
||||
last_addr == PCI_BAR_UNMAPPED ||
|
||||
|
||||
/* Now pcibus_t is 64bit.
|
||||
* Check if 32 bit BAR wrap around explicitly.
|
||||
* Without this, PC ide doesn't work well.
|
||||
* TODO: remove this work around.
|
||||
*/
|
||||
last_addr >= UINT32_MAX) {
|
||||
new_addr = PCI_BAR_UNMAPPED;
|
||||
}
|
||||
} else {
|
||||
|
|
4
hw/pci.h
4
hw/pci.h
|
@ -71,8 +71,8 @@ extern target_phys_addr_t pci_mem_base;
|
|||
#define PCI_DEVICE_ID_VIRTIO_BALLOON 0x1002
|
||||
#define PCI_DEVICE_ID_VIRTIO_CONSOLE 0x1003
|
||||
|
||||
typedef uint32_t pcibus_t;
|
||||
#define FMT_PCIBUS PRIx32
|
||||
typedef uint64_t pcibus_t;
|
||||
#define FMT_PCIBUS PRIx64
|
||||
|
||||
typedef void PCIConfigWriteFunc(PCIDevice *pci_dev,
|
||||
uint32_t address, uint32_t data, int len);
|
||||
|
|
Loading…
Reference in New Issue