OSDN Git Service

drm/i915/guc: Keep iosys_map of ads_blob around
authorLucas De Marchi <lucas.demarchi@intel.com>
Wed, 16 Feb 2022 17:41:35 +0000 (09:41 -0800)
committerLucas De Marchi <lucas.demarchi@intel.com>
Fri, 25 Feb 2022 23:23:19 +0000 (15:23 -0800)
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: Lucas De Marchi <lucas.demarchi@intel.com>
Reviewed-by: Matt Atwood <matthew.s.atwood@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220216174147.3073235-5-lucas.demarchi@intel.com
drivers/gpu/drm/i915/gt/uc/intel_guc.h
drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c

index 9d779de..f857e91 100644 (file)
@@ -6,8 +6,9 @@
 #ifndef _INTEL_GUC_H_
 #define _INTEL_GUC_H_
 
-#include <linux/xarray.h>
 #include <linux/delay.h>
+#include <linux/iosys-map.h>
+#include <linux/xarray.h>
 
 #include "intel_uncore.h"
 #include "intel_guc_fw.h"
@@ -148,6 +149,7 @@ struct intel_guc {
        struct i915_vma *ads_vma;
        /** @ads_blob: contents of the GuC ADS */
        struct __guc_ads_blob *ads_blob;
+       struct iosys_map ads_map;
        /** @ads_regset_size: size of the save/restore regsets in the ADS */
        u32 ads_regset_size;
        /**
index 7e41175..4ea8427 100644 (file)
@@ -666,6 +666,11 @@ int intel_guc_ads_create(struct intel_guc *guc)
        if (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);
 
        return 0;
@@ -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);
        guc->ads_blob = NULL;
+       iosys_map_clear(&guc->ads_map);
        kfree(guc->ads_regset);
 }