Jiri Slaby 0846cd
From: Guchun Chen <guchun.chen@amd.com>
Jiri Slaby 0846cd
Date: Tue, 9 May 2023 09:36:49 +0800
Jiri Slaby 0846cd
Subject: [PATCH] drm/amd/pm: avoid potential UBSAN issue on legacy asics
Jiri Slaby 0846cd
References: bsc#1012628
Jiri Slaby 0846cd
Patch-mainline: 6.3.3
Jiri Slaby 0846cd
Git-commit: 5247f05eadf1081a74b2233f291cee2efed25e3a
Jiri Slaby 0846cd
Jiri Slaby 0846cd
commit 5247f05eadf1081a74b2233f291cee2efed25e3a upstream.
Jiri Slaby 0846cd
Jiri Slaby 0846cd
Prevent further dpm casting on legacy asics without od_enabled in
Jiri Slaby 0846cd
amdgpu_dpm_is_overdrive_supported. This can avoid UBSAN complain
Jiri Slaby 0846cd
in init sequence.
Jiri Slaby 0846cd
Jiri Slaby 0846cd
v2: add a macro to check legacy dpm instead of checking asic family/type
Jiri Slaby 0846cd
v3: refine macro name for naming consistency
Jiri Slaby 0846cd
Jiri Slaby 0846cd
Suggested-by: Evan Quan <evan.quan@amd.com>
Jiri Slaby 0846cd
Signed-off-by: Guchun Chen <guchun.chen@amd.com>
Jiri Slaby 0846cd
Reviewed-by: Lijo Lazar <lijo.lazar@amd.com>
Jiri Slaby 0846cd
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Jiri Slaby 0846cd
Cc: stable@vger.kernel.org
Jiri Slaby 0846cd
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Jiri Slaby 0846cd
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
Jiri Slaby 0846cd
---
Jiri Slaby 0846cd
 drivers/gpu/drm/amd/pm/amdgpu_dpm.c | 9 +++++++--
Jiri Slaby 0846cd
 1 file changed, 7 insertions(+), 2 deletions(-)
Jiri Slaby 0846cd
Jiri Slaby 0846cd
diff --git a/drivers/gpu/drm/amd/pm/amdgpu_dpm.c b/drivers/gpu/drm/amd/pm/amdgpu_dpm.c
Jiri Slaby 0846cd
index 29720d0b..bdacc0a7 100644
Jiri Slaby 0846cd
--- a/drivers/gpu/drm/amd/pm/amdgpu_dpm.c
Jiri Slaby 0846cd
+++ b/drivers/gpu/drm/amd/pm/amdgpu_dpm.c
Jiri Slaby 0846cd
@@ -36,6 +36,8 @@
Jiri Slaby 0846cd
 #define amdgpu_dpm_enable_bapm(adev, e) \
Jiri Slaby 0846cd
 		((adev)->powerplay.pp_funcs->enable_bapm((adev)->powerplay.pp_handle, (e)))
Jiri Slaby 0846cd
 
Jiri Slaby 0846cd
+#define amdgpu_dpm_is_legacy_dpm(adev) ((adev)->powerplay.pp_handle == (adev))
Jiri Slaby 0846cd
+
Jiri Slaby 0846cd
 int amdgpu_dpm_get_sclk(struct amdgpu_device *adev, bool low)
Jiri Slaby 0846cd
 {
Jiri Slaby 0846cd
 	const struct amd_pm_funcs *pp_funcs = adev->powerplay.pp_funcs;
Jiri Slaby 0846cd
@@ -1439,8 +1441,11 @@ int amdgpu_dpm_is_overdrive_supported(struct amdgpu_device *adev)
Jiri Slaby 0846cd
 	} else {
Jiri Slaby 0846cd
 		struct pp_hwmgr *hwmgr;
Jiri Slaby 0846cd
 
Jiri Slaby 0846cd
-		/* SI asic does not carry od_enabled */
Jiri Slaby 0846cd
-		if (adev->family == AMDGPU_FAMILY_SI)
Jiri Slaby 0846cd
+		/*
Jiri Slaby 0846cd
+		 * dpm on some legacy asics don't carry od_enabled member
Jiri Slaby 0846cd
+		 * as its pp_handle is casted directly from adev.
Jiri Slaby 0846cd
+		 */
Jiri Slaby 0846cd
+		if (amdgpu_dpm_is_legacy_dpm(adev))
Jiri Slaby 0846cd
 			return false;
Jiri Slaby 0846cd
 
Jiri Slaby 0846cd
 		hwmgr = (struct pp_hwmgr *)adev->powerplay.pp_handle;
Jiri Slaby 0846cd
-- 
Jiri Slaby 0846cd
2.35.3
Jiri Slaby 0846cd