Commit 0df0c76c authored by Lucas De Marchi's avatar Lucas De Marchi

drm/i915/guc: Remove plain ads_blob pointer

Now we have the access to content of GuC ADS either using iosys_map
API or using a temporary buffer. Remove guc->ads_blob as there shouldn't
be updates using the bare pointer anymore.

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 avatarMatthew Brost <matthew.brost@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220216174147.3073235-17-lucas.demarchi@intel.com
parent 691ebb11
...@@ -147,8 +147,7 @@ struct intel_guc { ...@@ -147,8 +147,7 @@ struct intel_guc {
/** @ads_vma: object allocated to hold the GuC ADS */ /** @ads_vma: object allocated to hold the GuC ADS */
struct i915_vma *ads_vma; struct i915_vma *ads_vma;
/** @ads_blob: contents of the GuC ADS */ /** @ads_map: contents of the GuC ADS */
struct __guc_ads_blob *ads_blob;
struct iosys_map ads_map; 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;
......
...@@ -667,6 +667,7 @@ static void __guc_ads_init(struct intel_guc *guc) ...@@ -667,6 +667,7 @@ static void __guc_ads_init(struct intel_guc *guc)
*/ */
int intel_guc_ads_create(struct intel_guc *guc) int intel_guc_ads_create(struct intel_guc *guc)
{ {
void *ads_blob;
u32 size; u32 size;
int ret; int ret;
...@@ -691,14 +692,14 @@ int intel_guc_ads_create(struct intel_guc *guc) ...@@ -691,14 +692,14 @@ int intel_guc_ads_create(struct intel_guc *guc)
size = guc_ads_blob_size(guc); size = guc_ads_blob_size(guc);
ret = intel_guc_allocate_and_map_vma(guc, size, &guc->ads_vma, ret = intel_guc_allocate_and_map_vma(guc, size, &guc->ads_vma,
(void **)&guc->ads_blob); &ads_blob);
if (ret) if (ret)
return ret; return ret;
if (i915_gem_object_is_lmem(guc->ads_vma->obj)) if (i915_gem_object_is_lmem(guc->ads_vma->obj))
iosys_map_set_vaddr_iomem(&guc->ads_map, (void __iomem *)guc->ads_blob); iosys_map_set_vaddr_iomem(&guc->ads_map, (void __iomem *)ads_blob);
else else
iosys_map_set_vaddr(&guc->ads_map, guc->ads_blob); iosys_map_set_vaddr(&guc->ads_map, ads_blob);
__guc_ads_init(guc); __guc_ads_init(guc);
...@@ -720,7 +721,6 @@ void intel_guc_ads_init_late(struct intel_guc *guc) ...@@ -720,7 +721,6 @@ void intel_guc_ads_init_late(struct intel_guc *guc)
void intel_guc_ads_destroy(struct intel_guc *guc) 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;
iosys_map_clear(&guc->ads_map); 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