From: Alvin Lee <alvin.l...@amd.com>

[Description]
Refcount is incremented on allocation and
when adding to the context. Therefore we must
release the phantom plane and stream after
removing from the context.

Reviewed-by: Aric Cyr <aric....@amd.com>
Acked-by: Brian Chang <brian.ch...@amd.com>
Signed-off-by: Alvin Lee <alvin.l...@amd.com>
---
 .../gpu/drm/amd/display/dc/dcn32/dcn32_resource.c   | 13 +++++++++++++
 1 file changed, 13 insertions(+)

diff --git a/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_resource.c 
b/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_resource.c
index b8a9606863f8..194d7dbdbcd7 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_resource.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_resource.c
@@ -1729,13 +1729,26 @@ bool dcn32_remove_phantom_pipes(struct dc *dc, struct 
dc_state *context)
 {
        int i;
        bool removed_pipe = false;
+       struct dc_plane_state *phantom_plane = NULL;
+       struct dc_stream_state *phantom_stream = NULL;
 
        for (i = 0; i < dc->res_pool->pipe_count; i++) {
                struct pipe_ctx *pipe = &context->res_ctx.pipe_ctx[i];
                // build scaling params for phantom pipes
                if (pipe->plane_state && pipe->stream && 
pipe->stream->mall_stream_config.type == SUBVP_PHANTOM) {
+                       phantom_plane = pipe->plane_state;
+                       phantom_stream = pipe->stream;
+
                        dc_rem_all_planes_for_stream(dc, pipe->stream, context);
                        dc_remove_stream_from_ctx(dc, context, pipe->stream);
+
+                       /* Ref count is incremented on allocation and also when 
added to the context.
+                        * Therefore we must call release for the the phantom 
plane and stream once
+                        * they are removed from the ctx to finally decrement 
the refcount to 0 to free.
+                        */
+                       dc_plane_state_release(phantom_plane);
+                       dc_stream_release(phantom_stream);
+
                        removed_pipe = true;
                }
 
-- 
2.25.1

Reply via email to