Commit cc6201b7 authored by Duncan Ma's avatar Duncan Ma Committed by Alex Deucher

drm/amd/display: Add disable timeout option

[WHY]
Driver continues running whenever there is
is timeout from smu or dmcub.

It is difficult to track failure state
when dcn, dc or dmcub changes on root failure.

[HOW]
Add disable_timeout option to halt driver
whenever there is a failure in response.
Reviewed-by: default avatarCharlene Liu <charlene.liu@amd.com>
Acked-by: default avatarAlex Hung <alex.hung@amd.com>
Signed-off-by: default avatarDuncan Ma <duncan.ma@amd.com>
Tested-by: default avatarDaniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 5f70d4ff
...@@ -116,6 +116,9 @@ static uint32_t dcn35_smu_wait_for_response(struct clk_mgr_internal *clk_mgr, un ...@@ -116,6 +116,9 @@ static uint32_t dcn35_smu_wait_for_response(struct clk_mgr_internal *clk_mgr, un
msleep(delay_us/1000); msleep(delay_us/1000);
else if (delay_us > 0) else if (delay_us > 0)
udelay(delay_us); udelay(delay_us);
if (clk_mgr->base.ctx->dc->debug.disable_timeout)
max_retries++;
} while (max_retries--); } while (max_retries--);
return res_val; return res_val;
......
...@@ -978,6 +978,7 @@ struct dc_debug_options { ...@@ -978,6 +978,7 @@ struct dc_debug_options {
bool psp_disabled_wa; bool psp_disabled_wa;
unsigned int ips2_eval_delay_us; unsigned int ips2_eval_delay_us;
unsigned int ips2_entry_delay_us; unsigned int ips2_entry_delay_us;
bool disable_timeout;
}; };
struct gpu_info_soc_bounding_box_v1_0; struct gpu_info_soc_bounding_box_v1_0;
......
...@@ -241,7 +241,12 @@ bool dc_dmub_srv_cmd_run_list(struct dc_dmub_srv *dc_dmub_srv, unsigned int coun ...@@ -241,7 +241,12 @@ bool dc_dmub_srv_cmd_run_list(struct dc_dmub_srv *dc_dmub_srv, unsigned int coun
// Wait for DMUB to process command // Wait for DMUB to process command
if (wait_type != DM_DMUB_WAIT_TYPE_NO_WAIT) { if (wait_type != DM_DMUB_WAIT_TYPE_NO_WAIT) {
status = dmub_srv_wait_for_idle(dmub, 100000); if (dc_dmub_srv->ctx->dc->debug.disable_timeout) {
do {
status = dmub_srv_wait_for_idle(dmub, 100000);
} while (status != DMUB_STATUS_OK);
} else
status = dmub_srv_wait_for_idle(dmub, 100000);
if (status != DMUB_STATUS_OK) { if (status != DMUB_STATUS_OK) {
DC_LOG_DEBUG("No reply for DMUB command: status=%d\n", status); DC_LOG_DEBUG("No reply for DMUB command: status=%d\n", status);
...@@ -1147,10 +1152,16 @@ bool dc_dmub_srv_is_hw_pwr_up(struct dc_dmub_srv *dc_dmub_srv, bool wait) ...@@ -1147,10 +1152,16 @@ bool dc_dmub_srv_is_hw_pwr_up(struct dc_dmub_srv *dc_dmub_srv, bool wait)
return true; return true;
if (wait) { if (wait) {
status = dmub_srv_wait_for_hw_pwr_up(dc_dmub_srv->dmub, 500000); if (dc_dmub_srv->ctx->dc->debug.disable_timeout) {
if (status != DMUB_STATUS_OK) { do {
DC_ERROR("Error querying DMUB hw power up status: error=%d\n", status); status = dmub_srv_wait_for_hw_pwr_up(dc_dmub_srv->dmub, 500000);
return false; } while (status != DMUB_STATUS_OK);
} else {
status = dmub_srv_wait_for_hw_pwr_up(dc_dmub_srv->dmub, 500000);
if (status != DMUB_STATUS_OK) {
DC_ERROR("Error querying DMUB hw power up status: error=%d\n", status);
return false;
}
} }
} else } else
return dmub_srv_is_hw_pwr_up(dc_dmub_srv->dmub); return dmub_srv_is_hw_pwr_up(dc_dmub_srv->dmub);
...@@ -1187,7 +1198,7 @@ void dc_dmub_srv_exit_low_power_state(const struct dc *dc) ...@@ -1187,7 +1198,7 @@ void dc_dmub_srv_exit_low_power_state(const struct dc *dc)
const uint32_t max_num_polls = 10000; const uint32_t max_num_polls = 10000;
uint32_t allow_state = 0; uint32_t allow_state = 0;
uint32_t commit_state = 0; uint32_t commit_state = 0;
uint32_t i; int i;
if (dc->debug.dmcub_emulation) if (dc->debug.dmcub_emulation)
return; return;
...@@ -1220,6 +1231,9 @@ void dc_dmub_srv_exit_low_power_state(const struct dc *dc) ...@@ -1220,6 +1231,9 @@ void dc_dmub_srv_exit_low_power_state(const struct dc *dc)
break; break;
udelay(1); udelay(1);
if (dc->debug.disable_timeout)
i--;
} }
ASSERT(i < max_num_polls); ASSERT(i < max_num_polls);
...@@ -1242,6 +1256,9 @@ void dc_dmub_srv_exit_low_power_state(const struct dc *dc) ...@@ -1242,6 +1256,9 @@ void dc_dmub_srv_exit_low_power_state(const struct dc *dc)
break; break;
udelay(1); udelay(1);
if (dc->debug.disable_timeout)
i--;
} }
ASSERT(i < max_num_polls); ASSERT(i < max_num_polls);
} }
......
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