Commit 017fa747 authored by Rex Zhu's avatar Rex Zhu Committed by Tim Gardner

drm/amd/powerplay: add point check to avoid NULL point hang.

BugLink: http://bugs.launchpad.net/bugs/1546572Signed-off-by: default avatarRex Zhu <Rex.Zhu@amd.com>
Reviewed-by: default avatarAlex Deucher <alexander.deucher@amd.com>
(cherry picked from commit 88b8dcbe)
Signed-off-by: default avatarAlberto Milone <alberto.milone@canonical.com>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
parent 6b085c51
...@@ -28,6 +28,12 @@ ...@@ -28,6 +28,12 @@
#include "amd_acpi.h" #include "amd_acpi.h"
#include "amd_powerplay.h" #include "amd_powerplay.h"
#define PHM_FUNC_CHECK(hw) \
do { \
if ((hw) == NULL || (hw)->hwmgr_func == NULL) \
return -EINVAL; \
} while (0)
void phm_init_dynamic_caps(struct pp_hwmgr *hwmgr) void phm_init_dynamic_caps(struct pp_hwmgr *hwmgr)
{ {
phm_cap_unset(hwmgr->platform_descriptor.platformCaps, PHM_PlatformCaps_DisableVoltageTransition); phm_cap_unset(hwmgr->platform_descriptor.platformCaps, PHM_PlatformCaps_DisableVoltageTransition);
...@@ -70,6 +76,8 @@ int phm_block_hw_access(struct pp_hwmgr *hwmgr, bool block) ...@@ -70,6 +76,8 @@ int phm_block_hw_access(struct pp_hwmgr *hwmgr, bool block)
int phm_setup_asic(struct pp_hwmgr *hwmgr) int phm_setup_asic(struct pp_hwmgr *hwmgr)
{ {
PHM_FUNC_CHECK(hwmgr);
if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps, if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps,
PHM_PlatformCaps_TablelessHardwareInterface)) { PHM_PlatformCaps_TablelessHardwareInterface)) {
if (NULL != hwmgr->hwmgr_func->asic_setup) if (NULL != hwmgr->hwmgr_func->asic_setup)
...@@ -88,6 +96,8 @@ int phm_set_power_state(struct pp_hwmgr *hwmgr, ...@@ -88,6 +96,8 @@ int phm_set_power_state(struct pp_hwmgr *hwmgr,
{ {
struct phm_set_power_state_input states; struct phm_set_power_state_input states;
PHM_FUNC_CHECK(hwmgr);
states.pcurrent_state = pcurrent_state; states.pcurrent_state = pcurrent_state;
states.pnew_state = pnew_power_state; states.pnew_state = pnew_power_state;
...@@ -104,6 +114,8 @@ int phm_set_power_state(struct pp_hwmgr *hwmgr, ...@@ -104,6 +114,8 @@ int phm_set_power_state(struct pp_hwmgr *hwmgr,
int phm_enable_dynamic_state_management(struct pp_hwmgr *hwmgr) int phm_enable_dynamic_state_management(struct pp_hwmgr *hwmgr)
{ {
PHM_FUNC_CHECK(hwmgr);
if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps, if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps,
PHM_PlatformCaps_TablelessHardwareInterface)) { PHM_PlatformCaps_TablelessHardwareInterface)) {
if (NULL != hwmgr->hwmgr_func->dynamic_state_management_enable) if (NULL != hwmgr->hwmgr_func->dynamic_state_management_enable)
...@@ -118,6 +130,8 @@ int phm_enable_dynamic_state_management(struct pp_hwmgr *hwmgr) ...@@ -118,6 +130,8 @@ int phm_enable_dynamic_state_management(struct pp_hwmgr *hwmgr)
int phm_force_dpm_levels(struct pp_hwmgr *hwmgr, enum amd_dpm_forced_level level) int phm_force_dpm_levels(struct pp_hwmgr *hwmgr, enum amd_dpm_forced_level level)
{ {
PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->force_dpm_level != NULL) if (hwmgr->hwmgr_func->force_dpm_level != NULL)
return hwmgr->hwmgr_func->force_dpm_level(hwmgr, level); return hwmgr->hwmgr_func->force_dpm_level(hwmgr, level);
...@@ -128,6 +142,8 @@ int phm_apply_state_adjust_rules(struct pp_hwmgr *hwmgr, ...@@ -128,6 +142,8 @@ int phm_apply_state_adjust_rules(struct pp_hwmgr *hwmgr,
struct pp_power_state *adjusted_ps, struct pp_power_state *adjusted_ps,
const struct pp_power_state *current_ps) const struct pp_power_state *current_ps)
{ {
PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->apply_state_adjust_rules != NULL) if (hwmgr->hwmgr_func->apply_state_adjust_rules != NULL)
return hwmgr->hwmgr_func->apply_state_adjust_rules( return hwmgr->hwmgr_func->apply_state_adjust_rules(
hwmgr, hwmgr,
...@@ -138,6 +154,8 @@ int phm_apply_state_adjust_rules(struct pp_hwmgr *hwmgr, ...@@ -138,6 +154,8 @@ int phm_apply_state_adjust_rules(struct pp_hwmgr *hwmgr,
int phm_powerdown_uvd(struct pp_hwmgr *hwmgr) int phm_powerdown_uvd(struct pp_hwmgr *hwmgr)
{ {
PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->powerdown_uvd != NULL) if (hwmgr->hwmgr_func->powerdown_uvd != NULL)
return hwmgr->hwmgr_func->powerdown_uvd(hwmgr); return hwmgr->hwmgr_func->powerdown_uvd(hwmgr);
return 0; return 0;
...@@ -145,6 +163,8 @@ int phm_powerdown_uvd(struct pp_hwmgr *hwmgr) ...@@ -145,6 +163,8 @@ int phm_powerdown_uvd(struct pp_hwmgr *hwmgr)
int phm_powergate_uvd(struct pp_hwmgr *hwmgr, bool gate) int phm_powergate_uvd(struct pp_hwmgr *hwmgr, bool gate)
{ {
PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->powergate_uvd != NULL) if (hwmgr->hwmgr_func->powergate_uvd != NULL)
return hwmgr->hwmgr_func->powergate_uvd(hwmgr, gate); return hwmgr->hwmgr_func->powergate_uvd(hwmgr, gate);
return 0; return 0;
...@@ -152,6 +172,8 @@ int phm_powergate_uvd(struct pp_hwmgr *hwmgr, bool gate) ...@@ -152,6 +172,8 @@ int phm_powergate_uvd(struct pp_hwmgr *hwmgr, bool gate)
int phm_powergate_vce(struct pp_hwmgr *hwmgr, bool gate) int phm_powergate_vce(struct pp_hwmgr *hwmgr, bool gate)
{ {
PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->powergate_vce != NULL) if (hwmgr->hwmgr_func->powergate_vce != NULL)
return hwmgr->hwmgr_func->powergate_vce(hwmgr, gate); return hwmgr->hwmgr_func->powergate_vce(hwmgr, gate);
return 0; return 0;
...@@ -159,6 +181,8 @@ int phm_powergate_vce(struct pp_hwmgr *hwmgr, bool gate) ...@@ -159,6 +181,8 @@ int phm_powergate_vce(struct pp_hwmgr *hwmgr, bool gate)
int phm_enable_clock_power_gatings(struct pp_hwmgr *hwmgr) int phm_enable_clock_power_gatings(struct pp_hwmgr *hwmgr)
{ {
PHM_FUNC_CHECK(hwmgr);
if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps, if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps,
PHM_PlatformCaps_TablelessHardwareInterface)) { PHM_PlatformCaps_TablelessHardwareInterface)) {
if (NULL != hwmgr->hwmgr_func->enable_clock_power_gating) if (NULL != hwmgr->hwmgr_func->enable_clock_power_gating)
...@@ -171,8 +195,7 @@ int phm_enable_clock_power_gatings(struct pp_hwmgr *hwmgr) ...@@ -171,8 +195,7 @@ int phm_enable_clock_power_gatings(struct pp_hwmgr *hwmgr)
int phm_display_configuration_changed(struct pp_hwmgr *hwmgr) int phm_display_configuration_changed(struct pp_hwmgr *hwmgr)
{ {
if (hwmgr == NULL) PHM_FUNC_CHECK(hwmgr);
return -EINVAL;
if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps, if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps,
PHM_PlatformCaps_TablelessHardwareInterface)) { PHM_PlatformCaps_TablelessHardwareInterface)) {
...@@ -185,8 +208,7 @@ int phm_display_configuration_changed(struct pp_hwmgr *hwmgr) ...@@ -185,8 +208,7 @@ int phm_display_configuration_changed(struct pp_hwmgr *hwmgr)
int phm_notify_smc_display_config_after_ps_adjustment(struct pp_hwmgr *hwmgr) int phm_notify_smc_display_config_after_ps_adjustment(struct pp_hwmgr *hwmgr)
{ {
if (hwmgr == NULL) PHM_FUNC_CHECK(hwmgr);
return -EINVAL;
if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps, if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps,
PHM_PlatformCaps_TablelessHardwareInterface)) PHM_PlatformCaps_TablelessHardwareInterface))
...@@ -198,7 +220,9 @@ int phm_notify_smc_display_config_after_ps_adjustment(struct pp_hwmgr *hwmgr) ...@@ -198,7 +220,9 @@ int phm_notify_smc_display_config_after_ps_adjustment(struct pp_hwmgr *hwmgr)
int phm_stop_thermal_controller(struct pp_hwmgr *hwmgr) int phm_stop_thermal_controller(struct pp_hwmgr *hwmgr)
{ {
if (hwmgr == NULL || hwmgr->hwmgr_func->stop_thermal_controller == NULL) PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->stop_thermal_controller == NULL)
return -EINVAL; return -EINVAL;
return hwmgr->hwmgr_func->stop_thermal_controller(hwmgr); return hwmgr->hwmgr_func->stop_thermal_controller(hwmgr);
...@@ -206,7 +230,9 @@ int phm_stop_thermal_controller(struct pp_hwmgr *hwmgr) ...@@ -206,7 +230,9 @@ int phm_stop_thermal_controller(struct pp_hwmgr *hwmgr)
int phm_register_thermal_interrupt(struct pp_hwmgr *hwmgr, const void *info) int phm_register_thermal_interrupt(struct pp_hwmgr *hwmgr, const void *info)
{ {
if (hwmgr == NULL || hwmgr->hwmgr_func->register_internal_thermal_interrupt == NULL) PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->register_internal_thermal_interrupt == NULL)
return -EINVAL; return -EINVAL;
return hwmgr->hwmgr_func->register_internal_thermal_interrupt(hwmgr, info); return hwmgr->hwmgr_func->register_internal_thermal_interrupt(hwmgr, info);
...@@ -228,7 +254,9 @@ int phm_start_thermal_controller(struct pp_hwmgr *hwmgr, struct PP_TemperatureRa ...@@ -228,7 +254,9 @@ int phm_start_thermal_controller(struct pp_hwmgr *hwmgr, struct PP_TemperatureRa
bool phm_check_smc_update_required_for_display_configuration(struct pp_hwmgr *hwmgr) bool phm_check_smc_update_required_for_display_configuration(struct pp_hwmgr *hwmgr)
{ {
if (hwmgr == NULL || hwmgr->hwmgr_func->check_smc_update_required_for_display_configuration == NULL) PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->check_smc_update_required_for_display_configuration == NULL)
return -EINVAL; return -EINVAL;
return hwmgr->hwmgr_func->check_smc_update_required_for_display_configuration(hwmgr); return hwmgr->hwmgr_func->check_smc_update_required_for_display_configuration(hwmgr);
...@@ -240,7 +268,9 @@ int phm_check_states_equal(struct pp_hwmgr *hwmgr, ...@@ -240,7 +268,9 @@ int phm_check_states_equal(struct pp_hwmgr *hwmgr,
const struct pp_hw_power_state *pstate2, const struct pp_hw_power_state *pstate2,
bool *equal) bool *equal)
{ {
if (hwmgr == NULL || hwmgr->hwmgr_func->check_states_equal == NULL) PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->check_states_equal == NULL)
return -EINVAL; return -EINVAL;
return hwmgr->hwmgr_func->check_states_equal(hwmgr, pstate1, pstate2, equal); return hwmgr->hwmgr_func->check_states_equal(hwmgr, pstate1, pstate2, equal);
...@@ -249,8 +279,9 @@ int phm_check_states_equal(struct pp_hwmgr *hwmgr, ...@@ -249,8 +279,9 @@ int phm_check_states_equal(struct pp_hwmgr *hwmgr,
int phm_store_dal_configuration_data(struct pp_hwmgr *hwmgr, int phm_store_dal_configuration_data(struct pp_hwmgr *hwmgr,
const struct amd_pp_display_configuration *display_config) const struct amd_pp_display_configuration *display_config)
{ {
PHM_FUNC_CHECK(hwmgr);
if (hwmgr == NULL) if (hwmgr->hwmgr_func->store_cc6_data == NULL)
return -EINVAL; return -EINVAL;
hwmgr->display_config = *display_config; hwmgr->display_config = *display_config;
...@@ -267,10 +298,11 @@ int phm_store_dal_configuration_data(struct pp_hwmgr *hwmgr, ...@@ -267,10 +298,11 @@ int phm_store_dal_configuration_data(struct pp_hwmgr *hwmgr,
} }
int phm_get_dal_power_level(struct pp_hwmgr *hwmgr, int phm_get_dal_power_level(struct pp_hwmgr *hwmgr,
struct amd_pp_dal_clock_info*info) struct amd_pp_dal_clock_info *info)
{ {
if (info == NULL || hwmgr == NULL || PHM_FUNC_CHECK(hwmgr);
hwmgr->hwmgr_func->get_dal_power_level == NULL)
if (info == NULL || hwmgr->hwmgr_func->get_dal_power_level == NULL)
return -EINVAL; return -EINVAL;
return hwmgr->hwmgr_func->get_dal_power_level(hwmgr, info); return hwmgr->hwmgr_func->get_dal_power_level(hwmgr, info);
...@@ -278,7 +310,9 @@ int phm_get_dal_power_level(struct pp_hwmgr *hwmgr, ...@@ -278,7 +310,9 @@ int phm_get_dal_power_level(struct pp_hwmgr *hwmgr,
int phm_set_cpu_power_state(struct pp_hwmgr *hwmgr) int phm_set_cpu_power_state(struct pp_hwmgr *hwmgr)
{ {
if (hwmgr != NULL && hwmgr->hwmgr_func->set_cpu_power_state != NULL) PHM_FUNC_CHECK(hwmgr);
if (hwmgr->hwmgr_func->set_cpu_power_state != NULL)
return hwmgr->hwmgr_func->set_cpu_power_state(hwmgr); return hwmgr->hwmgr_func->set_cpu_power_state(hwmgr);
return 0; return 0;
......
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