• Nicholas Kazlauskas's avatar
    drm/amd/display: Rework DC plane filling and surface updates · 695af5f9
    Nicholas Kazlauskas authored
    [Why]
    We currently don't do DC validation for medium or full updates where
    the plane state isn't created. There are some medium and full updates
    that can cause bandwidth or clock changes to occur resulting in
    underflow or corruption.
    
    We need to be able to fill surface and plane info updates during
    atomic commit for dm_determine_update_type for commit. Since we already
    do this during atomic commit tail it would be good if we had the same
    logic in both places for creating these structures.
    
    [How]
    Introduce fill_dc_scaling_info and fill_dc_plane_info_and_addr.
    These two functions cover the following three update structures:
    
    - struct dc_scaling_info
    - struct dc_plane_info
    - struct dc_plane_address
    
    Cleanup and adapter the existing fill_plane_* helpers to work with
    these functions.
    
    Update call sites that used most of these sub helpers directly to work
    with the new functions. The exception being prepare_fb - we just want
    the new buffer attributes specifically in the case where we're
    creating the plane. This is needed for dc_commit_state in the case
    where the FB hasn't been previously been used.
    
    This isn't quite a refactor, but functionally driver behavior should
    be mostly the smae as before. The one exception is that we now check
    the return code for fill_plane_buffer_attributes which means that
    commits will be rejected that try to enable DCC with erroneous
    parameters.
    Signed-off-by: default avatarNicholas Kazlauskas <nicholas.kazlauskas@amd.com>
    Reviewed-by: default avatarDavid Francis <David.Francis@amd.com>
    Acked-by: Bhawanpreet Lakha <Bhawanpreet Lakha@amd.com>
    Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
    695af5f9
amdgpu_dm.c 185 KB