summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Zimmermann <tzimmermann@suse.de>2025-10-27 13:09:12 +0100
committerThomas Zimmermann <tzimmermann@suse.de>2025-10-30 21:01:12 +0100
commitdce4657ff526b65007fe8d5c92968a933cc7c9da (patch)
tree9e5cc25103edd34957c846d997e13efa85d5e47a
parente4d82d7e90e77ff398fa589a2817ae09f1278ff5 (diff)
drm/client: Remove pitch from struct drm_client_buffer
Only the client-buffer setup uses the pitch field from struct drm_client_buffer. Remove the field and pass the value among setup helpers. Clients that need the pitch should rather look at the framebuffer's pitches[0] directly. Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de> Reviewed-by: Jocelyn Falempe <jfalempe@redhat.com> Tested-by: Francesco Valla <francesco@valla.it> Link: https://patch.msgid.link/20251027121042.143588-2-tzimmermann@suse.de
-rw-r--r--drivers/gpu/drm/drm_client.c14
-rw-r--r--include/drm/drm_client.h5
2 files changed, 7 insertions, 12 deletions
diff --git a/drivers/gpu/drm/drm_client.c b/drivers/gpu/drm/drm_client.c
index fe9c6d7083ea..82b871d62313 100644
--- a/drivers/gpu/drm/drm_client.c
+++ b/drivers/gpu/drm/drm_client.c
@@ -188,7 +188,7 @@ static void drm_client_buffer_delete(struct drm_client_buffer *buffer)
static struct drm_client_buffer *
drm_client_buffer_create(struct drm_client_dev *client, u32 width, u32 height,
- u32 format, u32 *handle)
+ u32 format, u32 *handle, u32 *pitch)
{
const struct drm_format_info *info = drm_format_info(format);
struct drm_mode_create_dumb dumb_args = { };
@@ -216,9 +216,9 @@ drm_client_buffer_create(struct drm_client_dev *client, u32 width, u32 height,
goto err_delete;
}
- buffer->pitch = dumb_args.pitch;
buffer->gem = obj;
*handle = dumb_args.handle;
+ *pitch = dumb_args.pitch;
return buffer;
@@ -353,7 +353,7 @@ static void drm_client_buffer_rmfb(struct drm_client_buffer *buffer)
static int drm_client_buffer_addfb(struct drm_client_buffer *buffer,
u32 width, u32 height, u32 format,
- u32 handle)
+ u32 handle, u32 pitch)
{
struct drm_client_dev *client = buffer->client;
struct drm_mode_fb_cmd2 fb_req = { };
@@ -363,7 +363,7 @@ static int drm_client_buffer_addfb(struct drm_client_buffer *buffer,
fb_req.height = height;
fb_req.pixel_format = format;
fb_req.handles[0] = handle;
- fb_req.pitches[0] = buffer->pitch;
+ fb_req.pitches[0] = pitch;
ret = drm_mode_addfb2(client->dev, &fb_req, client->file);
if (ret)
@@ -399,15 +399,15 @@ struct drm_client_buffer *
drm_client_framebuffer_create(struct drm_client_dev *client, u32 width, u32 height, u32 format)
{
struct drm_client_buffer *buffer;
- u32 handle;
+ u32 handle, pitch;
int ret;
buffer = drm_client_buffer_create(client, width, height, format,
- &handle);
+ &handle, &pitch);
if (IS_ERR(buffer))
return buffer;
- ret = drm_client_buffer_addfb(buffer, width, height, format, handle);
+ ret = drm_client_buffer_addfb(buffer, width, height, format, handle, pitch);
/*
* The handle is only needed for creating the framebuffer, destroy it
diff --git a/include/drm/drm_client.h b/include/drm/drm_client.h
index 715b422952ee..c674464f7e74 100644
--- a/include/drm/drm_client.h
+++ b/include/drm/drm_client.h
@@ -174,11 +174,6 @@ struct drm_client_buffer {
struct drm_client_dev *client;
/**
- * @pitch: Buffer pitch
- */
- u32 pitch;
-
- /**
* @gem: GEM object backing this buffer
*
* FIXME: The dependency on GEM here isn't required, we could