drm/amd/display: Account for MPO planes in dcn32 mall alloc calculations
[WHY?] Cannot only consider the MALL required from top pipes because of the MPO case. [HOW?] Only count a pipe if it fits the following criteria: 1) does not have a top pipe (is the topmost pipe for that plane) 2) it does have a top pipe, but that pipe is associated with a different plane Tested-by: Daniel Wheeler <Daniel.Wheeler@amd.com> Reviewed-by: Nevenko Stupar <Nevenko.Stupar@amd.com> Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com> Signed-off-by: Dillon Varone <Dillon.Varone@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
2ebd103620
commit
e36193123f
|
@ -1356,9 +1356,10 @@ static void dcn32_calculate_dlg_params(struct dc *dc, struct dc_state *context,
|
|||
context->res_ctx.pipe_ctx[i].surface_size_in_mall_bytes = get_surface_size_in_mall(&context->bw_ctx.dml, pipes, pipe_cnt, pipe_idx);
|
||||
|
||||
/* MALL Allocation Sizes */
|
||||
/* count from active, top pipes only */
|
||||
/* count from active, top pipes per plane only */
|
||||
if (context->res_ctx.pipe_ctx[i].stream && context->res_ctx.pipe_ctx[i].plane_state &&
|
||||
context->res_ctx.pipe_ctx[i].top_pipe == NULL &&
|
||||
(context->res_ctx.pipe_ctx[i].top_pipe == NULL ||
|
||||
context->res_ctx.pipe_ctx[i].plane_state != context->res_ctx.pipe_ctx[i].top_pipe->plane_state) &&
|
||||
context->res_ctx.pipe_ctx[i].prev_odm_pipe == NULL) {
|
||||
/* SS: all active surfaces stored in MALL */
|
||||
if (context->res_ctx.pipe_ctx[i].stream->mall_stream_config.type != SUBVP_PHANTOM) {
|
||||
|
|
Loading…
Reference in New Issue