Linux ARM-MSM sub-architecture
 help / color / mirror / Atom feed
* [PATCH v6 0/9] drm/msm/dpu: support virtual wide planes
@ 2024-10-25  0:20 Dmitry Baryshkov
  2024-10-25  0:20 ` [PATCH v6 1/9] drm/msm/dpu: use drm_rect_fp_to_int() Dmitry Baryshkov
                   ` (9 more replies)
  0 siblings, 10 replies; 30+ messages in thread
From: Dmitry Baryshkov @ 2024-10-25  0:20 UTC (permalink / raw)
  To: Rob Clark, Abhinav Kumar, Sean Paul, Marijn Suijten, David Airlie,
	Simona Vetter
  Cc: linux-arm-msm, dri-devel, freedreno, linux-kernel

As promised in the basic wide planes support ([1]) here comes a series
supporting 2*max_linewidth for all the planes.

Note: Unlike v1 and v2 this series finally includes support for
additional planes - having more planes than the number of SSPP blocks.

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.

[1] https://patchwork.freedesktop.org/series/99909/

---
Changes in v6:
- Renamed dpu_plane_atomic_check_nopipe() ->
  dpu_plane_atomic_check_nosspp() and dpu_plane_atomic_check_pipes() ->
  dpu_plane_atomic_check_sspp() (Abhinav)
- In dpu_rm_reserve_sspp() replaced hweight usage with explicit type
  allocation (Abhinav)
- In dpu_plane_atomic_check() set r_pipe->sspp (Jun Nie)
- In dpu_rm_reserve_sspp() check hw_sspp->ops.setup_scaler to rule out
  SSPP blocks with unsupported scaler blocks (RGB, QSEED2)
- Link to v5: https://lore.kernel.org/r/20240627-dpu-virtual-wide-v5-0-5efb90cbb8be@linaro.org

Changes in v5:
- Dropped extra dpu_kms instance from dpu_plane_atomic_check() (Abhinav)
- Use DRM_PLANE_NO_SCALING instead of (1 << 16) (Abhinav)
- Dropped excess returns documentation for dpu_rm_reserve_sspp() (Sui
  Jingfeng, Abhinav)
- best_weght -> best_weight (Abhinav)
- Moved drm_rect_width() call back to the the patch "split
  dpu_plane_atomic_check()" (Abhinav)
- Got rid of saved_fmt / saved dimensions (Abhinav)
- Expanded the commit message to describe SSPP allocation per CRTC id
  (Abhinav)
- Added comment on why the size change also causes resource reallocation
  (Abhinav)
- Dropeed several last "feature" patches, leaving only SSPP reallocation
  and using 2 SSPPs per plane for now. The rest will be submitted
  separately.

Changes since v3:
- Dropped the drm_atomic_helper_check_plane_noscale (Ville)
- Reworked the scaling factor according to global value and then check
  if SSPP has scaler_blk later on.
- Split drm_rect_fp_to_int from the rotation-related fix (Abhinav)

Changes since v2:
- Dropped the encoder-related parts, leave all resource allocation as is
  (Abhinav)
- Significantly reworked the SSPP allocation code
- Added debugging code to dump RM state in dri/N/state

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 (9):
      drm/msm/dpu: use drm_rect_fp_to_int()
      drm/msm/dpu: move pstate->pipe initialization to dpu_plane_atomic_check
      drm/msm/dpu: drop virt_formats from SSPP subblock configuration
      drm/msm/dpu: move scaling limitations out of the hw_catalog
      drm/msm/dpu: split dpu_plane_atomic_check()
      drm/msm/dpu: move rot90 checking to dpu_plane_atomic_check_sspp()
      drm/msm/dpu: add support for virtual planes
      drm/msm/dpu: allow using two SSPP blocks for a single plane
      drm/msm/dpu: include SSPP allocation state into the dumped state

 drivers/gpu/drm/msm/disp/dpu1/dpu_crtc.c       |  50 +++
 drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c |  28 --
 drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.h |   8 -
 drivers/gpu/drm/msm/disp/dpu1/dpu_hw_sspp.h    |   2 +
 drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c        |  10 +-
 drivers/gpu/drm/msm/disp/dpu1/dpu_kms.h        |   4 +
 drivers/gpu/drm/msm/disp/dpu1/dpu_plane.c      | 539 +++++++++++++++++++------
 drivers/gpu/drm/msm/disp/dpu1/dpu_plane.h      |  18 +-
 drivers/gpu/drm/msm/disp/dpu1/dpu_rm.c         |  75 ++++
 drivers/gpu/drm/msm/disp/dpu1/dpu_rm.h         |  27 ++
 10 files changed, 606 insertions(+), 155 deletions(-)
