Commit 63408972 authored by Colin Ian King's avatar Colin Ian King Committed by Alex Deucher

drm/amd/powerplay: fix various dereferences of a pointer before it is null checked

There are several occurrances of the pointer hwmgr being dereferenced
before it is null checked.  Fix these by performing the dereference
of hwmgr after it has been null checked.

Addresses-Coverity: ("Dereference before null check")
Fixes: c9ffa427 ("drm/amd/powerplay: enable pp one vf mode for vega10")
Signed-off-by: default avatarColin Ian King <colin.king@canonical.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent b3eca59d
...@@ -275,12 +275,12 @@ static int pp_dpm_load_fw(void *handle) ...@@ -275,12 +275,12 @@ static int pp_dpm_load_fw(void *handle)
{ {
struct pp_hwmgr *hwmgr = handle; struct pp_hwmgr *hwmgr = handle;
if (!hwmgr->not_vf)
return 0;
if (!hwmgr || !hwmgr->smumgr_funcs || !hwmgr->smumgr_funcs->start_smu) if (!hwmgr || !hwmgr->smumgr_funcs || !hwmgr->smumgr_funcs->start_smu)
return -EINVAL; return -EINVAL;
if (!hwmgr->not_vf)
return 0;
if (hwmgr->smumgr_funcs->start_smu(hwmgr)) { if (hwmgr->smumgr_funcs->start_smu(hwmgr)) {
pr_err("fw load failed\n"); pr_err("fw load failed\n");
return -EINVAL; return -EINVAL;
......
...@@ -282,10 +282,7 @@ int hwmgr_hw_init(struct pp_hwmgr *hwmgr) ...@@ -282,10 +282,7 @@ int hwmgr_hw_init(struct pp_hwmgr *hwmgr)
int hwmgr_hw_fini(struct pp_hwmgr *hwmgr) int hwmgr_hw_fini(struct pp_hwmgr *hwmgr)
{ {
if (!hwmgr->not_vf) if (!hwmgr || !hwmgr->pm_en || !hwmgr->not_vf)
return 0;
if (!hwmgr || !hwmgr->pm_en)
return 0; return 0;
phm_stop_thermal_controller(hwmgr); phm_stop_thermal_controller(hwmgr);
...@@ -305,10 +302,7 @@ int hwmgr_suspend(struct pp_hwmgr *hwmgr) ...@@ -305,10 +302,7 @@ int hwmgr_suspend(struct pp_hwmgr *hwmgr)
{ {
int ret = 0; int ret = 0;
if (!hwmgr->not_vf) if (!hwmgr || !hwmgr->pm_en || !hwmgr->not_vf)
return 0;
if (!hwmgr || !hwmgr->pm_en)
return 0; return 0;
phm_disable_smc_firmware_ctf(hwmgr); phm_disable_smc_firmware_ctf(hwmgr);
...@@ -327,13 +321,10 @@ int hwmgr_resume(struct pp_hwmgr *hwmgr) ...@@ -327,13 +321,10 @@ int hwmgr_resume(struct pp_hwmgr *hwmgr)
{ {
int ret = 0; int ret = 0;
if (!hwmgr->not_vf)
return 0;
if (!hwmgr) if (!hwmgr)
return -EINVAL; return -EINVAL;
if (!hwmgr->pm_en) if (!hwmgr->not_vf || !hwmgr->pm_en)
return 0; return 0;
ret = phm_setup_asic(hwmgr); ret = phm_setup_asic(hwmgr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment