mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-06 09:13:55 -06:00
libqos: Give qvirtio_config_read*() consistent semantics
The 'addr' parameter to qvirtio_config_read*() doesn't have a consistent meaning: when using the virtio-pci versions, it's a full PCI space address, but for virtio-mmio, it's an offset from the device's base mmio address. This means that the callers need to do different things to calculate the addresses in the two cases, which rather defeats the purpose of function pointer backends. All the current users of these functions are using them to retrieve variables from the device specific portion of the virtio config space. So, this patch alters the semantics to always be an offset into that device specific config area. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Reviewed-by: Laurent Vivier <lvivier@redhat.com> Reviewed-by: Greg Kurz <groug@kaod.org>
This commit is contained in:
parent
a37eb9fccd
commit
246fc0fb66
5 changed files with 36 additions and 59 deletions
|
@ -143,7 +143,6 @@ static QVirtIOSCSI *qvirtio_scsi_pci_init(int slot)
|
|||
QVirtIOSCSI *vs;
|
||||
QVirtioPCIDevice *dev;
|
||||
struct virtio_scsi_cmd_resp resp;
|
||||
void *addr;
|
||||
int i;
|
||||
|
||||
vs = g_new0(QVirtIOSCSI, 1);
|
||||
|
@ -161,8 +160,7 @@ static QVirtIOSCSI *qvirtio_scsi_pci_init(int slot)
|
|||
qvirtio_set_acknowledge(vs->dev);
|
||||
qvirtio_set_driver(vs->dev);
|
||||
|
||||
addr = dev->addr + VIRTIO_PCI_CONFIG_OFF(false);
|
||||
vs->num_queues = qvirtio_config_readl(vs->dev, (uint64_t)(uintptr_t)addr);
|
||||
vs->num_queues = qvirtio_config_readl(vs->dev, 0);
|
||||
|
||||
g_assert_cmpint(vs->num_queues, <, MAX_NUM_QUEUES);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue