drm/i915/perf: complete programming whitelisting for XEHPSDV
authorLionel Landwerlin <lionel.g.landwerlin@intel.com>
Wed, 26 Oct 2022 22:21:01 +0000 (22:21 +0000)
committerJohn Harrison <John.C.Harrison@Intel.com>
Thu, 27 Oct 2022 19:37:02 +0000 (12:37 -0700)
We have an additional register to select which slices contribute to
OAG/OAG counter increments.

Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
Reviewed-by: Ashutosh Dixit <ashutosh.dixit@intel.com>
Signed-off-by: John Harrison <John.C.Harrison@Intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20221026222102.5526-16-umesh.nerlige.ramappa@intel.com
drivers/gpu/drm/i915/i915_drv.h
drivers/gpu/drm/i915/i915_pci.c
drivers/gpu/drm/i915/i915_perf.c
drivers/gpu/drm/i915/intel_device_info.h

index 34f0bcc36671e17565b0407c5367fa0fbe62cdd8..b1c4e924d8838fed5e539aa6661b78b4daae2638 100644 (file)
@@ -903,6 +903,8 @@ IS_SUBPLATFORM(const struct drm_i915_private *i915,
 
 #define HAS_OA_BPC_REPORTING(dev_priv) \
        (INTEL_INFO(dev_priv)->has_oa_bpc_reporting)
+#define HAS_OA_SLICE_CONTRIB_LIMITS(dev_priv) \
+       (INTEL_INFO(dev_priv)->has_oa_slice_contrib_limits)
 
 /*
  * Set this flag, when platform requires 64K GTT page sizes or larger for
index 7b751bf4be21ed2b435ceea5a7e480f0040d240c..6b22fb506aa994dcf92fa38b816b21af9642a9b4 100644 (file)
@@ -1024,6 +1024,7 @@ static const struct intel_device_info adl_p_info = {
        .has_logical_ring_elsq = 1, \
        .has_mslice_steering = 1, \
        .has_oa_bpc_reporting = 1, \
+       .has_oa_slice_contrib_limits = 1, \
        .has_rc6 = 1, \
        .has_reset_engine = 1, \
        .has_rps = 1, \
index b2766485888fd347b98b769c99ee20df11d5acdc..2db74b5a54cd69b49bcf26fb293afb37e7d14304 100644 (file)
@@ -4261,6 +4261,11 @@ static const struct i915_range gen12_oa_b_counters[] = {
        {}
 };
 
+static const struct i915_range xehp_oa_b_counters[] = {
+       { .start = 0xdc48, .end = 0xdc48 },     /* OAA_ENABLE_REG */
+       { .start = 0xdd00, .end = 0xdd48 },     /* OAG_LCE0_0 - OAA_LENABLE_REG */
+};
+
 static const struct i915_range gen7_oa_mux_regs[] = {
        { .start = 0x91b8, .end = 0x91cc },     /* OA_PERFCNT[1-2], OA_PERFMATRIX */
        { .start = 0x9800, .end = 0x9888 },     /* MICRO_BP0_0 - NOA_WRITE */
@@ -4335,6 +4340,12 @@ static bool gen12_is_valid_b_counter_addr(struct i915_perf *perf, u32 addr)
        return reg_in_range_table(addr, gen12_oa_b_counters);
 }
 
+static bool xehp_is_valid_b_counter_addr(struct i915_perf *perf, u32 addr)
+{
+       return reg_in_range_table(addr, xehp_oa_b_counters) ||
+               reg_in_range_table(addr, gen12_oa_b_counters);
+}
+
 static bool gen12_is_valid_mux_addr(struct i915_perf *perf, u32 addr)
 {
        return reg_in_range_table(addr, gen12_oa_mux_regs);
@@ -4847,6 +4858,8 @@ void i915_perf_init(struct drm_i915_private *i915)
                        perf->ops.oa_hw_tail_read = gen8_oa_hw_tail_read;
                } else if (GRAPHICS_VER(i915) == 12) {
                        perf->ops.is_valid_b_counter_reg =
+                               HAS_OA_SLICE_CONTRIB_LIMITS(i915) ?
+                               xehp_is_valid_b_counter_addr :
                                gen12_is_valid_b_counter_addr;
                        perf->ops.is_valid_mux_reg =
                                gen12_is_valid_mux_addr;
index d11546d87fe77b1b1e605aed16ccdebd15d887b7..4ee6074955efec06a1c793f4bbd1ef4f93ff32ba 100644 (file)
@@ -164,6 +164,7 @@ enum intel_ppgtt_type {
        func(has_media_ratio_mode); \
        func(has_mslice_steering); \
        func(has_oa_bpc_reporting); \
+       func(has_oa_slice_contrib_limits); \
        func(has_one_eu_per_fuse_bit); \
        func(has_pxp); \
        func(has_rc6); \