diff options
author | Nirmoy Das <nirmoy.das@intel.com> | 2022-12-19 12:29:33 +0100 |
---|---|---|
committer | Matthew Auld <matthew.auld@intel.com> | 2022-12-20 09:57:03 +0000 |
commit | 7ccf9a5386a48b86c1abc0e7cb42f4b8f961af38 (patch) | |
tree | ca035d4e738dd1c4070c841ee7303ea62343cf76 | |
parent | 08d34f12fead958d17e32d57d8061c14f9104373 (diff) | |
download | linux-7ccf9a5386a48b86c1abc0e7cb42f4b8f961af38.tar.gz linux-7ccf9a5386a48b86c1abc0e7cb42f4b8f961af38.tar.bz2 linux-7ccf9a5386a48b86c1abc0e7cb42f4b8f961af38.zip |
drm/i915: Use helper func to find out map type
Use i915_coherent_map_type() function to find out
map_type of the shmem obj.
v2: handle non-llc platform(Matt)
Signed-off-by: Nirmoy Das <nirmoy.das@intel.com>
Reviewed-by: Andrzej Hajda <andrzej.hajda@intel.com>
Signed-off-by: Matthew Auld <matthew.auld@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20221219112933.21417-1-nirmoy.das@intel.com
-rw-r--r-- | drivers/gpu/drm/i915/gt/shmem_utils.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/gt/shmem_utils.c b/drivers/gpu/drm/i915/gt/shmem_utils.c index 402f085f3a02..449c9ed44382 100644 --- a/drivers/gpu/drm/i915/gt/shmem_utils.c +++ b/drivers/gpu/drm/i915/gt/shmem_utils.c @@ -8,6 +8,7 @@ #include <linux/pagemap.h> #include <linux/shmem_fs.h> +#include "i915_drv.h" #include "gem/i915_gem_object.h" #include "gem/i915_gem_lmem.h" #include "shmem_utils.h" @@ -32,6 +33,8 @@ struct file *shmem_create_from_data(const char *name, void *data, size_t len) struct file *shmem_create_from_object(struct drm_i915_gem_object *obj) { + struct drm_i915_private *i915 = to_i915(obj->base.dev); + enum i915_map_type map_type; struct file *file; void *ptr; @@ -41,8 +44,8 @@ struct file *shmem_create_from_object(struct drm_i915_gem_object *obj) return file; } - ptr = i915_gem_object_pin_map_unlocked(obj, i915_gem_object_is_lmem(obj) ? - I915_MAP_WC : I915_MAP_WB); + map_type = i915_coherent_map_type(i915, obj, true); + ptr = i915_gem_object_pin_map_unlocked(obj, map_type); if (IS_ERR(ptr)) return ERR_CAST(ptr); |