From: Thomas Zimmermann <tzimmermann@suse.de>
To: simona@ffwll.ch, airlied@gmail.com, mripard@kernel.org,
maarten.lankhorst@linux.intel.com, geert@linux-m68k.org,
tomi.valkeinen@ideasonboard.com
Cc: dri-devel@lists.freedesktop.org,
linux-mediatek@lists.infradead.org,
freedreno@lists.freedesktop.org, linux-arm-msm@vger.kernel.org,
imx@lists.linux.dev, linux-samsung-soc@vger.kernel.org,
nouveau@lists.freedesktop.org, virtualization@lists.linux.dev,
spice-devel@lists.freedesktop.org,
linux-renesas-soc@vger.kernel.org,
linux-rockchip@lists.infradead.org, linux-tegra@vger.kernel.org,
intel-xe@lists.freedesktop.org, xen-devel@lists.xenproject.org,
Thomas Zimmermann <tzimmermann@suse.de>
Subject: [PATCH v6 03/25] drm/gem-dma: Compute dumb-buffer sizes with drm_mode_size_dumb()
Date: Thu, 21 Aug 2025 10:17:10 +0200 [thread overview]
Message-ID: <20250821081918.79786-4-tzimmermann@suse.de> (raw)
In-Reply-To: <20250821081918.79786-1-tzimmermann@suse.de>
Call drm_mode_size_dumb() to compute dumb-buffer scanline pitch and
buffer size. Align the pitch to a multiple of 8.
Push the current calculation into the only direct caller imx. Imx's
hardware requires the framebuffer width to be aligned to 8. The
driver's current approach is actually incorrect, as it only guarantees
this implicitly and requires bpp to be a multiple of 8 already. A
later commit will fix this problem by aligning the scanline pitch
such that an aligned width still fits into each scanline's memory.
A number of other drivers are build on top of gem-dma helpers and
implement their own dumb-buffer allocation. These drivers invoke
drm_gem_dma_dumb_create_internal(), which is not affected by this
commit.
v5:
- avoid reset of arguments (Tomi)
Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>
---
drivers/gpu/drm/drm_gem_dma_helper.c | 7 +++++--
drivers/gpu/drm/imx/ipuv3/imx-drm-core.c | 4 +++-
2 files changed, 8 insertions(+), 3 deletions(-)
diff --git a/drivers/gpu/drm/drm_gem_dma_helper.c b/drivers/gpu/drm/drm_gem_dma_helper.c
index 4f0320df858f..ab1a70b1d6f1 100644
--- a/drivers/gpu/drm/drm_gem_dma_helper.c
+++ b/drivers/gpu/drm/drm_gem_dma_helper.c
@@ -20,6 +20,7 @@
#include <drm/drm.h>
#include <drm/drm_device.h>
#include <drm/drm_drv.h>
+#include <drm/drm_dumb_buffers.h>
#include <drm/drm_gem_dma_helper.h>
#include <drm/drm_vma_manager.h>
@@ -304,9 +305,11 @@ int drm_gem_dma_dumb_create(struct drm_file *file_priv,
struct drm_mode_create_dumb *args)
{
struct drm_gem_dma_object *dma_obj;
+ int ret;
- args->pitch = DIV_ROUND_UP(args->width * args->bpp, 8);
- args->size = args->pitch * args->height;
+ ret = drm_mode_size_dumb(drm, args, SZ_8, 0);
+ if (ret)
+ return ret;
dma_obj = drm_gem_dma_create_with_handle(file_priv, drm, args->size,
&args->handle);
diff --git a/drivers/gpu/drm/imx/ipuv3/imx-drm-core.c b/drivers/gpu/drm/imx/ipuv3/imx-drm-core.c
index ec5fd9a01f1e..af4a30311e18 100644
--- a/drivers/gpu/drm/imx/ipuv3/imx-drm-core.c
+++ b/drivers/gpu/drm/imx/ipuv3/imx-drm-core.c
@@ -145,8 +145,10 @@ static int imx_drm_dumb_create(struct drm_file *file_priv,
int ret;
args->width = ALIGN(width, 8);
+ args->pitch = DIV_ROUND_UP(args->width * args->bpp, 8);
+ args->size = args->pitch * args->height;
- ret = drm_gem_dma_dumb_create(file_priv, drm, args);
+ ret = drm_gem_dma_dumb_create_internal(file_priv, drm, args);
if (ret)
return ret;
--
2.50.1
next prev parent reply other threads:[~2025-08-21 8:22 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
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 ` Thomas Zimmermann [this message]
2025-11-25 14:39 ` [PATCH v6 03/25] drm/gem-dma: Compute dumb-buffer sizes with drm_mode_size_dumb() 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
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250821081918.79786-4-tzimmermann@suse.de \
--to=tzimmermann@suse.de \
--cc=airlied@gmail.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=freedreno@lists.freedesktop.org \
--cc=geert@linux-m68k.org \
--cc=imx@lists.linux.dev \
--cc=intel-xe@lists.freedesktop.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-mediatek@lists.infradead.org \
--cc=linux-renesas-soc@vger.kernel.org \
--cc=linux-rockchip@lists.infradead.org \
--cc=linux-samsung-soc@vger.kernel.org \
--cc=linux-tegra@vger.kernel.org \
--cc=maarten.lankhorst@linux.intel.com \
--cc=mripard@kernel.org \
--cc=nouveau@lists.freedesktop.org \
--cc=simona@ffwll.ch \
--cc=spice-devel@lists.freedesktop.org \
--cc=tomi.valkeinen@ideasonboard.com \
--cc=virtualization@lists.linux.dev \
--cc=xen-devel@lists.xenproject.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox