drm/i915/mtl: Hook up interrupts for standalone media
authorMatt Roper <matthew.d.roper@intel.com>
Tue, 6 Sep 2022 23:49:34 +0000 (16:49 -0700)
committerJoonas Lahtinen <joonas.lahtinen@linux.intel.com>
Mon, 12 Sep 2022 12:23:12 +0000 (15:23 +0300)
Top-level handling of standalone media interrupts will be processed as
part of the primary GT's interrupt handler (since primary and media GTs
share an MMIO space, unlike remote tile setups).  When we get down to
the point of handling engine interrupts, we need to take care to lookup
VCS and VECS engines in the media GT rather than the primary.

There are also a couple of additional "other" instance bits that
correspond to the media GT's GuC and media GT's power management
interrupts; we need to direct those to the media GT instance as well.

Bspec: 45605
Cc: Anusha Srivatsa <anusha.srivatsa@intel.com>
Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
Reviewed-by: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220906234934.3655440-15-matthew.d.roper@intel.com
Signed-off-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
drivers/gpu/drm/i915/gt/intel_gt_irq.c
drivers/gpu/drm/i915/gt/intel_gt_regs.h
drivers/gpu/drm/i915/gt/intel_sa_media.c
drivers/gpu/drm/i915/i915_drv.h

index 0dfd0c42d00da81e3537fdd674c7bd8d443510a3..f26882fdc24c9638832acb4b6155b8c7da468efd 100644 (file)
@@ -59,11 +59,17 @@ static void
 gen11_other_irq_handler(struct intel_gt *gt, const u8 instance,
                        const u16 iir)
 {
+       struct intel_gt *media_gt = gt->i915->media_gt;
+
        if (instance == OTHER_GUC_INSTANCE)
                return guc_irq_handler(&gt->uc.guc, iir);
+       if (instance == OTHER_MEDIA_GUC_INSTANCE && media_gt)
+               return guc_irq_handler(&media_gt->uc.guc, iir);
 
        if (instance == OTHER_GTPM_INSTANCE)
                return gen11_rps_irq_handler(&gt->rps, iir);
+       if (instance == OTHER_MEDIA_GTPM_INSTANCE && media_gt)
+               return gen11_rps_irq_handler(&media_gt->rps, iir);
 
        if (instance == OTHER_KCR_INSTANCE)
                return intel_pxp_irq_handler(&gt->pxp, iir);
@@ -81,6 +87,18 @@ gen11_engine_irq_handler(struct intel_gt *gt, const u8 class,
 {
        struct intel_engine_cs *engine;
 
+       /*
+        * Platforms with standalone media have their media engines in another
+        * GT.
+        */
+       if (MEDIA_VER(gt->i915) >= 13 &&
+           (class == VIDEO_DECODE_CLASS || class == VIDEO_ENHANCEMENT_CLASS)) {
+               if (!gt->i915->media_gt)
+                       goto err;
+
+               gt = gt->i915->media_gt;
+       }
+
        if (instance <= MAX_ENGINE_INSTANCE)
                engine = gt->engine_class[class][instance];
        else
@@ -89,6 +107,7 @@ gen11_engine_irq_handler(struct intel_gt *gt, const u8 class,
        if (likely(engine))
                return intel_engine_cs_irq(engine, iir);
 
+err:
        WARN_ONCE(1, "unhandled engine interrupt class=0x%x, instance=0x%x\n",
                  class, instance);
 }
index fb2c56777480721dd81209366ead4a051f6cfd90..2275ee47da95589311015189babcc8a40d0cb40d 100644 (file)
 #define   OTHER_GTPM_INSTANCE                  1
 #define   OTHER_KCR_INSTANCE                   4
 #define   OTHER_GSC_INSTANCE                   6
+#define   OTHER_MEDIA_GUC_INSTANCE             16
+#define   OTHER_MEDIA_GTPM_INSTANCE            17
 
 #define GEN11_IIR_REG_SELECTOR(x)              _MMIO(0x190070 + ((x) * 4))
 
index 5516e9c363a48ecbf3cda7eb5738c8ceb3c6b029..e8f3d18c12b838d37a1e06be16e7ef2aa06cb0fd 100644 (file)
@@ -36,5 +36,12 @@ int intel_sa_mediagt_setup(struct intel_gt *gt, phys_addr_t phys_addr,
        gt->uncore = uncore;
        gt->phys_addr = phys_addr;
 
+       /*
+        * For current platforms we can assume there's only a single
+        * media GT and cache it for quick lookup.
+        */
+       drm_WARN_ON(&i915->drm, i915->media_gt);
+       i915->media_gt = gt;
+
        return 0;
 }
index 9d6d630ad50600ca517a679164cfc6cafeb9b590..b11c212f1b0d6a3a321cce90c8cae3da03c91a63 100644 (file)
@@ -780,6 +780,9 @@ struct drm_i915_private {
 
        struct kobject *sysfs_gt;
 
+       /* Quick lookup of media GT (current platforms only have one) */
+       struct intel_gt *media_gt;
+
        struct {
                struct i915_gem_contexts {
                        spinlock_t lock; /* locks list */