mirror of
https://github.com/qemu/qemu.git
synced 2024-11-30 15:23:34 +08:00
95524ae8dc
The msix table is defined as a subregion, to allow for a BAR that mixes device specific regions with the msix table. Reviewed-by: Richard Henderson <rth@twiddle.net> Reviewed-by: Anthony Liguori <aliguori@us.ibm.com> Signed-off-by: Avi Kivity <avi@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
35 lines
864 B
C
35 lines
864 B
C
#ifndef QEMU_MSIX_H
|
|
#define QEMU_MSIX_H
|
|
|
|
#include "qemu-common.h"
|
|
#include "pci.h"
|
|
|
|
int msix_init(PCIDevice *pdev, unsigned short nentries,
|
|
MemoryRegion *bar,
|
|
unsigned bar_nr, unsigned bar_size);
|
|
|
|
void msix_write_config(PCIDevice *pci_dev, uint32_t address,
|
|
uint32_t val, int len);
|
|
|
|
int msix_uninit(PCIDevice *d, MemoryRegion *bar);
|
|
|
|
void msix_save(PCIDevice *dev, QEMUFile *f);
|
|
void msix_load(PCIDevice *dev, QEMUFile *f);
|
|
|
|
int msix_enabled(PCIDevice *dev);
|
|
int msix_present(PCIDevice *dev);
|
|
|
|
uint32_t msix_bar_size(PCIDevice *dev);
|
|
|
|
int msix_vector_use(PCIDevice *dev, unsigned vector);
|
|
void msix_vector_unuse(PCIDevice *dev, unsigned vector);
|
|
void msix_unuse_all_vectors(PCIDevice *dev);
|
|
|
|
void msix_notify(PCIDevice *dev, unsigned vector);
|
|
|
|
void msix_reset(PCIDevice *dev);
|
|
|
|
extern int msix_supported;
|
|
|
|
#endif
|