mirror of https://gitee.com/openkylin/linux.git
drm/amd/powerplay: off by one bugs in smu_cmn_to_asic_specific_index()
These tables have _COUNT number of elements so the comparisons should be
>= instead of > to prevent reading one element beyond the end of the
array.
Fixes: 8264ee69f0
("drm/amd/powerplay: drop unused code")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
a486bc3c50
commit
68bb3c3ff9
|
@ -166,7 +166,7 @@ int smu_cmn_to_asic_specific_index(struct smu_context *smu,
|
|||
|
||||
switch (type) {
|
||||
case CMN2ASIC_MAPPING_MSG:
|
||||
if (index > SMU_MSG_MAX_COUNT ||
|
||||
if (index >= SMU_MSG_MAX_COUNT ||
|
||||
!smu->message_map)
|
||||
return -EINVAL;
|
||||
|
||||
|
@ -181,7 +181,7 @@ int smu_cmn_to_asic_specific_index(struct smu_context *smu,
|
|||
return msg_mapping.map_to;
|
||||
|
||||
case CMN2ASIC_MAPPING_CLK:
|
||||
if (index > SMU_CLK_COUNT ||
|
||||
if (index >= SMU_CLK_COUNT ||
|
||||
!smu->clock_map)
|
||||
return -EINVAL;
|
||||
|
||||
|
@ -192,7 +192,7 @@ int smu_cmn_to_asic_specific_index(struct smu_context *smu,
|
|||
return mapping.map_to;
|
||||
|
||||
case CMN2ASIC_MAPPING_FEATURE:
|
||||
if (index > SMU_FEATURE_COUNT ||
|
||||
if (index >= SMU_FEATURE_COUNT ||
|
||||
!smu->feature_map)
|
||||
return -EINVAL;
|
||||
|
||||
|
@ -203,7 +203,7 @@ int smu_cmn_to_asic_specific_index(struct smu_context *smu,
|
|||
return mapping.map_to;
|
||||
|
||||
case CMN2ASIC_MAPPING_TABLE:
|
||||
if (index > SMU_TABLE_COUNT ||
|
||||
if (index >= SMU_TABLE_COUNT ||
|
||||
!smu->table_map)
|
||||
return -EINVAL;
|
||||
|
||||
|
@ -214,7 +214,7 @@ int smu_cmn_to_asic_specific_index(struct smu_context *smu,
|
|||
return mapping.map_to;
|
||||
|
||||
case CMN2ASIC_MAPPING_PWR:
|
||||
if (index > SMU_POWER_SOURCE_COUNT ||
|
||||
if (index >= SMU_POWER_SOURCE_COUNT ||
|
||||
!smu->pwr_src_map)
|
||||
return -EINVAL;
|
||||
|
||||
|
|
Loading…
Reference in New Issue