On 15/11/16 15:49, Deucher, Alexander wrote: >> -----Original Message----- >> From: Colin King [mailto:colin.king at canonical.com] >> Sent: Tuesday, November 15, 2016 7:55 AM >> To: Deucher, Alexander; Koenig, Christian; David Airlie; Zhu, Rex; StDenis, >> Tom; Huang, Ray; Nils Wallménius; Baoyou Xie; dri- >> devel at lists.freedesktop.org >> Cc: linux-kernel at vger.kernel.org >> Subject: [PATCH] drm/amd/powerplay: check if table_info is NULL before >> dereferencing it >> >> From: Colin Ian King <colin.king at canonical.com> >> >> table_info is being dereferenced before a null check, which implies >> a potential null pointer deference error. Fix this by moving the null >> check of table_info to the start of smu7_get_evv_voltages to avoid >> potential null pointer deferencing. >> >> Found with static analysis by CoverityScan, CID 1377752 >> >> Signed-off-by: Colin Ian King <colin.king at canonical.com> > > NACK, this effectively reverts the patch. This causes the function to exit > early on asics where the table it NULL which is not what we want. Whether > the table exists or not is dependent on the table version and the feature > caps for the chip which are checked before the table is dereferenced. The > NULL check in the top if clause is not strictly necessary and could be > removed. > > Alex
OK, understood. The part I'm missing is that we dereference table_info at the following statement: if ((hwmgr->pp_table_version == PP_TABLE_V1) && !phm_get_sclk_for_voltage_evv(hwmgr, table_info->vddgfx_lookup_table, vv_id, &sclk)) and later check if it is NULL. So, I can't see where table_info is being set other than the start of the function, so, either it can be null and hence we have a null ptr deference, or it's never null, in which case the check for NULL is redundant. Colin > >> --- >> drivers/gpu/drm/amd/powerplay/hwmgr/smu7_hwmgr.c | 6 ++---- >> 1 file changed, 2 insertions(+), 4 deletions(-) >> >> diff --git a/drivers/gpu/drm/amd/powerplay/hwmgr/smu7_hwmgr.c >> b/drivers/gpu/drm/amd/powerplay/hwmgr/smu7_hwmgr.c >> index 28e748d..6798067 100644 >> --- a/drivers/gpu/drm/amd/powerplay/hwmgr/smu7_hwmgr.c >> +++ b/drivers/gpu/drm/amd/powerplay/hwmgr/smu7_hwmgr.c >> @@ -1473,6 +1473,8 @@ static int smu7_get_evv_voltages(struct pp_hwmgr >> *hwmgr) >> (struct phm_ppt_v1_information *)hwmgr->pptable; >> struct phm_ppt_v1_clock_voltage_dependency_table *sclk_table = >> NULL; >> >> + if (table_info == NULL) >> + return -EINVAL; >> >> for (i = 0; i < SMU7_MAX_LEAKAGE_COUNT; i++) { >> vv_id = ATOM_VIRTUAL_VOLTAGE_ID0 + i; >> @@ -1483,8 +1485,6 @@ static int smu7_get_evv_voltages(struct pp_hwmgr >> *hwmgr) >> table_info- >>> vddgfx_lookup_table, vv_id, &sclk)) { >> if (phm_cap_enabled(hwmgr- >>> platform_descriptor.platformCaps, >> >> PHM_PlatformCaps_ClockStretcher)) { >> - if (table_info == NULL) >> - return -EINVAL; >> sclk_table = table_info- >>> vdd_dep_on_sclk; >> >> for (j = 1; j < sclk_table->count; j++) >> { >> @@ -1517,8 +1517,6 @@ static int smu7_get_evv_voltages(struct pp_hwmgr >> *hwmgr) >> table_info->vddc_lookup_table, >> vv_id, &sclk)) { >> if (phm_cap_enabled(hwmgr- >>> platform_descriptor.platformCaps, >> >> PHM_PlatformCaps_ClockStretcher)) { >> - if (table_info == NULL) >> - return -EINVAL; >> sclk_table = table_info- >>> vdd_dep_on_sclk; >> >> for (j = 1; j < sclk_table->count; j++) >> { >> -- >> 2.10.2 >