]> git.baikalelectronics.ru Git - kernel.git/commitdiff
drm/amd/display: Pass triplebuffer surface flip flags down to plane state
authorNicholas Kazlauskas <nicholas.kazlauskas@amd.com>
Mon, 2 Mar 2020 15:29:26 +0000 (10:29 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 19 Mar 2020 04:03:04 +0000 (00:03 -0400)
[Why]
A "dcn20_program_front_end_for_ctx" warning is observed on Renoir.

Since the resource definition doesn't explicitly disable triplebuffer
flips like Navi10 DC actually attempts to go and setup triplebuffering
even when we pass in false to the plane state.

If we hit a full update after triplebuffering has been setup we see the
assertion since we don't expect full updates while performing
triplebuffer flips.

Normally this would get reset back to false whne we pass in the new
plane state, but since we never actually copy the flag when doing
surface updates this doesn't happen.

[How]
Copy the flag onto the plane update based on the requested surface
update state.

Signed-off-by: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
Reviewed-by: Hersen Wu <hersenxs.wu@amd.com>
Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/core/dc.c
drivers/gpu/drm/amd/display/dc/dc.h

index df285f57fe9249f450abb74bc3de330f9db1fca8..137180ad6a25f8eb238fb9af063fe9b187da5729 100644 (file)
@@ -1871,6 +1871,8 @@ static void copy_surface_update_to_plane(
                surface->time.index++;
                if (surface->time.index >= DC_PLANE_UPDATE_TIMES_MAX)
                        surface->time.index = 0;
+
+               surface->triplebuffer_flips = srf_update->flip_addr->triplebuffer_flips;
        }
 
        if (srf_update->scaling_info) {
index 1e6413a79d47aa471362d8aaa1ed9411a44f8e9b..280b015d10bd70b6031d7ed81d132b8d51b195f0 100644 (file)
@@ -872,6 +872,7 @@ struct dc_flip_addrs {
        unsigned int flip_timestamp_in_us;
        bool flip_immediate;
        /* TODO: add flip duration for FreeSync */
+       bool triplebuffer_flips;
 };
 
 bool dc_post_update_surfaces_to_stream(