All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v6 00/17] pci: Abort if pci_add_capability fails
@ 2022-10-31 12:33 Akihiko Odaki
  2022-10-31 12:33 ` [PATCH v6 01/17] hw/vfio/pci: Ensure MSI and MSI-X do not overlap Akihiko Odaki
                   ` (17 more replies)
  0 siblings, 18 replies; 20+ messages in thread
From: Akihiko Odaki @ 2022-10-31 12:33 UTC (permalink / raw)
  Cc: qemu-devel, qemu-block, qemu-arm, Michael S . Tsirkin,
	Marcel Apfelbaum, Gerd Hoffmann, Paolo Bonzini, Richard Henderson,
	Eduardo Habkost, John Snow, Dmitry Fleytman, Jason Wang,
	Stefan Weil, Keith Busch, Klaus Jensen, Peter Maydell,
	Andrey Smirnov, Paul Burton, Aleksandar Rikalo, Yan Vugenfirer,
	Yuri Benditovich, Akihiko Odaki

pci_add_capability appears most PCI devices. Its error handling required
lots of code, and led to inconsistent behaviors such as:
- passing error_abort
- passing error_fatal
- asserting the returned value
- propagating the error to the caller
- skipping the rest of the function
- just ignoring

The code generating errors in pci_add_capability had a comment which
says:
> Verify that capabilities don't overlap.  Note: device assignment
> depends on this check to verify that the device is not broken.
> Should never trigger for emulated devices, but it's helpful for
> debugging these.

Indeed vfio has some code that passes capability offsets and sizes from
a physical device, but it explicitly pays attention so that the
capabilities never overlap and the only exception are MSI and MSI-X
capabilities. Therefore, we can add code specific to the case, and
always assert that capabilities never overlap in the other cases,
resolving these inconsistencies.

v6:
- Error in case of MSI/MSI-X capability overlap (Alex Williamson)

v5:
- Fix capability ID specification in vfio_msi_early_setup (Alex Williamson)
- Use range_covers_byte() (Alex Williamson)
- warn_report() in case of MSI/MSI-X capability overlap (Alex Williamson)

v4:
- Fix typos in messages (Markus Armbruster)
- hw/vfio/pci: Ensure MSI and MSI-X do not overlap (Alex Williamson)

v3:
- Correct patch split between virtio-pci and pci (Markus Armbruster)
- Add messages for individual patches (Markus Armbruster)
- Acked-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>

Akihiko Odaki (17):
  hw/vfio/pci: Ensure MSI and MSI-X do not overlap
  pci: Allow to omit errp for pci_add_capability
  hw/i386/amd_iommu: Omit errp for pci_add_capability
  ahci: Omit errp for pci_add_capability
  e1000e: Omit errp for pci_add_capability
  eepro100: Omit errp for pci_add_capability
  hw/nvme: Omit errp for pci_add_capability
  msi: Omit errp for pci_add_capability
  hw/pci/pci_bridge: Omit errp for pci_add_capability
  pcie: Omit errp for pci_add_capability
  pci/shpc: Omit errp for pci_add_capability
  msix: Omit errp for pci_add_capability
  pci/slotid: Omit errp for pci_add_capability
  hw/pci-bridge/pcie_pci_bridge: Omit errp for pci_add_capability
  hw/vfio/pci: Omit errp for pci_add_capability
  virtio-pci: Omit errp for pci_add_capability
  pci: Remove legacy errp from pci_add_capability

 docs/pcie_sriov.txt                |  4 +-
 hw/display/bochs-display.c         |  4 +-
 hw/i386/amd_iommu.c                | 21 ++-------
 hw/ide/ich.c                       |  8 +---
 hw/net/e1000e.c                    | 22 ++-------
 hw/net/eepro100.c                  |  7 +--
 hw/nvme/ctrl.c                     | 14 +-----
 hw/pci-bridge/cxl_downstream.c     |  9 +---
 hw/pci-bridge/cxl_upstream.c       |  8 +---
 hw/pci-bridge/i82801b11.c          | 14 +-----
 hw/pci-bridge/pci_bridge_dev.c     |  2 +-
 hw/pci-bridge/pcie_pci_bridge.c    | 19 ++------
 hw/pci-bridge/pcie_root_port.c     | 16 +------
 hw/pci-bridge/xio3130_downstream.c | 15 ++----
 hw/pci-bridge/xio3130_upstream.c   | 15 ++----
 hw/pci-host/designware.c           |  3 +-
 hw/pci-host/xilinx-pcie.c          |  4 +-
 hw/pci/msi.c                       |  9 +---
 hw/pci/msix.c                      |  8 +---
 hw/pci/pci.c                       | 29 +++---------
 hw/pci/pci_bridge.c                | 21 +++------
 hw/pci/pcie.c                      | 52 ++++++---------------
 hw/pci/shpc.c                      | 23 +++------
 hw/pci/slotid_cap.c                |  8 +---
 hw/usb/hcd-xhci-pci.c              |  3 +-
 hw/vfio/pci-quirks.c               | 15 ++----
 hw/vfio/pci.c                      | 75 ++++++++++++++++++++++--------
 hw/vfio/pci.h                      |  3 ++
 hw/virtio/virtio-pci.c             | 12 ++---
 include/hw/pci/pci.h               |  5 +-
 include/hw/pci/pci_bridge.h        |  5 +-
 include/hw/pci/pcie.h              | 11 ++---
 include/hw/pci/shpc.h              |  3 +-
 include/hw/virtio/virtio-pci.h     |  2 +-
 34 files changed, 153 insertions(+), 316 deletions(-)

-- 
2.38.1


^ permalink raw reply	[flat|nested] 20+ messages in thread

end of thread, other threads:[~2022-10-31 13:51 UTC | newest]

Thread overview: 20+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-10-31 12:33 [PATCH v6 00/17] pci: Abort if pci_add_capability fails Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 01/17] hw/vfio/pci: Ensure MSI and MSI-X do not overlap Akihiko Odaki
2022-10-31 13:51   ` Alex Williamson
2022-10-31 12:33 ` [PATCH v6 02/17] pci: Allow to omit errp for pci_add_capability Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 03/17] hw/i386/amd_iommu: Omit " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 04/17] ahci: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 05/17] e1000e: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 06/17] eepro100: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 07/17] hw/nvme: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 08/17] msi: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 09/17] hw/pci/pci_bridge: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 10/17] pcie: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 11/17] pci/shpc: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 12/17] msix: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 13/17] pci/slotid: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 14/17] hw/pci-bridge/pcie_pci_bridge: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 15/17] hw/vfio/pci: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 16/17] virtio-pci: " Akihiko Odaki
2022-10-31 12:33 ` [PATCH v6 17/17] pci: Remove legacy errp from pci_add_capability Akihiko Odaki
2022-10-31 12:37 ` [PATCH v6 00/17] pci: Abort if pci_add_capability fails Michael S. Tsirkin

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.