mirror of
https://github.com/nxp-imx/linux-imx.git
synced 2025-07-08 02:15:20 +02:00
drm/amd/pm: check negtive return for table entries
[ Upstream commit f76059fe14
]
Function hwmgr->hwmgr_func->get_num_of_pp_table_entries(hwmgr) returns a negative number
Signed-off-by: Jesse Zhang <Jesse.Zhang@amd.com>
Suggested-by: Tim Huang <Tim.Huang@amd.com>
Reviewed-by: Tim Huang <Tim.Huang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
7d265772e4
commit
7e8d106ca9
|
@ -30,9 +30,8 @@ int psm_init_power_state_table(struct pp_hwmgr *hwmgr)
|
||||||
{
|
{
|
||||||
int result;
|
int result;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
unsigned int table_entries;
|
|
||||||
struct pp_power_state *state;
|
struct pp_power_state *state;
|
||||||
int size;
|
int size, table_entries;
|
||||||
|
|
||||||
if (hwmgr->hwmgr_func->get_num_of_pp_table_entries == NULL)
|
if (hwmgr->hwmgr_func->get_num_of_pp_table_entries == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -40,15 +39,19 @@ int psm_init_power_state_table(struct pp_hwmgr *hwmgr)
|
||||||
if (hwmgr->hwmgr_func->get_power_state_size == NULL)
|
if (hwmgr->hwmgr_func->get_power_state_size == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
hwmgr->num_ps = table_entries = hwmgr->hwmgr_func->get_num_of_pp_table_entries(hwmgr);
|
table_entries = hwmgr->hwmgr_func->get_num_of_pp_table_entries(hwmgr);
|
||||||
|
|
||||||
hwmgr->ps_size = size = hwmgr->hwmgr_func->get_power_state_size(hwmgr) +
|
size = hwmgr->hwmgr_func->get_power_state_size(hwmgr) +
|
||||||
sizeof(struct pp_power_state);
|
sizeof(struct pp_power_state);
|
||||||
|
|
||||||
if (table_entries == 0 || size == 0) {
|
if (table_entries <= 0 || size == 0) {
|
||||||
pr_warn("Please check whether power state management is supported on this asic\n");
|
pr_warn("Please check whether power state management is supported on this asic\n");
|
||||||
|
hwmgr->num_ps = 0;
|
||||||
|
hwmgr->ps_size = 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
hwmgr->num_ps = table_entries;
|
||||||
|
hwmgr->ps_size = size;
|
||||||
|
|
||||||
hwmgr->ps = kcalloc(table_entries, size, GFP_KERNEL);
|
hwmgr->ps = kcalloc(table_entries, size, GFP_KERNEL);
|
||||||
if (hwmgr->ps == NULL)
|
if (hwmgr->ps == NULL)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user