Commit ac0cc350 authored by Moritz Kühner's avatar Moritz Kühner Committed by Alex Deucher

drm/amd/powerplay/hwmgr: don't add invalid voltage

if atomctrl_get_voltage_evv_on_sclk returns non zero (fail) in the expansion
of the PP_ASSERT_WITH_CODE macro the continue will actually do nothing
(The macro uses a do ... while(0) as scope, which eats the continue).
Based on the code I don't think this was the intent.
Unfortunately fixing this requires rewriting the control flow and
removing the macros.

v2: added signed of by
fixed error message print

v3: agd: drop DRM_ERROR
Signed-off-by: default avatarMoritz Kühner <kuehner.moritz@gmail.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent c790f873
...@@ -432,19 +432,20 @@ int tonga_get_evv_voltage(struct pp_hwmgr *hwmgr) ...@@ -432,19 +432,20 @@ int tonga_get_evv_voltage(struct pp_hwmgr *hwmgr)
} }
} }
} }
PP_ASSERT_WITH_CODE(0 == atomctrl_get_voltage_evv_on_sclk if (0 == atomctrl_get_voltage_evv_on_sclk
(hwmgr, VOLTAGE_TYPE_VDDGFX, sclk, (hwmgr, VOLTAGE_TYPE_VDDGFX, sclk,
virtual_voltage_id, &vddgfx), virtual_voltage_id, &vddgfx)) {
"Error retrieving EVV voltage value!", continue); /* need to make sure vddgfx is less than 2v or else, it could burn the ASIC. */
PP_ASSERT_WITH_CODE((vddgfx < 2000 && vddgfx != 0), "Invalid VDDGFX value!", return -1);
/* need to make sure vddgfx is less than 2v or else, it could burn the ASIC. */
PP_ASSERT_WITH_CODE((vddgfx < 2000 && vddgfx != 0), "Invalid VDDGFX value!", return -1); /* the voltage should not be zero nor equal to leakage ID */
if (vddgfx != 0 && vddgfx != virtual_voltage_id) {
/* the voltage should not be zero nor equal to leakage ID */ data->vddcgfx_leakage.actual_voltage[data->vddcgfx_leakage.count] = vddgfx;
if (vddgfx != 0 && vddgfx != virtual_voltage_id) { data->vddcgfx_leakage.leakage_id[data->vddcgfx_leakage.count] = virtual_voltage_id;
data->vddcgfx_leakage.actual_voltage[data->vddcgfx_leakage.count] = vddgfx; data->vddcgfx_leakage.count++;
data->vddcgfx_leakage.leakage_id[data->vddcgfx_leakage.count] = virtual_voltage_id; }
data->vddcgfx_leakage.count++; } else {
printk("Error retrieving EVV voltage value!\n");
} }
} }
} else { } else {
...@@ -452,19 +453,20 @@ int tonga_get_evv_voltage(struct pp_hwmgr *hwmgr) ...@@ -452,19 +453,20 @@ int tonga_get_evv_voltage(struct pp_hwmgr *hwmgr)
if (0 == tonga_get_sclk_for_voltage_evv(hwmgr, if (0 == tonga_get_sclk_for_voltage_evv(hwmgr,
pptable_info->vddc_lookup_table, pptable_info->vddc_lookup_table,
virtual_voltage_id, &sclk)) { virtual_voltage_id, &sclk)) {
PP_ASSERT_WITH_CODE(0 == atomctrl_get_voltage_evv_on_sclk if (0 == atomctrl_get_voltage_evv_on_sclk
(hwmgr, VOLTAGE_TYPE_VDDC, sclk, (hwmgr, VOLTAGE_TYPE_VDDC, sclk,
virtual_voltage_id, &vddc), virtual_voltage_id, &vddc)) {
"Error retrieving EVV voltage value!", continue); /* need to make sure vddc is less than 2v or else, it could burn the ASIC. */
PP_ASSERT_WITH_CODE(vddc < 2000, "Invalid VDDC value!", return -1);
/* need to make sure vddc is less than 2v or else, it could burn the ASIC. */
PP_ASSERT_WITH_CODE(vddc < 2000, "Invalid VDDC value!", return -1); /* the voltage should not be zero nor equal to leakage ID */
if (vddc != 0 && vddc != virtual_voltage_id) {
/* the voltage should not be zero nor equal to leakage ID */ data->vddc_leakage.actual_voltage[data->vddc_leakage.count] = vddc;
if (vddc != 0 && vddc != virtual_voltage_id) { data->vddc_leakage.leakage_id[data->vddc_leakage.count] = virtual_voltage_id;
data->vddc_leakage.actual_voltage[data->vddc_leakage.count] = vddc; data->vddc_leakage.count++;
data->vddc_leakage.leakage_id[data->vddc_leakage.count] = virtual_voltage_id; }
data->vddc_leakage.count++; } else {
printk("Error retrieving EVV voltage value!\n");
} }
} }
} }
......
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