diff options
| author | Jan Kiszka <jan.kiszka@siemens.com> | 2012-05-17 10:32:30 -0300 |
|---|---|---|
| committer | Avi Kivity <avi@redhat.com> | 2012-05-21 19:22:49 +0300 |
| commit | 5b5f1330da2d7e5b5cbde8c60738774b2bd8692f (patch) | |
| tree | 052fe0a536faf4ef25b12a091e624484b8905bb3 /hw/msix.c | |
| parent | bc4caf49c7fee6d1e063df32ca7554e5b98bfc89 (diff) | |
| download | focaccia-qemu-5b5f1330da2d7e5b5cbde8c60738774b2bd8692f.tar.gz focaccia-qemu-5b5f1330da2d7e5b5cbde8c60738774b2bd8692f.zip | |
msix: Invoke msix_handle_mask_update on msix_mask_all
In preparation of firing vector notifiers on mask changes, call msix_handle_mask_update also from msix_mask_all. So far, this will have no real effect. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'hw/msix.c')
| -rw-r--r-- | hw/msix.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/hw/msix.c b/hw/msix.c index 31974657d3..e1a7d92fea 100644 --- a/hw/msix.c +++ b/hw/msix.c @@ -231,10 +231,14 @@ static void msix_mmio_setup(PCIDevice *d, MemoryRegion *bar) static void msix_mask_all(struct PCIDevice *dev, unsigned nentries) { int vector; + for (vector = 0; vector < nentries; ++vector) { unsigned offset = vector * PCI_MSIX_ENTRY_SIZE + PCI_MSIX_ENTRY_VECTOR_CTRL; + bool was_masked = msix_is_masked(dev, vector); + dev->msix_table_page[offset] |= PCI_MSIX_ENTRY_CTRL_MASKBIT; + msix_handle_mask_update(dev, vector, was_masked); } } |