public inbox for linux-mediatek@lists.infradead.org
 help / color / mirror / Atom feed
* [PATCH v6 00/25] drm/dumb-buffers: Fix and improve buffer-size calculation
@ 2025-08-21  8:17 Thomas Zimmermann
  2025-08-21  8:17 ` [PATCH v6 01/25] drm/dumb-buffers: Sanitize output on errors Thomas Zimmermann
                   ` (25 more replies)
  0 siblings, 26 replies; 37+ messages in thread
From: Thomas Zimmermann @ 2025-08-21  8:17 UTC (permalink / raw)
  To: simona, airlied, mripard, maarten.lankhorst, geert,
	tomi.valkeinen
  Cc: dri-devel, linux-mediatek, freedreno, linux-arm-msm, imx,
	linux-samsung-soc, nouveau, virtualization, spice-devel,
	linux-renesas-soc, linux-rockchip, linux-tegra, intel-xe,
	xen-devel, Thomas Zimmermann

Dumb-buffer pitch and size is specified by width, height, bits-per-pixel
plus various hardware-specific alignments. The calculation of these
values is inconsistent and duplicated among drivers. The results for
formats with bpp < 8 are sometimes incorrect.

This series fixes this for most drivers. Default scanline pitch and
buffer size are now calculated with the existing 4CC helpers. There is
a new helper drm_mode_size_dumb() that calculates scanline pitch and
buffer size according to driver requirements.

The series fixes the common GEM implementations for DMA, SHMEM and
VRAM. It further changes most implementations of dumb_create to use
the new helper. A small number of drivers has more complicated
calculations and will be updated by a later patches.

v6:
- extend TODO item (Tomi)
- fix typos in documentation (Tomi)
v5:
- use check_mul_overflow() for overflow test (Tomi)
- imx: fix intermediate code (Tomi)
- rz-du: include dumb-buffers header
v4:
- improve UAPI documentation
- document bpp special cases
- use drm_warn_once()
- add TODO lists
- armada: fix pitch alignment
v3:
- document UAPI semantics
- fall back to bpp-based allocation for unknown color modes
- cleanups
v2:
- rewrite series
- convert many individual drivers besides the shared GEM helpers

Thomas Zimmermann (25):
  drm/dumb-buffers: Sanitize output on errors
  drm/dumb-buffers: Provide helper to set pitch and size
  drm/gem-dma: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/gem-shmem: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/gem-vram: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/armada: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/exynos: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/gma500: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/hibmc: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/imx/ipuv3: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/loongson: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/mediatek: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/msm: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/nouveau: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/omapdrm: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/qxl: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/renesas/rcar-du: Compute dumb-buffer sizes with
    drm_mode_size_dumb()
  drm/renesas/rz-du: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/rockchip: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/tegra: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/virtio: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/vmwgfx: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/xe: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/xen: Compute dumb-buffer sizes with drm_mode_size_dumb()
  drm/xlnx: Compute dumb-buffer sizes with drm_mode_size_dumb()

 Documentation/gpu/todo.rst                    |  37 ++++
 drivers/gpu/drm/armada/armada_gem.c           |  16 +-
 drivers/gpu/drm/drm_dumb_buffers.c            | 170 ++++++++++++++++--
 drivers/gpu/drm/drm_gem_dma_helper.c          |   7 +-
 drivers/gpu/drm/drm_gem_shmem_helper.c        |  16 +-
 drivers/gpu/drm/drm_gem_vram_helper.c         |  89 +++------
 drivers/gpu/drm/exynos/exynos_drm_gem.c       |   8 +-
 drivers/gpu/drm/gma500/gem.c                  |  21 +--
 .../gpu/drm/hisilicon/hibmc/hibmc_drm_drv.c   |  25 ++-
 drivers/gpu/drm/imx/ipuv3/imx-drm-core.c      |  29 ++-
 drivers/gpu/drm/loongson/lsdc_gem.c           |  29 +--
 drivers/gpu/drm/mediatek/mtk_gem.c            |  13 +-
 drivers/gpu/drm/msm/msm_gem.c                 |  27 ++-
 drivers/gpu/drm/nouveau/nouveau_display.c     |   7 +-
 drivers/gpu/drm/omapdrm/omap_gem.c            |  15 +-
 drivers/gpu/drm/qxl/qxl_dumb.c                |  17 +-
 drivers/gpu/drm/renesas/rcar-du/rcar_du_kms.c |   7 +-
 drivers/gpu/drm/renesas/rz-du/rzg2l_du_kms.c  |   8 +-
 drivers/gpu/drm/rockchip/rockchip_drm_gem.c   |  12 +-
 drivers/gpu/drm/tegra/gem.c                   |   8 +-
 drivers/gpu/drm/virtio/virtgpu_gem.c          |  11 +-
 drivers/gpu/drm/vmwgfx/vmwgfx_surface.c       |  21 +--
 drivers/gpu/drm/xe/xe_bo.c                    |   8 +-
 drivers/gpu/drm/xen/xen_drm_front.c           |   7 +-
 drivers/gpu/drm/xlnx/zynqmp_kms.c             |   7 +-
 include/drm/drm_dumb_buffers.h                |  14 ++
 include/drm/drm_gem_vram_helper.h             |   6 -
 include/uapi/drm/drm_mode.h                   |  50 +++++-
 28 files changed, 457 insertions(+), 228 deletions(-)
 create mode 100644 include/drm/drm_dumb_buffers.h

