Commit f36f2648 authored by Cruise Hung's avatar Cruise Hung Committed by Alex Deucher

drm/amd/display: Fix DMUB debugging print issue

[Why]
The DMUB diagnostic data was not printed out correctly.

[How]
Print the DMUB diagnostic data line by line.
Reviewed-by: default avatarNicholas Kazlauskas <nicholas.kazlauskas@amd.com>
Acked-by: default avatarTom Chung <chiahsuan.chung@amd.com>
Signed-off-by: default avatarCruise Hung <cruise.hung@amd.com>
Tested-by: default avatarDaniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 73ade646
...@@ -4832,6 +4832,18 @@ void dc_process_dmub_dpia_hpd_int_enable(const struct dc *dc, ...@@ -4832,6 +4832,18 @@ void dc_process_dmub_dpia_hpd_int_enable(const struct dc *dc,
DC_LOG_DEBUG("%s: hpd_int_enable(%d)\n", __func__, hpd_int_enable); DC_LOG_DEBUG("%s: hpd_int_enable(%d)\n", __func__, hpd_int_enable);
} }
/**
* dc_print_dmub_diagnostic_data - Print DMUB diagnostic data for debugging
*
* @dc: [in] dc structure
*
*
*/
void dc_print_dmub_diagnostic_data(const struct dc *dc)
{
dc_dmub_srv_log_diagnostic_data(dc->ctx->dmub_srv);
}
/** /**
* dc_disable_accelerated_mode - disable accelerated mode * dc_disable_accelerated_mode - disable accelerated mode
* @dc: dc structure * @dc: dc structure
......
...@@ -2236,6 +2236,8 @@ enum dc_status dc_process_dmub_set_mst_slots(const struct dc *dc, ...@@ -2236,6 +2236,8 @@ enum dc_status dc_process_dmub_set_mst_slots(const struct dc *dc,
void dc_process_dmub_dpia_hpd_int_enable(const struct dc *dc, void dc_process_dmub_dpia_hpd_int_enable(const struct dc *dc,
uint32_t hpd_int_enable); uint32_t hpd_int_enable);
void dc_print_dmub_diagnostic_data(const struct dc *dc);
/* DSC Interfaces */ /* DSC Interfaces */
#include "dc_dsc.h" #include "dc_dsc.h"
......
...@@ -169,6 +169,7 @@ bool dc_dmub_srv_cmd_run_list(struct dc_dmub_srv *dc_dmub_srv, unsigned int coun ...@@ -169,6 +169,7 @@ bool dc_dmub_srv_cmd_run_list(struct dc_dmub_srv *dc_dmub_srv, unsigned int coun
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);
dc_dmub_srv_log_diagnostic_data(dc_dmub_srv);
return false; return false;
} }
...@@ -797,74 +798,40 @@ void dc_dmub_srv_log_diagnostic_data(struct dc_dmub_srv *dc_dmub_srv) ...@@ -797,74 +798,40 @@ void dc_dmub_srv_log_diagnostic_data(struct dc_dmub_srv *dc_dmub_srv)
return; return;
} }
DC_LOG_DEBUG( DC_LOG_DEBUG("DMCUB STATE:");
"DMCUB STATE\n" DC_LOG_DEBUG(" dmcub_version : %08x", diag_data.dmcub_version);
" dmcub_version : %08x\n" DC_LOG_DEBUG(" scratch [0] : %08x", diag_data.scratch[0]);
" scratch [0] : %08x\n" DC_LOG_DEBUG(" scratch [1] : %08x", diag_data.scratch[1]);
" scratch [1] : %08x\n" DC_LOG_DEBUG(" scratch [2] : %08x", diag_data.scratch[2]);
" scratch [2] : %08x\n" DC_LOG_DEBUG(" scratch [3] : %08x", diag_data.scratch[3]);
" scratch [3] : %08x\n" DC_LOG_DEBUG(" scratch [4] : %08x", diag_data.scratch[4]);
" scratch [4] : %08x\n" DC_LOG_DEBUG(" scratch [5] : %08x", diag_data.scratch[5]);
" scratch [5] : %08x\n" DC_LOG_DEBUG(" scratch [6] : %08x", diag_data.scratch[6]);
" scratch [6] : %08x\n" DC_LOG_DEBUG(" scratch [7] : %08x", diag_data.scratch[7]);
" scratch [7] : %08x\n" DC_LOG_DEBUG(" scratch [8] : %08x", diag_data.scratch[8]);
" scratch [8] : %08x\n" DC_LOG_DEBUG(" scratch [9] : %08x", diag_data.scratch[9]);
" scratch [9] : %08x\n" DC_LOG_DEBUG(" scratch [10] : %08x", diag_data.scratch[10]);
" scratch [10] : %08x\n" DC_LOG_DEBUG(" scratch [11] : %08x", diag_data.scratch[11]);
" scratch [11] : %08x\n" DC_LOG_DEBUG(" scratch [12] : %08x", diag_data.scratch[12]);
" scratch [12] : %08x\n" DC_LOG_DEBUG(" scratch [13] : %08x", diag_data.scratch[13]);
" scratch [13] : %08x\n" DC_LOG_DEBUG(" scratch [14] : %08x", diag_data.scratch[14]);
" scratch [14] : %08x\n" DC_LOG_DEBUG(" scratch [15] : %08x", diag_data.scratch[15]);
" scratch [15] : %08x\n" DC_LOG_DEBUG(" pc : %08x", diag_data.pc);
" pc : %08x\n" DC_LOG_DEBUG(" unk_fault_addr : %08x", diag_data.undefined_address_fault_addr);
" unk_fault_addr : %08x\n" DC_LOG_DEBUG(" inst_fault_addr : %08x", diag_data.inst_fetch_fault_addr);
" inst_fault_addr : %08x\n" DC_LOG_DEBUG(" data_fault_addr : %08x", diag_data.data_write_fault_addr);
" data_fault_addr : %08x\n" DC_LOG_DEBUG(" inbox1_rptr : %08x", diag_data.inbox1_rptr);
" inbox1_rptr : %08x\n" DC_LOG_DEBUG(" inbox1_wptr : %08x", diag_data.inbox1_wptr);
" inbox1_wptr : %08x\n" DC_LOG_DEBUG(" inbox1_size : %08x", diag_data.inbox1_size);
" inbox1_size : %08x\n" DC_LOG_DEBUG(" inbox0_rptr : %08x", diag_data.inbox0_rptr);
" inbox0_rptr : %08x\n" DC_LOG_DEBUG(" inbox0_wptr : %08x", diag_data.inbox0_wptr);
" inbox0_wptr : %08x\n" DC_LOG_DEBUG(" inbox0_size : %08x", diag_data.inbox0_size);
" inbox0_size : %08x\n" DC_LOG_DEBUG(" is_enabled : %d", diag_data.is_dmcub_enabled);
" is_enabled : %d\n" DC_LOG_DEBUG(" is_soft_reset : %d", diag_data.is_dmcub_soft_reset);
" is_soft_reset : %d\n" DC_LOG_DEBUG(" is_secure_reset : %d", diag_data.is_dmcub_secure_reset);
" is_secure_reset : %d\n" DC_LOG_DEBUG(" is_traceport_en : %d", diag_data.is_traceport_en);
" is_traceport_en : %d\n" DC_LOG_DEBUG(" is_cw0_en : %d", diag_data.is_cw0_enabled);
" is_cw0_en : %d\n" DC_LOG_DEBUG(" is_cw6_en : %d", diag_data.is_cw6_enabled);
" is_cw6_en : %d\n",
diag_data.dmcub_version,
diag_data.scratch[0],
diag_data.scratch[1],
diag_data.scratch[2],
diag_data.scratch[3],
diag_data.scratch[4],
diag_data.scratch[5],
diag_data.scratch[6],
diag_data.scratch[7],
diag_data.scratch[8],
diag_data.scratch[9],
diag_data.scratch[10],
diag_data.scratch[11],
diag_data.scratch[12],
diag_data.scratch[13],
diag_data.scratch[14],
diag_data.scratch[15],
diag_data.pc,
diag_data.undefined_address_fault_addr,
diag_data.inst_fetch_fault_addr,
diag_data.data_write_fault_addr,
diag_data.inbox1_rptr,
diag_data.inbox1_wptr,
diag_data.inbox1_size,
diag_data.inbox0_rptr,
diag_data.inbox0_wptr,
diag_data.inbox0_size,
diag_data.is_dmcub_enabled,
diag_data.is_dmcub_soft_reset,
diag_data.is_dmcub_secure_reset,
diag_data.is_traceport_en,
diag_data.is_cw0_enabled,
diag_data.is_cw6_enabled);
} }
static bool dc_can_pipe_disable_cursor(struct pipe_ctx *pipe_ctx) static bool dc_can_pipe_disable_cursor(struct pipe_ctx *pipe_ctx)
......
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