d08f68b8e8
Implement the VIRTIO 1.0 virtio-pci interface. The main change here is that the register layout is no longer a fixed layout in BAR 0. Instead we have to iterate of PCI Capabilities to find descriptions of where various registers are located. The vring registers are also more fine-grained, allowing for more flexible vring layouts, but we don't take advantage of that. Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Reviewed-by: Sergio Lopez <slp@redhat.com> Message-Id: <20191023100425.12168-17-stefanha@redhat.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Acked-by: Thomas Huth <thuth@redhat.com>
87 lines
2.6 KiB
C
87 lines
2.6 KiB
C
/*
|
|
* libqos virtio PCI definitions
|
|
*
|
|
* Copyright (c) 2014 Marc Marí
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
* See the COPYING file in the top-level directory.
|
|
*/
|
|
|
|
#ifndef LIBQOS_VIRTIO_PCI_H
|
|
#define LIBQOS_VIRTIO_PCI_H
|
|
|
|
#include "libqos/virtio.h"
|
|
#include "libqos/pci.h"
|
|
#include "libqos/qgraph.h"
|
|
|
|
typedef struct QVirtioPCIMSIXOps QVirtioPCIMSIXOps;
|
|
|
|
typedef struct QVirtioPCIDevice {
|
|
QOSGraphObject obj;
|
|
QVirtioDevice vdev;
|
|
QPCIDevice *pdev;
|
|
QPCIBar bar;
|
|
const QVirtioPCIMSIXOps *msix_ops;
|
|
uint16_t config_msix_entry;
|
|
uint64_t config_msix_addr;
|
|
uint32_t config_msix_data;
|
|
|
|
int bar_idx;
|
|
|
|
/* VIRTIO 1.0 */
|
|
uint32_t common_cfg_offset;
|
|
uint32_t notify_cfg_offset;
|
|
uint32_t notify_off_multiplier;
|
|
uint32_t isr_cfg_offset;
|
|
uint32_t device_cfg_offset;
|
|
} QVirtioPCIDevice;
|
|
|
|
struct QVirtioPCIMSIXOps {
|
|
/* Set the Configuration Vector for MSI-X */
|
|
void (*set_config_vector)(QVirtioPCIDevice *d, uint16_t entry);
|
|
|
|
/* Set the Queue Vector for MSI-X */
|
|
void (*set_queue_vector)(QVirtioPCIDevice *d, uint16_t vq_idx,
|
|
uint16_t entry);
|
|
};
|
|
|
|
typedef struct QVirtQueuePCI {
|
|
QVirtQueue vq;
|
|
uint16_t msix_entry;
|
|
uint64_t msix_addr;
|
|
uint32_t msix_data;
|
|
|
|
/* VIRTIO 1.0 */
|
|
uint64_t notify_offset;
|
|
} QVirtQueuePCI;
|
|
|
|
void virtio_pci_init(QVirtioPCIDevice *dev, QPCIBus *bus, QPCIAddress * addr);
|
|
QVirtioPCIDevice *virtio_pci_new(QPCIBus *bus, QPCIAddress * addr);
|
|
|
|
/* virtio-pci object functions available for subclasses that
|
|
* override the original start_hw and destroy
|
|
* function. All virtio-xxx-pci subclass that override must
|
|
* take care of calling these two functions in the respective
|
|
* places
|
|
*/
|
|
void qvirtio_pci_destructor(QOSGraphObject *obj);
|
|
void qvirtio_pci_start_hw(QOSGraphObject *obj);
|
|
|
|
|
|
void qvirtio_pci_device_enable(QVirtioPCIDevice *d);
|
|
void qvirtio_pci_device_disable(QVirtioPCIDevice *d);
|
|
|
|
void qvirtio_pci_set_msix_configuration_vector(QVirtioPCIDevice *d,
|
|
QGuestAllocator *alloc, uint16_t entry);
|
|
void qvirtqueue_pci_msix_setup(QVirtioPCIDevice *d, QVirtQueuePCI *vqpci,
|
|
QGuestAllocator *alloc, uint16_t entry);
|
|
|
|
/* Used by Legacy and Modern virtio-pci code */
|
|
QVirtQueue *qvirtio_pci_virtqueue_setup_common(QVirtioDevice *d,
|
|
QGuestAllocator *alloc,
|
|
uint16_t index);
|
|
void qvirtio_pci_virtqueue_cleanup_common(QVirtQueue *vq,
|
|
QGuestAllocator *alloc);
|
|
|
|
#endif
|