Commit 501b4026 authored by Wyatt Wood's avatar Wyatt Wood Committed by Alex Deucher

drm/amd/display: Use config flag to disable dmcu obj creation

[Why]
When dmcub is the default we no longer wish to create the psr and dmcu
objects. Currently a dc debug flag is used to implement this, but these
flags aren't populated until after dcn21_resource_construct is called.
This means the dmcub objects will never be created. Therefore we must
use a dc config flag, which is populated before dc resource construct.

[How]
Add a dc config flag.
Signed-off-by: default avatarWyatt Wood <wyatt.wood@amd.com>
Reviewed-by: default avatarNicholas Kazlauskas <Nicholas.Kazlauskas@amd.com>
Acked-by: default avatarRodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent d5e27f07
...@@ -230,7 +230,7 @@ struct dc_config { ...@@ -230,7 +230,7 @@ struct dc_config {
bool forced_clocks; bool forced_clocks;
bool disable_extended_timeout_support; // Used to disable extended timeout and lttpr feature as well bool disable_extended_timeout_support; // Used to disable extended timeout and lttpr feature as well
bool multi_mon_pp_mclk_switch; bool multi_mon_pp_mclk_switch;
bool psr_on_dmub; bool disable_dmcu;
}; };
enum visual_confirm { enum visual_confirm {
......
...@@ -993,7 +993,7 @@ static void dcn21_resource_destruct(struct dcn21_resource_pool *pool) ...@@ -993,7 +993,7 @@ static void dcn21_resource_destruct(struct dcn21_resource_pool *pool)
} }
if (pool->base.abm != NULL) { if (pool->base.abm != NULL) {
if (pool->base.abm->ctx->dc->debug.disable_dmcu) if (pool->base.abm->ctx->dc->config.disable_dmcu)
dmub_abm_destroy(&pool->base.abm); dmub_abm_destroy(&pool->base.abm);
else else
dce_abm_destroy(&pool->base.abm); dce_abm_destroy(&pool->base.abm);
...@@ -1846,7 +1846,7 @@ static bool dcn21_resource_construct( ...@@ -1846,7 +1846,7 @@ static bool dcn21_resource_construct(
goto create_fail; goto create_fail;
} }
if (!dc->debug.disable_dmcu) { if (!dc->config.disable_dmcu) {
pool->base.dmcu = dcn21_dmcu_create(ctx, pool->base.dmcu = dcn21_dmcu_create(ctx,
&dmcu_regs, &dmcu_regs,
&dmcu_shift, &dmcu_shift,
...@@ -1858,7 +1858,7 @@ static bool dcn21_resource_construct( ...@@ -1858,7 +1858,7 @@ static bool dcn21_resource_construct(
} }
} }
if (dc->debug.disable_dmcu) { if (dc->config.disable_dmcu) {
pool->base.psr = dmub_psr_create(ctx); pool->base.psr = dmub_psr_create(ctx);
if (pool->base.psr == NULL) { if (pool->base.psr == NULL) {
...@@ -1868,7 +1868,7 @@ static bool dcn21_resource_construct( ...@@ -1868,7 +1868,7 @@ static bool dcn21_resource_construct(
} }
} }
if (dc->debug.disable_dmcu) if (dc->config.disable_dmcu)
pool->base.abm = dmub_abm_create(ctx, pool->base.abm = dmub_abm_create(ctx,
&abm_regs, &abm_regs,
&abm_shift, &abm_shift,
......
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