提交 a052a516 编写于 作者: D Dmytro Laktyushkin 提交者: Alex Deucher

drm/amd/display: align dtn logs and add mpc idle bit print

Signed-off-by: NDmytro Laktyushkin <Dmytro.Laktyushkin@amd.com>
Reviewed-by: NTony Cheng <Tony.Cheng@amd.com>
Acked-by: NHarry Wentland <harry.wentland@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 8a6095e0
...@@ -56,16 +56,17 @@ ...@@ -56,16 +56,17 @@
#define FN(reg_name, field_name) \ #define FN(reg_name, field_name) \
hws->shifts->field_name, hws->masks->field_name hws->shifts->field_name, hws->masks->field_name
/*print is 17 wide, first two characters are spaces*/
#define DTN_INFO_MICRO_SEC(ref_cycle) \ #define DTN_INFO_MICRO_SEC(ref_cycle) \
print_microsec(dc_ctx, ref_cycle) print_microsec(dc_ctx, ref_cycle)
void print_microsec(struct dc_context *dc_ctx, uint32_t ref_cycle) void print_microsec(struct dc_context *dc_ctx, uint32_t ref_cycle)
{ {
static const uint32_t ref_clk_mhz = 48; const uint32_t ref_clk_mhz = dc_ctx->dc->res_pool->ref_clock_inKhz / 1000;
static const unsigned int frac = 10; static const unsigned int frac = 1000;
uint32_t us_x10 = (ref_cycle * frac) / ref_clk_mhz; uint32_t us_x10 = (ref_cycle * frac) / ref_clk_mhz;
DTN_INFO("%d.%d \t ", DTN_INFO(" %11d.%03d",
us_x10 / frac, us_x10 / frac,
us_x10 % frac); us_x10 % frac);
} }
...@@ -92,14 +93,14 @@ void dcn10_log_hubbub_state(struct dc *dc) ...@@ -92,14 +93,14 @@ void dcn10_log_hubbub_state(struct dc *dc)
hubbub1_wm_read_state(dc->res_pool->hubbub, &wm); hubbub1_wm_read_state(dc->res_pool->hubbub, &wm);
DTN_INFO("HUBBUB WM: \t data_urgent \t pte_meta_urgent \t " DTN_INFO("HUBBUB WM: data_urgent pte_meta_urgent"
"sr_enter \t sr_exit \t dram_clk_change \n"); " sr_enter sr_exit dram_clk_change\n");
for (i = 0; i < 4; i++) { for (i = 0; i < 4; i++) {
struct dcn_hubbub_wm_set *s; struct dcn_hubbub_wm_set *s;
s = &wm.sets[i]; s = &wm.sets[i];
DTN_INFO("WM_Set[%d]:\t ", s->wm_set); DTN_INFO("WM_Set[%d]:", s->wm_set);
DTN_INFO_MICRO_SEC(s->data_urgent); DTN_INFO_MICRO_SEC(s->data_urgent);
DTN_INFO_MICRO_SEC(s->pte_meta_urgent); DTN_INFO_MICRO_SEC(s->pte_meta_urgent);
DTN_INFO_MICRO_SEC(s->sr_enter); DTN_INFO_MICRO_SEC(s->sr_enter);
...@@ -121,19 +122,17 @@ void dcn10_log_hw_state(struct dc *dc) ...@@ -121,19 +122,17 @@ void dcn10_log_hw_state(struct dc *dc)
dcn10_log_hubbub_state(dc); dcn10_log_hubbub_state(dc);
DTN_INFO("HUBP: format addr_hi width height " DTN_INFO("HUBP: format addr_hi width height"
"rotation mirror sw_mode " " rot mir sw_mode dcc_en blank_en ttu_dis underflow"
"dcc_en blank_en ttu_dis underflow " " min_ttu_vblank qos_low_wm qos_high_wm\n");
"min_ttu_vblank qos_low_wm qos_high_wm\n");
for (i = 0; i < pool->pipe_count; i++) { for (i = 0; i < pool->pipe_count; i++) {
struct hubp *hubp = pool->hubps[i]; struct hubp *hubp = pool->hubps[i];
struct dcn_hubp_state s; struct dcn_hubp_state s;
hubp1_read_state(TO_DCN10_HUBP(hubp), &s); hubp1_read_state(TO_DCN10_HUBP(hubp), &s);
DTN_INFO("[%-2d]: %5xh %6xh %5d %6d " DTN_INFO("[%2d]: %5xh %6xh %5d %6d %2xh %2xh %6xh"
"%7xh %5xh %6xh " " %6d %8d %7d %8xh",
"%6d %8d %7d %8xh \t",
hubp->inst, hubp->inst,
s.pixel_format, s.pixel_format,
s.inuse_addr_hi, s.inuse_addr_hi,
...@@ -152,25 +151,21 @@ void dcn10_log_hw_state(struct dc *dc) ...@@ -152,25 +151,21 @@ void dcn10_log_hw_state(struct dc *dc)
DTN_INFO("\n"); DTN_INFO("\n");
} }
DTN_INFO("\n"); DTN_INFO("\n");
DTN_INFO("MPCC: OPP DPP MPCCBOT MODE ALPHA_MODE PREMULT OVERLAP_ONLY IDLE\n");
for (i = 0; i < pool->pipe_count; i++) { for (i = 0; i < pool->pipe_count; i++) {
struct output_pixel_processor *opp = pool->opps[i];
struct mpcc *mpcc = opp->mpc_tree_params.opp_list;
struct mpcc_state s = {0}; struct mpcc_state s = {0};
while (mpcc) { pool->mpc->funcs->read_mpcc_state(pool->mpc, i, &s);
ASSERT(opp->mpc_tree_params.opp_id == opp->inst); DTN_INFO("[%2d]: %2xh %2xh %6xh %4d %10d %7d %12d %4d\n",
pool->mpc->funcs->read_mpcc_state(pool->mpc, mpcc->mpcc_id, &s); i, s.opp_id, s.dpp_id, s.bot_mpcc_id,
DTN_INFO("[OPP%d - MPCC%d]: DPP%d MPCCBOT%x MODE:%d ALPHA_MODE:%d PREMULT:%d OVERLAP_ONLY:%d\n", s.mode, s.alpha_mode, s.pre_multiplied_alpha, s.overlap_only,
s.opp_id, mpcc->mpcc_id, s.dpp_id, s.bot_mpcc_id, s.idle);
s.mode, s.alpha_mode, s.pre_multiplied_alpha, s.overlap_only);
mpcc = mpcc->mpcc_bot;
ASSERT(!mpcc || mpcc->mpcc_id == s.bot_mpcc_id);
}
} }
DTN_INFO("\n"); DTN_INFO("\n");
DTN_INFO("OTG:\t v_bs \t v_be \t v_ss \t v_se \t vpol \t vmax \t vmin \t " DTN_INFO("OTG: v_bs v_be v_ss v_se vpol vmax vmin"
"h_bs \t h_be \t h_ss \t h_se \t hpol \t htot \t vtot \t underflow\n"); " h_bs h_be h_ss h_se hpol htot vtot underflow\n");
for (i = 0; i < pool->timing_generator_count; i++) { for (i = 0; i < pool->timing_generator_count; i++) {
struct timing_generator *tg = pool->timing_generators[i]; struct timing_generator *tg = pool->timing_generators[i];
...@@ -182,9 +177,8 @@ void dcn10_log_hw_state(struct dc *dc) ...@@ -182,9 +177,8 @@ void dcn10_log_hw_state(struct dc *dc)
if ((s.otg_enabled & 1) == 0) if ((s.otg_enabled & 1) == 0)
continue; continue;
DTN_INFO("[%d]:\t %d \t %d \t %d \t %d \t " DTN_INFO("[%d]: %5d %5d %5d %5d %5d %5d %5d %5d %5d %5d"
"%d \t %d \t %d \t %d \t %d \t %d \t " " %5d %5d %5d %5d %9d\n",
"%d \t %d \t %d \t %d \t %d \t ",
tg->inst, tg->inst,
s.v_blank_start, s.v_blank_start,
s.v_blank_end, s.v_blank_end,
...@@ -201,7 +195,6 @@ void dcn10_log_hw_state(struct dc *dc) ...@@ -201,7 +195,6 @@ void dcn10_log_hw_state(struct dc *dc)
s.h_total, s.h_total,
s.v_total, s.v_total,
s.underflow_occurred_status); s.underflow_occurred_status);
DTN_INFO("\n");
} }
DTN_INFO("\n"); DTN_INFO("\n");
......
...@@ -422,7 +422,9 @@ void mpc1_read_mpcc_state( ...@@ -422,7 +422,9 @@ void mpc1_read_mpcc_state(
REG_GET_4(MPCC_CONTROL[mpcc_inst], MPCC_MODE, &s->mode, REG_GET_4(MPCC_CONTROL[mpcc_inst], MPCC_MODE, &s->mode,
MPCC_ALPHA_BLND_MODE, &s->alpha_mode, MPCC_ALPHA_BLND_MODE, &s->alpha_mode,
MPCC_ALPHA_MULTIPLIED_MODE, &s->pre_multiplied_alpha, MPCC_ALPHA_MULTIPLIED_MODE, &s->pre_multiplied_alpha,
MPCC_BLND_ACTIVE_OVERLAP_ONLY, &s->pre_multiplied_alpha); MPCC_BLND_ACTIVE_OVERLAP_ONLY, &s->overlap_only);
REG_GET_2(MPCC_STATUS[mpcc_inst], MPCC_IDLE, &s->idle,
MPCC_BUSY, &s->busy);
} }
const struct mpc_funcs dcn10_mpc_funcs = { const struct mpc_funcs dcn10_mpc_funcs = {
......
...@@ -113,6 +113,8 @@ struct mpcc_state { ...@@ -113,6 +113,8 @@ struct mpcc_state {
uint32_t alpha_mode; uint32_t alpha_mode;
uint32_t pre_multiplied_alpha; uint32_t pre_multiplied_alpha;
uint32_t overlap_only; uint32_t overlap_only;
uint32_t idle;
uint32_t busy;
}; };
struct mpc_funcs { struct mpc_funcs {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册