[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH for-9.2 v15 04/11] s390x/pci: Check for multifunction after devic
From: |
Akihiko Odaki |
Subject: |
[PATCH for-9.2 v15 04/11] s390x/pci: Check for multifunction after device realization |
Date: |
Fri, 23 Aug 2024 14:00:41 +0900 |
The SR-IOV PFs set the multifunction bits during device realization so
check them after that. This forbids adding SR-IOV devices to s390x.
Signed-off-by: Akihiko Odaki <akihiko.odaki@daynix.com>
---
hw/s390x/s390-pci-bus.c | 14 ++++++--------
1 file changed, 6 insertions(+), 8 deletions(-)
diff --git a/hw/s390x/s390-pci-bus.c b/hw/s390x/s390-pci-bus.c
index 3e57d5faca18..00b2c1f6157b 100644
--- a/hw/s390x/s390-pci-bus.c
+++ b/hw/s390x/s390-pci-bus.c
@@ -971,14 +971,7 @@ static void s390_pcihost_pre_plug(HotplugHandler
*hotplug_dev, DeviceState *dev,
"this device");
}
- if (object_dynamic_cast(OBJECT(dev), TYPE_PCI_DEVICE)) {
- PCIDevice *pdev = PCI_DEVICE(dev);
-
- if (pdev->cap_present & QEMU_PCI_CAP_MULTIFUNCTION) {
- error_setg(errp, "multifunction not supported in s390");
- return;
- }
- } else if (object_dynamic_cast(OBJECT(dev), TYPE_S390_PCI_DEVICE)) {
+ if (object_dynamic_cast(OBJECT(dev), TYPE_S390_PCI_DEVICE)) {
S390PCIBusDevice *pbdev = S390_PCI_DEVICE(dev);
if (!s390_pci_alloc_idx(s, pbdev)) {
@@ -1069,6 +1062,11 @@ static void s390_pcihost_plug(HotplugHandler
*hotplug_dev, DeviceState *dev,
} else if (object_dynamic_cast(OBJECT(dev), TYPE_PCI_DEVICE)) {
pdev = PCI_DEVICE(dev);
+ if (pdev->cap_present & QEMU_PCI_CAP_MULTIFUNCTION) {
+ error_setg(errp, "multifunction not supported in s390");
+ return;
+ }
+
if (!dev->id) {
/* In the case the PCI device does not define an id */
/* we generate one based on the PCI address */
--
2.46.0
- [PATCH for-9.2 v15 00/11] hw/pci: SR-IOV related fixes and improvements, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 01/11] hw/pci: Rename has_power to enabled, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 04/11] s390x/pci: Check for multifunction after device realization,
Akihiko Odaki <=
- [PATCH for-9.2 v15 02/11] hw/ppc/spapr_pci: Do not create DT for disabled PCI device, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 03/11] hw/ppc/spapr_pci: Do not reject VFs created after a PF, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 05/11] pcie_sriov: Do not manually unrealize, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 06/11] pcie_sriov: Reuse SR-IOV VF device instances, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 07/11] pcie_sriov: Release VFs failed to realize, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 08/11] pcie_sriov: Remove num_vfs from PCIESriovPF, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 11/11] hw/qdev: Remove opts member, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 09/11] pcie_sriov: Register VFs after migration, Akihiko Odaki, 2024/08/23
- [PATCH for-9.2 v15 10/11] hw/pci: Use -1 as the default value for rombar, Akihiko Odaki, 2024/08/23