Terminate msi/msix_write_config early if support is not enabled. This allows to remove checks at the caller site if MSI is optional.
Signed-off-by: Jan Kiszka <jan.kis...@siemens.com> --- hw/msi.c | 3 ++- hw/msix.c | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/hw/msi.c b/hw/msi.c index 56a4698..bbc9cd7 100644 --- a/hw/msi.c +++ b/hw/msi.c @@ -378,7 +378,8 @@ void msi_write_config(PCIDevice *dev, uint32_t addr, uint32_t val, int len) unsigned int vector; uint32_t pending; - if (!ranges_overlap(addr, len, dev->msi_cap, msi_cap_sizeof(flags))) { + if (!msi_present(dev) || + !ranges_overlap(addr, len, dev->msi_cap, msi_cap_sizeof(flags))) { return; } diff --git a/hw/msix.c b/hw/msix.c index 60d6d1e..ebd5aee 100644 --- a/hw/msix.c +++ b/hw/msix.c @@ -240,7 +240,7 @@ void msix_write_config(PCIDevice *dev, uint32_t addr, unsigned enable_pos = dev->msix_cap + MSIX_CONTROL_OFFSET; int vector; - if (!range_covers_byte(addr, len, enable_pos)) { + if (!msix_present(dev) || !range_covers_byte(addr, len, enable_pos)) { return; } -- 1.7.3.4