[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 13/46] virtio-pci: only reset pm state during resetting
From: |
Michael S. Tsirkin |
Subject: |
[PULL 13/46] virtio-pci: only reset pm state during resetting |
Date: |
Tue, 4 Jun 2024 15:06:43 -0400 |
From: Jiqian Chen <Jiqian.Chen@amd.com>
Fix bug imported by 27ce0f3afc9dd ("fix Power Management Control Register for
PCI Express virtio devices"
After this change, observe that QEMU may erroneously clear the power status of
the device,
or may erroneously clear non writable registers, such as NO_SOFT_RESET, etc.
Only state of PM_CTRL is writable.
Only when flag VIRTIO_PCI_FLAG_INIT_PM is set, need to reset state.
Fixes: 27ce0f3afc9dd ("fix Power Management Control Register for PCI Express
virtio devices"
Signed-off-by: Jiqian Chen <Jiqian.Chen@amd.com>
Message-Id: <20240515073526.17297-2-Jiqian.Chen@amd.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
---
hw/virtio/virtio-pci.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/hw/virtio/virtio-pci.c b/hw/virtio/virtio-pci.c
index ad0035952f..b6757ffce2 100644
--- a/hw/virtio/virtio-pci.c
+++ b/hw/virtio/virtio-pci.c
@@ -2309,10 +2309,16 @@ static void virtio_pci_bus_reset_hold(Object *obj,
ResetType type)
virtio_pci_reset(qdev);
if (pci_is_express(dev)) {
+ VirtIOPCIProxy *proxy = VIRTIO_PCI(dev);
+
pcie_cap_deverr_reset(dev);
pcie_cap_lnkctl_reset(dev);
- pci_set_word(dev->config + dev->exp.pm_cap + PCI_PM_CTRL, 0);
+ if (proxy->flags & VIRTIO_PCI_FLAG_INIT_PM) {
+ pci_word_test_and_clear_mask(
+ dev->config + dev->exp.pm_cap + PCI_PM_CTRL,
+ PCI_PM_CTRL_STATE_MASK);
+ }
}
}
--
MST
- [PULL 04/46] virtio-pci: Fix the use of an uninitialized irqfd., (continued)
- [PULL 04/46] virtio-pci: Fix the use of an uninitialized irqfd., Michael S. Tsirkin, 2024/06/04
- [PULL 05/46] virtio/virtio-pci: Handle extra notification data, Michael S. Tsirkin, 2024/06/04
- [PULL 07/46] virtio-mmio: Handle extra notification data, Michael S. Tsirkin, 2024/06/04
- [PULL 06/46] virtio: Prevent creation of device using notification-data with ioeventfd, Michael S. Tsirkin, 2024/06/04
- [PULL 08/46] virtio-ccw: Handle extra notification data, Michael S. Tsirkin, 2024/06/04
- [PULL 09/46] vhost/vhost-user: Add VIRTIO_F_NOTIFICATION_DATA to vhost feature bits, Michael S. Tsirkin, 2024/06/04
- [PULL 10/46] Fix vhost user assertion when sending more than one fd, Michael S. Tsirkin, 2024/06/04
- [PULL 11/46] vhost-vsock: add VIRTIO_F_RING_PACKED to feature_bits, Michael S. Tsirkin, 2024/06/04
- [PULL 12/46] hw/virtio: Fix obtain the buffer id from the last descriptor, Michael S. Tsirkin, 2024/06/04
- [PULL 13/46] virtio-pci: only reset pm state during resetting,
Michael S. Tsirkin <=
- [PULL 14/46] vhost-user-gpu: fix import of DMABUF, Michael S. Tsirkin, 2024/06/04
- [PULL 15/46] Revert "vhost-user: fix lost reconnect", Michael S. Tsirkin, 2024/06/04
- [PULL 16/46] vhost-user: fix lost reconnect again, Michael S. Tsirkin, 2024/06/04
- [PULL 17/46] hw/cxl/mailbox: change CCI cmd set structure to be a member, not a reference, Michael S. Tsirkin, 2024/06/04
- [PULL 18/46] hw/cxl/mailbox: interface to add CCI commands to an existing CCI, Michael S. Tsirkin, 2024/06/04
- [PULL 19/46] hw/cxl/cxl-mailbox-utils: Add dc_event_log_size field to output payload of identify memory device command, Michael S. Tsirkin, 2024/06/04
- [PULL 20/46] hw/cxl/cxl-mailbox-utils: Add dynamic capacity region representative and mailbox command support, Michael S. Tsirkin, 2024/06/04
- [PULL 21/46] include/hw/cxl/cxl_device: Rename mem_size as static_mem_size for type3 memory devices, Michael S. Tsirkin, 2024/06/04
- [PULL 22/46] hw/mem/cxl_type3: Add support to create DC regions to type3 memory devices, Michael S. Tsirkin, 2024/06/04
- [PULL 23/46] hw/mem/cxl-type3: Refactor ct3_build_cdat_entries_for_mr to take mr size instead of mr as argument, Michael S. Tsirkin, 2024/06/04