]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
fbdev/deferred-io: Provide get_page hook in struct fb_deferred_io
authorThomas Zimmermann <tzimmermann@suse.de>
Fri, 19 Apr 2024 08:29:00 +0000 (10:29 +0200)
committerThomas Zimmermann <tzimmermann@suse.de>
Thu, 2 May 2024 09:33:14 +0000 (11:33 +0200)
Add a callback for drivers to provide framebuffer pages to fbdev's
deferred-I/O helpers. Implementations need to acquire a reference on
the page before returning it. Returning NULL generates a SIGBUS
signal.

This will be useful for DRM's fbdev emulation with GEM-shmem buffer
objects.

v2:
- fix typo in commit message (Javier)

Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: Javier Martinez Canillas <javierm@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240419083331.7761-8-tzimmermann@suse.de
drivers/video/fbdev/core/fb_defio.c
include/linux/fb.h

index c68c51d0ef70e7773c55fda3e701cadfd6d7e1fb..5ee7e78c2cea057cda348b20d6518423204e9c4c 100644 (file)
 
 static struct page *fb_deferred_io_get_page(struct fb_info *info, unsigned long offs)
 {
+       struct fb_deferred_io *fbdefio = info->fbdefio;
        const void *screen_buffer = info->screen_buffer;
        struct page *page = NULL;
 
+       if (fbdefio->get_page)
+               return fbdefio->get_page(info, offs);
+
        if (is_vmalloc_addr(screen_buffer + offs))
                page = vmalloc_to_page(screen_buffer + offs);
        else if (info->fix.smem_start)
index 811e47f9d1c3ffaf4ec286457dbbd1f55a335579..5358edbb9c0b7ad870df046bd6194fdb53447e44 100644 (file)
@@ -225,6 +225,7 @@ struct fb_deferred_io {
        struct mutex lock; /* mutex that protects the pageref list */
        struct list_head pagereflist; /* list of pagerefs for touched pages */
        /* callback */
+       struct page *(*get_page)(struct fb_info *info, unsigned long offset);
        void (*deferred_io)(struct fb_info *info, struct list_head *pagelist);
 };
 #endif