-- 
2.50.1



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

end of thread, other threads:[~2025-11-26  9:29 UTC | newest]

Thread overview: 37+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-08-21  8:17 [PATCH v6 00/25] drm/dumb-buffers: Fix and improve buffer-size calculation Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 01/25] drm/dumb-buffers: Sanitize output on errors Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 02/25] drm/dumb-buffers: Provide helper to set pitch and size Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 03/25] drm/gem-dma: Compute dumb-buffer sizes with drm_mode_size_dumb() Thomas Zimmermann
2025-11-25 14:39   ` Ludovic.Desroches
2025-11-25 15:03     ` Thomas Zimmermann
2025-11-26  6:24       ` Ludovic.Desroches
2025-11-26  7:40         ` Thomas Zimmermann
2025-11-26  9:29           ` Ludovic.Desroches
2025-08-21  8:17 ` [PATCH v6 04/25] drm/gem-shmem: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 05/25] drm/gem-vram: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 06/25] drm/armada: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 07/25] drm/exynos: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 08/25] drm/gma500: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 09/25] drm/hibmc: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 10/25] drm/imx/ipuv3: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 11/25] drm/loongson: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 12/25] drm/mediatek: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 13/25] drm/msm: " Thomas Zimmermann
2025-11-02 16:39   ` Dmitry Baryshkov
2025-08-21  8:17 ` [PATCH v6 14/25] drm/nouveau: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 15/25] drm/omapdrm: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 16/25] drm/qxl: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 17/25] drm/renesas/rcar-du: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 18/25] drm/renesas/rz-du: " Thomas Zimmermann
2025-08-21 11:28   ` Biju Das
2025-08-21 11:55     ` Thomas Zimmermann
2025-08-21 12:34       ` Biju Das
2025-08-21  8:17 ` [PATCH v6 19/25] drm/rockchip: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 20/25] drm/tegra: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 21/25] drm/virtio: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 22/25] drm/vmwgfx: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 23/25] drm/xe: " Thomas Zimmermann
2025-09-29 15:25   ` Lucas De Marchi
2025-08-21  8:17 ` [PATCH v6 24/25] drm/xen: " Thomas Zimmermann
2025-08-21  8:17 ` [PATCH v6 25/25] drm/xlnx: " Thomas Zimmermann
2025-09-15 10:35 ` [PATCH v6 00/25] drm/dumb-buffers: Fix and improve buffer-size calculation Thomas Zimmermann

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