---
base-commit: 2261751d5f2233a7a5d4791d6d13a0271e838ca5
change-id: 20240626-dpu-virtual-wide-beefb746a900

Best regards,
-- 
Dmitry Baryshkov <dmitry.baryshkov@linaro.org>


^ permalink raw reply	[flat|nested] 30+ messages in thread

end of thread, other threads:[~2024-11-02  1:08 UTC | newest]

Thread overview: 30+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-10-25  0:20 [PATCH v6 0/9] drm/msm/dpu: support virtual wide planes Dmitry Baryshkov
2024-10-25  0:20 ` [PATCH v6 1/9] drm/msm/dpu: use drm_rect_fp_to_int() Dmitry Baryshkov
2024-10-25  0:20 ` [PATCH v6 2/9] drm/msm/dpu: move pstate->pipe initialization to dpu_plane_atomic_check Dmitry Baryshkov
2024-10-25 19:00   ` Abhinav Kumar
2024-10-28 10:46     ` Dmitry Baryshkov
2024-10-29 20:42       ` Abhinav Kumar
2024-10-25  0:20 ` [PATCH v6 3/9] drm/msm/dpu: drop virt_formats from SSPP subblock configuration Dmitry Baryshkov
2024-10-25  0:20 ` [PATCH v6 4/9] drm/msm/dpu: move scaling limitations out of the hw_catalog Dmitry Baryshkov
2024-10-25 23:15   ` Abhinav Kumar
2024-10-25  0:20 ` [PATCH v6 5/9] drm/msm/dpu: split dpu_plane_atomic_check() Dmitry Baryshkov
2024-10-25 23:21   ` Abhinav Kumar
2024-10-25  0:20 ` [PATCH v6 6/9] drm/msm/dpu: move rot90 checking to dpu_plane_atomic_check_sspp() Dmitry Baryshkov
2024-10-29 21:00   ` Abhinav Kumar
2024-10-25  0:20 ` [PATCH v6 7/9] drm/msm/dpu: add support for virtual planes Dmitry Baryshkov
2024-10-29 21:30   ` Abhinav Kumar
2024-10-30 10:48     ` Dmitry Baryshkov
2024-10-30 19:26       ` Abhinav Kumar
2024-10-31 15:11         ` Dmitry Baryshkov
2024-10-31 15:17           ` Dmitry Baryshkov
2024-10-31 20:06           ` Abhinav Kumar
2024-10-31 21:03             ` Dmitry Baryshkov
2024-11-01 20:37               ` Abhinav Kumar
2024-11-01 20:53                 ` Dmitry Baryshkov
2024-11-01 21:27                   ` Abhinav Kumar
2024-11-01 23:30                     ` Abhinav Kumar
2024-10-25  0:20 ` [PATCH v6 8/9] drm/msm/dpu: allow using two SSPP blocks for a single plane Dmitry Baryshkov
2024-10-29 22:07   ` Abhinav Kumar
2024-10-30 10:03     ` Dmitry Baryshkov
2024-10-25  0:20 ` [PATCH v6 9/9] drm/msm/dpu: include SSPP allocation state into the dumped state Dmitry Baryshkov
2024-11-02  1:08 ` [PATCH v6 0/9] drm/msm/dpu: support virtual wide planes Dmitry Baryshkov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox