diff options
author | Damien Le Moal <damien.lemoal@opensource.wdc.com> | 2023-01-28 10:39:51 +0900 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2023-01-30 09:59:15 -0600 |
commit | 63ba51db24ed1b8f8088a897290eb6c036c5435d (patch) | |
tree | 21a91a0f51dedc6a42df6903fc333b7959f154f0 /include/linux/pci_ids.h | |
parent | 1b929c02afd37871d5afb9d498426f83432e71c2 (diff) |
PCI: Avoid FLR for AMD FCH AHCI adapters
PCI passthrough to VMs does not work with AMD FCH AHCI adapters: the guest
OS fails to correctly probe devices attached to the controller due to FIS
communication failures:
ata4: softreset failed (1st FIS failed)
...
ata4.00: qc timeout after 5000 msecs (cmd 0xec)
ata4.00: failed to IDENTIFY (I/O error, err_mask=0x4)
Forcing the "bus" reset method before unbinding & binding the adapter to
the vfio-pci driver solves this issue, e.g.:
echo "bus" > /sys/bus/pci/devices/<ID>/reset_method
gives a working guest OS, indicating that the default FLR reset method
doesn't work correctly.
Apply quirk_no_flr() to AMD FCH AHCI devices to work around this issue.
Link: https://lore.kernel.org/r/20230128013951.523247-1-damien.lemoal@opensource.wdc.com
Reported-by: Niklas Cassel <niklas.cassel@wdc.com>
Signed-off-by: Damien Le Moal <damien.lemoal@opensource.wdc.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Cc: stable@vger.kernel.org
Diffstat (limited to 'include/linux/pci_ids.h')
0 files changed, 0 insertions, 0 deletions