From: Wenjing Liu <wenjing....@amd.com>

[why]
Need DML2 to support new pipe resource management APIs.

Reviewed-by: Chaitanya Dhere <chaitanya.dh...@amd.com>
Acked-by: Roman Li <roman...@amd.com>
Signed-off-by: Wenjing Liu <wenjing....@amd.com>
---
 .../gpu/drm/amd/display/dc/dcn32/dcn32_resource.c |  5 +++++
 .../drm/amd/display/dc/dcn321/dcn321_resource.c   |  5 +++++
 .../gpu/drm/amd/display/dc/dcn35/dcn35_resource.c |  5 +++++
 .../gpu/drm/amd/display/dc/dml2/dml2_wrapper.h    | 15 +++++++++++++++
 4 files changed, 30 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 81b0588fa80b..02d3168f1673 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_resource.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn32/dcn32_resource.c
@@ -2445,6 +2445,11 @@ static bool dcn32_resource_construct(
        dc->dml2_options.callbacks.build_scaling_params = 
&resource_build_scaling_params;
        
dc->dml2_options.callbacks.can_support_mclk_switch_using_fw_based_vblank_stretch
 = &dcn30_can_support_mclk_switch_using_fw_based_vblank_stretch;
        dc->dml2_options.callbacks.acquire_secondary_pipe_for_mpc_odm = 
&dc_resource_acquire_secondary_pipe_for_mpc_odm_legacy;
+       dc->dml2_options.callbacks.update_pipes_for_stream_with_slice_count = 
&resource_update_pipes_for_stream_with_slice_count;
+       dc->dml2_options.callbacks.update_pipes_for_plane_with_slice_count = 
&resource_update_pipes_for_plane_with_slice_count;
+       dc->dml2_options.callbacks.get_mpc_slice_index = 
&resource_get_mpc_slice_index;
+       dc->dml2_options.callbacks.get_odm_slice_index = 
&resource_get_odm_slice_index;
+       dc->dml2_options.callbacks.get_opp_head = &resource_get_opp_head;
 
        dc->dml2_options.svp_pstate.callbacks.dc = dc;
        dc->dml2_options.svp_pstate.callbacks.add_plane_to_context = 
&dc_add_plane_to_context;
diff --git a/drivers/gpu/drm/amd/display/dc/dcn321/dcn321_resource.c 
b/drivers/gpu/drm/amd/display/dc/dcn321/dcn321_resource.c
index 44caf6711589..9f6186be7cd8 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn321/dcn321_resource.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn321/dcn321_resource.c
@@ -1998,6 +1998,11 @@ static bool dcn321_resource_construct(
        dc->dml2_options.callbacks.build_scaling_params = 
&resource_build_scaling_params;
        
dc->dml2_options.callbacks.can_support_mclk_switch_using_fw_based_vblank_stretch
 = &dcn30_can_support_mclk_switch_using_fw_based_vblank_stretch;
        dc->dml2_options.callbacks.acquire_secondary_pipe_for_mpc_odm = 
&dc_resource_acquire_secondary_pipe_for_mpc_odm_legacy;
+       dc->dml2_options.callbacks.update_pipes_for_stream_with_slice_count = 
&resource_update_pipes_for_stream_with_slice_count;
+       dc->dml2_options.callbacks.update_pipes_for_plane_with_slice_count = 
&resource_update_pipes_for_plane_with_slice_count;
+       dc->dml2_options.callbacks.get_mpc_slice_index = 
&resource_get_mpc_slice_index;
+       dc->dml2_options.callbacks.get_odm_slice_index = 
&resource_get_odm_slice_index;
+       dc->dml2_options.callbacks.get_opp_head = &resource_get_opp_head;
 
        dc->dml2_options.svp_pstate.callbacks.dc = dc;
        dc->dml2_options.svp_pstate.callbacks.add_plane_to_context = 
&dc_add_plane_to_context;
diff --git a/drivers/gpu/drm/amd/display/dc/dcn35/dcn35_resource.c 
b/drivers/gpu/drm/amd/display/dc/dcn35/dcn35_resource.c
index 4e03c9d663de..682bf93049b0 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn35/dcn35_resource.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn35/dcn35_resource.c
@@ -2082,6 +2082,11 @@ static bool dcn35_resource_construct(
        dc->dml2_options.callbacks.build_scaling_params = 
&resource_build_scaling_params;
        
dc->dml2_options.callbacks.can_support_mclk_switch_using_fw_based_vblank_stretch
 = &dcn30_can_support_mclk_switch_using_fw_based_vblank_stretch;
        dc->dml2_options.callbacks.acquire_secondary_pipe_for_mpc_odm = 
&dc_resource_acquire_secondary_pipe_for_mpc_odm_legacy;
+       dc->dml2_options.callbacks.update_pipes_for_stream_with_slice_count = 
&resource_update_pipes_for_stream_with_slice_count;
+       dc->dml2_options.callbacks.update_pipes_for_plane_with_slice_count = 
&resource_update_pipes_for_plane_with_slice_count;
+       dc->dml2_options.callbacks.get_mpc_slice_index = 
&resource_get_mpc_slice_index;
+       dc->dml2_options.callbacks.get_odm_slice_index = 
&resource_get_odm_slice_index;
+       dc->dml2_options.callbacks.get_opp_head = &resource_get_opp_head;
        dc->dml2_options.max_segments_per_hubp = 24;
 
        dc->dml2_options.det_segment_size = DCN3_2_DET_SEG_SIZE;/*todo*/
diff --git a/drivers/gpu/drm/amd/display/dc/dml2/dml2_wrapper.h 
b/drivers/gpu/drm/amd/display/dc/dml2/dml2_wrapper.h
index f3b85b0891d3..c3d5b84ee914 100644
--- a/drivers/gpu/drm/amd/display/dc/dml2/dml2_wrapper.h
+++ b/drivers/gpu/drm/amd/display/dc/dml2/dml2_wrapper.h
@@ -71,6 +71,21 @@ struct dml2_dc_callbacks {
        bool (*build_scaling_params)(struct pipe_ctx *pipe_ctx);
        bool (*can_support_mclk_switch_using_fw_based_vblank_stretch)(struct dc 
*dc, struct dc_state *context);
        bool (*acquire_secondary_pipe_for_mpc_odm)(const struct dc *dc, struct 
dc_state *state, struct pipe_ctx *pri_pipe, struct pipe_ctx *sec_pipe, bool 
odm);
+       bool (*update_pipes_for_stream_with_slice_count)(
+                       struct dc_state *new_ctx,
+                       const struct dc_state *cur_ctx,
+                       const struct resource_pool *pool,
+                       const struct dc_stream_state *stream,
+                       int new_slice_count);
+       bool (*update_pipes_for_plane_with_slice_count)(
+                       struct dc_state *new_ctx,
+                       const struct dc_state *cur_ctx,
+                       const struct resource_pool *pool,
+                       const struct dc_plane_state *plane,
+                       int slice_count);
+       int (*get_odm_slice_index)(const struct pipe_ctx *opp_head);
+       int (*get_mpc_slice_index)(const struct pipe_ctx *dpp_pipe);
+       struct pipe_ctx *(*get_opp_head)(const struct pipe_ctx *pipe_ctx);
 };
 
 struct dml2_dc_svp_callbacks {
-- 
2.34.1

Reply via email to