]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915: implement vmap/vunmap GEM object functions
authorAsbjørn Sloth Tønnesen <asbjorn@asbjorn.st>
Sat, 29 Jun 2024 18:25:06 +0000 (18:25 +0000)
committerAndi Shyti <andi.shyti@linux.intel.com>
Wed, 5 Mar 2025 21:13:30 +0000 (22:13 +0100)
Implement i915_gem_vmap_object() and i915_gem_vunmap_object(),
based on i915_gem_dmabuf_vmap() and i915_gem_dmabuf_vunmap().

This enables a drm_client to use drm_client_buffer_vmap() and
drm_client_buffer_vunmap() on hardware using the i915 driver.

Tested with a currently out of tree pixelflut drm_client[1] on:
- Lenovo ThinkCentre M720q (CoffeeLake-S GT2 / Intel UHD Graphics 630)
- Dell Wyse N06D - 3030 LT (ValleyView on Intel Celeron N2807 SOC)

[1] XDP->DRM pixelflut: https://labitat.dk/wiki/Pixelflut-XDR

Signed-off-by: Asbjørn Sloth Tønnesen <asbjorn@asbjorn.st>
Acked-by: Thomas Zimmermann <tzimmermann@suse.de>
Signed-off-by: Andi Shyti <andi.shyti@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240629182513.78026-1-asbjorn@asbjorn.st
drivers/gpu/drm/i915/gem/i915_gem_object.c

index 58e6c680fe0df6f7ee6223eef68cf67c5eaf0b4e..356530b599ce5cf23d9dc00a7b7aa8c874053c15 100644 (file)
@@ -873,6 +873,30 @@ bool i915_gem_object_needs_ccs_pages(struct drm_i915_gem_object *obj)
        return lmem_placement;
 }
 
+static int i915_gem_vmap_object(struct drm_gem_object *gem_obj,
+                               struct iosys_map *map)
+{
+       struct drm_i915_gem_object *obj = to_intel_bo(gem_obj);
+       void *vaddr;
+
+       vaddr = i915_gem_object_pin_map(obj, I915_MAP_WB);
+       if (IS_ERR(vaddr))
+               return PTR_ERR(vaddr);
+
+       iosys_map_set_vaddr(map, vaddr);
+
+       return 0;
+}
+
+static void i915_gem_vunmap_object(struct drm_gem_object *gem_obj,
+                                  struct iosys_map *map)
+{
+       struct drm_i915_gem_object *obj = to_intel_bo(gem_obj);
+
+       i915_gem_object_flush_map(obj);
+       i915_gem_object_unpin_map(obj);
+}
+
 void i915_gem_init__objects(struct drm_i915_private *i915)
 {
        INIT_WORK(&i915->mm.free_work, __i915_gem_free_work);
@@ -896,6 +920,8 @@ static const struct drm_gem_object_funcs i915_gem_object_funcs = {
        .free = i915_gem_free_object,
        .close = i915_gem_close_object,
        .export = i915_gem_prime_export,
+       .vmap = i915_gem_vmap_object,
+       .vunmap = i915_gem_vunmap_object,
 };
 
 /**