|
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 |
|