Commit 1c0b1175 authored by Lucas De Marchi's avatar Lucas De Marchi

drm/i915/guc: Keep iosys_map of ads_blob around

Convert intel_guc_ads_create() and initialization to use iosys_map
rather than plain pointer and save it in the guc struct. This will help
with additional updates to the ads_blob after the
creation/initialization by abstracting the IO vs system memory.

Cc: Matt Roper <matthew.d.roper@intel.com>
Cc: Thomas Hellström <thomas.hellstrom@linux.intel.com>
Cc: Daniel Vetter <daniel@ffwll.ch>
Cc: John Harrison <John.C.Harrison@Intel.com>
Cc: Matthew Brost <matthew.brost@intel.com>
Cc: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Signed-off-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
Reviewed-by: default avatarMatt Atwood <matthew.s.atwood@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220216174147.3073235-5-lucas.demarchi@intel.com
parent 9659dd2b
...@@ -6,8 +6,9 @@ ...@@ -6,8 +6,9 @@
#ifndef _INTEL_GUC_H_ #ifndef _INTEL_GUC_H_
#define _INTEL_GUC_H_ #define _INTEL_GUC_H_
#include <linux/xarray.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/iosys-map.h>
#include <linux/xarray.h>
#include "intel_uncore.h" #include "intel_uncore.h"
#include "intel_guc_fw.h" #include "intel_guc_fw.h"
...@@ -148,6 +149,7 @@ struct intel_guc { ...@@ -148,6 +149,7 @@ struct intel_guc {
struct i915_vma *ads_vma; struct i915_vma *ads_vma;
/** @ads_blob: contents of the GuC ADS */ /** @ads_blob: contents of the GuC ADS */
struct __guc_ads_blob *ads_blob; struct __guc_ads_blob *ads_blob;
struct iosys_map ads_map;
/** @ads_regset_size: size of the save/restore regsets in the ADS */ /** @ads_regset_size: size of the save/restore regsets in the ADS */
u32 ads_regset_size; u32 ads_regset_size;
/** /**
......
...@@ -666,6 +666,11 @@ int intel_guc_ads_create(struct intel_guc *guc) ...@@ -666,6 +666,11 @@ int intel_guc_ads_create(struct intel_guc *guc)
if (ret) if (ret)
return ret; return ret;
if (i915_gem_object_is_lmem(guc->ads_vma->obj))
iosys_map_set_vaddr_iomem(&guc->ads_map, (void __iomem *)guc->ads_blob);
else
iosys_map_set_vaddr(&guc->ads_map, guc->ads_blob);
__guc_ads_init(guc); __guc_ads_init(guc);
return 0; return 0;
...@@ -687,6 +692,7 @@ void intel_guc_ads_destroy(struct intel_guc *guc) ...@@ -687,6 +692,7 @@ void intel_guc_ads_destroy(struct intel_guc *guc)
{ {
i915_vma_unpin_and_release(&guc->ads_vma, I915_VMA_RELEASE_MAP); i915_vma_unpin_and_release(&guc->ads_vma, I915_VMA_RELEASE_MAP);
guc->ads_blob = NULL; guc->ads_blob = NULL;
iosys_map_clear(&guc->ads_map);
kfree(guc->ads_regset); kfree(guc->ads_regset);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment