As promised in the basic wide planes support ([1]) here comes a series supporting 2*max_linewidth for all the planes. Note: this iteration features handling of rotation and reflection of the wide plane. However rot90 is still not tested: it is enabled on sc7280 and it only supports UBWC (tiled) framebuffers, it was quite low on my priority list. Note#2: to simplify the dpu_plane_virtual_assign_resources(), which already becomes big enough, I stripped support for sharing the SSPP across two planes (doubling amount of planes available to some of compositors/applications). I plan to get back to this topic once this series lands. Dependencies: msm-next + msm-fixes, [1], [2] [1] https://patchwork.freedesktop.org/series/99909/ [2] https://patchwork.freedesktop.org/series/113423/ Changes since v1: - Fixed build error due to me missing one of fixups, it was left uncommitted. - Implementated proper handling of wide plane rotation & reflection. Dmitry Baryshkov (13): drm/atomic-helper: split not-scaling part of drm_atomic_helper_check_plane_state drm/msm/dpu: take plane rotation into account for wide planes drm/msm/dpu: encoder: simplify debugfs handling drm/msm/dpu: remove unused fields from dpu_encoder_virt drm/msm/dpu: get rid of struct dpu_rm_requirements drm/msm/dpu: switch RM to use crtc_id rather than enc_id for allocation drm/msm/dpu: move resource allocation to CRTC drm/msm/dpu: fill CRTC resources in dpu_crtc.c drm/msm/dpu: move pstate->pipe initialization to dpu_plane_atomic_check drm/msm/dpu: add list of supported formats to the DPU caps drm/msm/dpu: add a field describing inline rotation to dpu_caps drm/msm/dpu: add support for virtual planes drm/msm/dpu: allow using two SSPP blocks for a single plane drivers/gpu/drm/drm_atomic_helper.c | 85 +++- drivers/gpu/drm/msm/disp/dpu1/dpu_crtc.c | 162 ++++++- drivers/gpu/drm/msm/disp/dpu1/dpu_encoder.c | 150 +----- drivers/gpu/drm/msm/disp/dpu1/dpu_encoder.h | 8 + .../gpu/drm/msm/disp/dpu1/dpu_encoder_phys.h | 3 - .../gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c | 27 ++ .../gpu/drm/msm/disp/dpu1/dpu_hw_catalog.h | 6 + drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c | 120 +++-- drivers/gpu/drm/msm/disp/dpu1/dpu_kms.h | 14 +- drivers/gpu/drm/msm/disp/dpu1/dpu_plane.c | 428 ++++++++++++++++-- drivers/gpu/drm/msm/disp/dpu1/dpu_plane.h | 33 +- drivers/gpu/drm/msm/disp/dpu1/dpu_rm.c | 243 +++++----- drivers/gpu/drm/msm/disp/dpu1/dpu_rm.h | 41 +- include/drm/drm_atomic_helper.h | 4 + 14 files changed, 959 insertions(+), 365 deletions(-) -- 2.30.2