In the Linux kernel, the following vulnerability has been resolved: drm/amdgpu: handle the case of pci_channel_io_frozen only in amdgpu_pci_resume In current code, when a PCI error state pci_channel_io_normal is detectd, it will report PCI_ERS_RESULT_CAN_RECOVER status to PCI driver, and PCI driver will continue the execution of PCI resume callback report_resume by pci_walk_bridge, and the callback will go into amdgpu_pci_resume finally, where write lock is releasd unconditionally without acquiring such lock first. In this case, a deadlock will happen when other threads start to acquire the read lock. To fix this, add a member in amdgpu_device strucutre to cache pci_channel_state, and only continue the execution in amdgpu_pci_resume when it's pci_channel_io_frozen.
| Product | Vendor | Version |
|---|---|---|
| Linux | Linux | < 1b518f73f1b6f59e083ec33dea22d9a1a275a970 |
| Linux | Linux | < f0df00ebc57f803603f2a2e0df197e51f06fbe90 |
| Linux | Linux | n/a |
| Linux | Linux | < 6.3.9600.20069 |