drm/i915/pvc: Interrupt support for new copy engines
authorMatt Roper <matthew.d.roper@intel.com>
Thu, 5 May 2022 21:38:09 +0000 (14:38 -0700)
committerMatt Roper <matthew.d.roper@intel.com>
Tue, 10 May 2022 22:32:07 +0000 (15:32 -0700)
Add the interrupt handler support for new copy engines.

Bspec: 54030
Original-author: CQ Tang
Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
Reviewed-by: Stuart Summers <stuart.summers@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220505213812.3979301-10-matthew.d.roper@intel.com
drivers/gpu/drm/i915/gt/intel_gt_irq.c
drivers/gpu/drm/i915/gt/intel_gt_regs.h

index 88b4bec..3a72d4f 100644 (file)
@@ -193,6 +193,14 @@ void gen11_gt_irq_reset(struct intel_gt *gt)
        /* Restore masks irqs on RCS, BCS, VCS and VECS engines. */
        intel_uncore_write(uncore, GEN11_RCS0_RSVD_INTR_MASK,   ~0);
        intel_uncore_write(uncore, GEN11_BCS_RSVD_INTR_MASK,    ~0);
+       if (HAS_ENGINE(gt, BCS1) || HAS_ENGINE(gt, BCS2))
+               intel_uncore_write(uncore, XEHPC_BCS1_BCS2_INTR_MASK, ~0);
+       if (HAS_ENGINE(gt, BCS3) || HAS_ENGINE(gt, BCS4))
+               intel_uncore_write(uncore, XEHPC_BCS3_BCS4_INTR_MASK, ~0);
+       if (HAS_ENGINE(gt, BCS5) || HAS_ENGINE(gt, BCS6))
+               intel_uncore_write(uncore, XEHPC_BCS5_BCS6_INTR_MASK, ~0);
+       if (HAS_ENGINE(gt, BCS7) || HAS_ENGINE(gt, BCS8))
+               intel_uncore_write(uncore, XEHPC_BCS7_BCS8_INTR_MASK, ~0);
        intel_uncore_write(uncore, GEN11_VCS0_VCS1_INTR_MASK,   ~0);
        intel_uncore_write(uncore, GEN11_VCS2_VCS3_INTR_MASK,   ~0);
        if (HAS_ENGINE(gt, VCS4) || HAS_ENGINE(gt, VCS5))
@@ -248,6 +256,14 @@ void gen11_gt_irq_postinstall(struct intel_gt *gt)
        /* Unmask irqs on RCS, BCS, VCS and VECS engines. */
        intel_uncore_write(uncore, GEN11_RCS0_RSVD_INTR_MASK, ~smask);
        intel_uncore_write(uncore, GEN11_BCS_RSVD_INTR_MASK, ~smask);
+       if (HAS_ENGINE(gt, BCS1) || HAS_ENGINE(gt, BCS2))
+               intel_uncore_write(uncore, XEHPC_BCS1_BCS2_INTR_MASK, ~dmask);
+       if (HAS_ENGINE(gt, BCS3) || HAS_ENGINE(gt, BCS4))
+               intel_uncore_write(uncore, XEHPC_BCS3_BCS4_INTR_MASK, ~dmask);
+       if (HAS_ENGINE(gt, BCS5) || HAS_ENGINE(gt, BCS6))
+               intel_uncore_write(uncore, XEHPC_BCS5_BCS6_INTR_MASK, ~dmask);
+       if (HAS_ENGINE(gt, BCS7) || HAS_ENGINE(gt, BCS8))
+               intel_uncore_write(uncore, XEHPC_BCS7_BCS8_INTR_MASK, ~dmask);
        intel_uncore_write(uncore, GEN11_VCS0_VCS1_INTR_MASK, ~dmask);
        intel_uncore_write(uncore, GEN11_VCS2_VCS3_INTR_MASK, ~dmask);
        if (HAS_ENGINE(gt, VCS4) || HAS_ENGINE(gt, VCS5))
index aa2c097..fe09288 100644 (file)
 #define GEN11_GUNIT_CSME_INTR_MASK             _MMIO(0x1900f4)
 #define GEN12_CCS0_CCS1_INTR_MASK              _MMIO(0x190100)
 #define GEN12_CCS2_CCS3_INTR_MASK              _MMIO(0x190104)
+#define XEHPC_BCS1_BCS2_INTR_MASK              _MMIO(0x190110)
+#define XEHPC_BCS3_BCS4_INTR_MASK              _MMIO(0x190114)
+#define XEHPC_BCS5_BCS6_INTR_MASK              _MMIO(0x190118)
+#define XEHPC_BCS7_BCS8_INTR_MASK              _MMIO(0x19011c)
 
 #define GEN12_SFC_DONE(n)                      _MMIO(0x1cc000 + (n) * 0x1000)