Commit 4e89d629 authored by John Olender's avatar John Olender Committed by Alex Deucher
Browse files

drm/amdgpu: Fix NULL ptr deref in amdgpu_device_cache_switch_state()

Kaveri has no upstream bridge, therefore parent is NULL.

$ lspci -PP
...
00:01.0 VGA compatible controller: Advanced Micro Devices, Inc. [AMD/ATI] Kaveri [Radeon R7 Graphics] (rev d4)

For comparison, Raphael:

$ lspci -PP
...
00:08.1 PCI bridge: Advanced Micro Devices, Inc. [AMD] Raphael/Granite Ridge Internal GPP Bridge to Bus [C:A]
...
00:08.1/0e:00.0 VGA compatible controller: Advanced Micro Devices, Inc. [AMD/ATI] Raphael (rev c5)

Fixes: 1dd2fa0e ("drm/amdgpu: Save and restore switch state")
Link: https://lore.kernel.org/amd-gfx/38fe6513-f8a9-4669-8e86-89c54c465611@gmail.com/


Reviewed-by: default avatarCandice Li <candice.li@amd.com>
Reviewed-by: default avatarYang Wang <kevinyang.wang@amd.com>
Signed-off-by: default avatarJohn Olender <john.olender@gmail.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent a525fa37
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -7161,7 +7161,7 @@ static void amdgpu_device_cache_switch_state(struct amdgpu_device *adev)
	struct pci_dev *parent = pci_upstream_bridge(adev->pdev);
	int r;

	if (parent->vendor != PCI_VENDOR_ID_ATI)
	if (!parent || parent->vendor != PCI_VENDOR_ID_ATI)
		return;

	/* If already saved, return */