提交 60bf1860 编写于 作者: A Andrey Grodzovsky 提交者: Alex Deucher

drm/amd/display: Preserve refcount for S3 case.

Curent_context is zerroed out for suspend, keep the refcount.
Minor code move in dc_commit_context_no_check
Signed-off-by: NAndrey Grodzovsky <Andrey.Grodzovsky@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>
上级 587cdfe9
...@@ -977,10 +977,10 @@ static bool dc_commit_context_no_check(struct dc *dc, struct validate_context *c ...@@ -977,10 +977,10 @@ static bool dc_commit_context_no_check(struct dc *dc, struct validate_context *c
dc_release_validate_context(core_dc->current_context); dc_release_validate_context(core_dc->current_context);
dc_retain_validate_context(context);
core_dc->current_context = context; core_dc->current_context = context;
dc_retain_validate_context(core_dc->current_context);
return (result == DC_OK); return (result == DC_OK);
} }
...@@ -1065,8 +1065,6 @@ bool dc_commit_streams( ...@@ -1065,8 +1065,6 @@ bool dc_commit_streams(
result = dc_commit_context_no_check(dc, context); result = dc_commit_context_no_check(dc, context);
return (result == DC_OK);
fail: fail:
dc_release_validate_context(context); dc_release_validate_context(context);
...@@ -1736,6 +1734,7 @@ void dc_set_power_state( ...@@ -1736,6 +1734,7 @@ void dc_set_power_state(
enum dc_acpi_cm_power_state power_state) enum dc_acpi_cm_power_state power_state)
{ {
struct core_dc *core_dc = DC_TO_CORE(dc); struct core_dc *core_dc = DC_TO_CORE(dc);
int ref_count;
switch (power_state) { switch (power_state) {
case DC_ACPI_CM_POWER_STATE_D0: case DC_ACPI_CM_POWER_STATE_D0:
...@@ -1749,8 +1748,13 @@ void dc_set_power_state( ...@@ -1749,8 +1748,13 @@ void dc_set_power_state(
* clean state, and dc hw programming optimizations will not * clean state, and dc hw programming optimizations will not
* cause any trouble. * cause any trouble.
*/ */
/* Preserve refcount */
ref_count = core_dc->current_context->ref_count;
dc_resource_validate_ctx_destruct(core_dc->current_context);
memset(core_dc->current_context, 0, memset(core_dc->current_context, 0,
sizeof(*core_dc->current_context)); sizeof(*core_dc->current_context));
core_dc->current_context->ref_count = ref_count;
break; break;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册