2014-09-01 12:07:54 +02:00
|
|
|
/*
|
|
|
|
* 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"
|
|
|
|
|
2015-02-24 22:21:53 +01:00
|
|
|
#define QVIRTIO_PCI_DEVICE_FEATURES 0x00
|
|
|
|
#define QVIRTIO_PCI_GUEST_FEATURES 0x04
|
|
|
|
#define QVIRTIO_PCI_QUEUE_ADDRESS 0x08
|
|
|
|
#define QVIRTIO_PCI_QUEUE_SIZE 0x0C
|
|
|
|
#define QVIRTIO_PCI_QUEUE_SELECT 0x0E
|
|
|
|
#define QVIRTIO_PCI_QUEUE_NOTIFY 0x10
|
|
|
|
#define QVIRTIO_PCI_DEVICE_STATUS 0x12
|
|
|
|
#define QVIRTIO_PCI_ISR_STATUS 0x13
|
|
|
|
#define QVIRTIO_PCI_MSIX_CONF_VECTOR 0x14
|
|
|
|
#define QVIRTIO_PCI_MSIX_QUEUE_VECTOR 0x16
|
|
|
|
#define QVIRTIO_PCI_DEVICE_SPECIFIC_MSIX 0x18
|
|
|
|
#define QVIRTIO_PCI_DEVICE_SPECIFIC_NO_MSIX 0x14
|
2014-09-01 12:07:55 +02:00
|
|
|
|
2014-09-01 12:07:56 +02:00
|
|
|
#define QVIRTIO_PCI_ALIGN 4096
|
|
|
|
|
2014-09-01 12:07:59 +02:00
|
|
|
#define QVIRTIO_MSI_NO_VECTOR 0xFFFF
|
|
|
|
|
2014-09-01 12:07:54 +02:00
|
|
|
typedef struct QVirtioPCIDevice {
|
|
|
|
QVirtioDevice vdev;
|
|
|
|
QPCIDevice *pdev;
|
2014-09-01 12:07:55 +02:00
|
|
|
void *addr;
|
2014-09-01 12:07:59 +02:00
|
|
|
uint16_t config_msix_entry;
|
|
|
|
uint64_t config_msix_addr;
|
|
|
|
uint32_t config_msix_data;
|
2014-09-01 12:07:54 +02:00
|
|
|
} QVirtioPCIDevice;
|
|
|
|
|
2014-09-01 12:07:59 +02:00
|
|
|
typedef struct QVirtQueuePCI {
|
|
|
|
QVirtQueue vq;
|
|
|
|
uint16_t msix_entry;
|
|
|
|
uint64_t msix_addr;
|
|
|
|
uint32_t msix_data;
|
|
|
|
} QVirtQueuePCI;
|
|
|
|
|
2014-09-01 12:07:55 +02:00
|
|
|
extern const QVirtioBus qvirtio_pci;
|
|
|
|
|
2014-09-01 12:07:54 +02:00
|
|
|
void qvirtio_pci_foreach(QPCIBus *bus, uint16_t device_type,
|
|
|
|
void (*func)(QVirtioDevice *d, void *data), void *data);
|
|
|
|
QVirtioPCIDevice *qvirtio_pci_device_find(QPCIBus *bus, uint16_t device_type);
|
2014-09-01 12:07:55 +02:00
|
|
|
void qvirtio_pci_device_enable(QVirtioPCIDevice *d);
|
|
|
|
void qvirtio_pci_device_disable(QVirtioPCIDevice *d);
|
2014-09-01 12:07:59 +02:00
|
|
|
|
|
|
|
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);
|
2014-09-01 12:07:54 +02:00
|
|
|
#endif
|