On 5/19/2026 12:36 AM, Rob Clark wrote:
> Pull in perfcntr json and wire up generation of perfcntr tables.
>
> Sync from mesa commit d2c4653ee953 ("freedreno/registers: Add gen8 perfcntrs")
>
> Signed-off-by: Rob Clark <[email protected]>
> Reviewed-by: Dmitry Baryshkov <[email protected]>
> Reviewed-by: Anna Maniscalco <[email protected]>
> ---
> drivers/gpu/drm/msm/Makefile | 25 +-
> drivers/gpu/drm/msm/msm_perfcntr.h | 48 ++++
> .../msm/registers/adreno/a2xx_perfcntrs.json | 109 ++++++++
> .../msm/registers/adreno/a5xx_perfcntrs.json | 128 ++++++++++
> .../msm/registers/adreno/a6xx_perfcntrs.json | 105 ++++++++
> .../msm/registers/adreno/a7xx_perfcntrs.json | 228 +++++++++++++++++
> .../msm/registers/adreno/a8xx_perfcntrs.json | 240 ++++++++++++++++++
> 7 files changed, 882 insertions(+), 1 deletion(-)
> create mode 100644 drivers/gpu/drm/msm/msm_perfcntr.h
> create mode 100644 drivers/gpu/drm/msm/registers/adreno/a2xx_perfcntrs.json
> create mode 100644 drivers/gpu/drm/msm/registers/adreno/a5xx_perfcntrs.json
> create mode 100644 drivers/gpu/drm/msm/registers/adreno/a6xx_perfcntrs.json
> create mode 100644 drivers/gpu/drm/msm/registers/adreno/a7xx_perfcntrs.json
> create mode 100644 drivers/gpu/drm/msm/registers/adreno/a8xx_perfcntrs.json
>
<< snip >>
> diff --git a/drivers/gpu/drm/msm/registers/adreno/a6xx_perfcntrs.json
> b/drivers/gpu/drm/msm/registers/adreno/a6xx_perfcntrs.json
> new file mode 100644
> index 000000000000..8bb31820479e
> --- /dev/null
> +++ b/drivers/gpu/drm/msm/registers/adreno/a6xx_perfcntrs.json
> @@ -0,0 +1,105 @@
> +{
RBBM and CMP groups are missing here.
> + "chip": "A6XX",
> + "groups": [
> + {
> + "name": "CP",
> + "num": 14,
> + "reserved": [ 0 ],
> + "select": "CP_PERFCTR_CP_SEL",
> + "counter": "RBBM_PERFCTR_CP",
> + "countable_type": "a6xx_cp_perfcounter_select"
<< snip >>
> diff --git a/drivers/gpu/drm/msm/registers/adreno/a7xx_perfcntrs.json
> b/drivers/gpu/drm/msm/registers/adreno/a7xx_perfcntrs.json
> new file mode 100644
> index 000000000000..e60aab1862ec
> --- /dev/null
> +++ b/drivers/gpu/drm/msm/registers/adreno/a7xx_perfcntrs.json
> @@ -0,0 +1,228 @@
> +{
> + "chip": "A7XX",
> + "groups": [
> + {
> + "name": "CP",
> + "num": 14,
> + "reserved": [ 0 ],
> + "select": "CP_PERFCTR_CP_SEL",
> + "counter": "RBBM_PERFCTR_CP",
> + "countable_type": "a7xx_cp_perfcounter_select"
> + },
> + {
> + "name": "RBBM",
> + "num": 4,
> + "select": "RBBM_PERFCTR_RBBM_SEL",
> + "counter": "RBBM_PERFCTR_RBBM",
> + "countable_type": "a7xx_rbbm_perfcounter_select"
> + },
> + {
> + "name": "PC",
> + "pipe": "BR",
> + "num": 8,
> + "select": "PC_PERFCTR_PC_SEL",
> + "counter": "RBBM_PERFCTR_PC",
> + "countable_type": "a7xx_pc_perfcounter_select"
> + },
> + {
> + "name": "VFD",
> + "pipe": "BR",
> + "num": 8,
> + "select": "VFD_PERFCTR_VFD_SEL",
> + "counter": "RBBM_PERFCTR_VFD",
> + "countable_type": "a7xx_vfd_perfcounter_select"
> + },
> + {
> + "name": "HLSQ",
> + "pipe": "BR",
> + "num": 6,
> + "select": "SP_PERFCTR_HLSQ_SEL",
> + "counter": "RBBM_PERFCTR_HLSQ",
> + "countable_type": "a7xx_hlsq_perfcounter_select"
> + },
> + {
> + "name": "VPC",
> + "pipe": "BR",
> + "num": 6,
> + "select": "VPC_PERFCTR_VPC_SEL",
> + "counter": "RBBM_PERFCTR_VPC",
> + "countable_type": "a7xx_vpc_perfcounter_select"
> + },
> + {
> + "name": "TSE",
> + "pipe": "BR",
> + "num": 4,
> + "select": "GRAS_PERFCTR_TSE_SEL",
> + "counter": "RBBM_PERFCTR_TSE",
> + "countable_type": "a7xx_tse_perfcounter_select"
> + },
> + {
> + "name": "RAS",
> + "pipe": "BR",
> + "num": 4,
> + "select": "GRAS_PERFCTR_RAS_SEL",
> + "counter": "RBBM_PERFCTR_RAS",
> + "countable_type": "a7xx_ras_perfcounter_select"
> + },
> + {
> + "name": "UCHE",
> + "num": 12,
A740 and newer has 24 counters
> + "select": "UCHE_PERFCTR_UCHE_SEL",
> + "counter": "RBBM_PERFCTR_UCHE",
> + "countable_type": "a7xx_uche_perfcounter_select"
> + },
<< snip >>
> diff --git a/drivers/gpu/drm/msm/registers/adreno/a8xx_perfcntrs.json
> b/drivers/gpu/drm/msm/registers/adreno/a8xx_perfcntrs.json
> new file mode 100644
> index 000000000000..503b113df397
> --- /dev/null
> +++ b/drivers/gpu/drm/msm/registers/adreno/a8xx_perfcntrs.json
> @@ -0,0 +1,240 @@
> +{
> + "chip": "A8XX",
> + "groups": [
> + {
> + "name": "CP",
> + "num": 14,
> + "reserved": [ 0 ],
> + "select": "CP_PERFCTR_CP_SEL",
> + "counter": "RBBM_PERFCTR_CP",
> + "countable_type": "a8xx_cp_perfcounter_select"
> + },
> + {
> + "name": "RBBM",
> + "num": 4,
> + "select": "RBBM_PERFCTR_RBBM_SEL",
> + "slice_select": [ "RBBM_SLICE_PERFCTR_RBBM_SEL" ],
> + "counter": "RBBM_PERFCTR_RBBM",
> + "countable_type": "a8xx_rbbm_perfcounter_select"
> + },
> + {
> + "name": "PC",
> + "pipe": "BR",
> + "num": 8,
> + "select": "PC_PERFCTR_PC_SEL",
> + "slice_select": [ "PC_SLICE_PERFCTR_PC_SEL" ],
> + "counter": "RBBM_PERFCTR_PC",
> + "countable_type": "a8xx_pc_perfcounter_select"
> + },
> + {
> + "name": "VFD",
> + "pipe": "BR",
> + "num": 8,
> + "select": "VFD_PERFCTR_VFD_SEL",
> + "counter": "RBBM_PERFCTR_VFD",
> + "countable_type": "a8xx_vfd_perfcounter_select"
> + },
> + {
> + "name": "HLSQ",
> + "pipe": "BR",
> + "num": 6,
> + "select": "SP_PERFCTR_HLSQ_SEL",
> + "slice_select": [ "SP_PERFCTR_HLSQ_SEL_2" ],
> + "counter": "RBBM_PERFCTR_HLSQ",
> + "countable_type": "a8xx_hlsq_perfcounter_select"
> + },
> + {
> + "name": "VPC",
> + "pipe": "BR",
> + "num": 6,
> + "select": "VPC_PERFCTR_VPC_SEL",
> + "slice_select": [ "VPC_PERFCTR_VPC_SEL_1",
> "VPC_PERFCTR_VPC_SEL_2" ],
> + "counter": "RBBM_PERFCTR_VPC",
> + "countable_type": "a8xx_vpc_perfcounter_select"
> + },
> + {
> + "name": "TSE",
> + "pipe": "BR",
> + "num": 4,
> + "select": "GRAS_PERFCTR_TSE_SEL",
> + "slice_select": [ "GRAS_PERFCTR_TSEFE_SEL" ],
> + "counter": "RBBM_PERFCTR_TSE",
> + "countable_type": "a8xx_tse_perfcounter_select"
> + },
> + {
> + "name": "RAS",
> + "pipe": "BR",
> + "num": 4,
> + "select": "GRAS_PERFCTR_RAS_SEL",
> + "counter": "RBBM_PERFCTR_RAS",
> + "countable_type": "a8xx_ras_perfcounter_select"
> + },
> + {
> + "name": "UCHE",
> + "num": 12,
"num": 24,
> + "select": "UCHE_PERFCTR_UCHE_SEL",
> + "counter": "RBBM_PERFCTR_UCHE",
> + "countable_type": "a8xx_uche_perfcounter_select"
> + },
> + {
> + "name": "TP",
> + "pipe": "BR",
> + "num": 12,
> + "select": "TPL1_PERFCTR_TP_SEL",
> + "counter": "RBBM_PERFCTR_TP",
> + "countable_type": "a8xx_tp_perfcounter_select"
> + },
> + {
> + "name": "SP",
> + "pipe": "BR",
> + "num": 24,
> + "select": "SP_PERFCTR_SP_SEL",
> + "counter": "RBBM_PERFCTR_SP",
> + "countable_type": "a8xx_sp_perfcounter_select"
> + },
> + {
> + "name": "RB",
> + "pipe": "BR",
> + "num": 8,
> + "select": "RB_PERFCTR_RB_SEL",
> + "counter": "RBBM_PERFCTR_RB",
> + "countable_type": "a8xx_rb_perfcounter_select"
> + },
> + {
> + "name": "VSC",
> + "num": 2,
> + "select": "VSC_PERFCTR_VSC_SEL",
> + "counter": "RBBM_PERFCTR_VSC",
> + "countable_type": "a8xx_vsc_perfcounter_select"
> + },
> + {
> + "name": "CCU",
> + "pipe": "BR",
> + "num": 5,
> + "select": "RB_PERFCTR_CCU_SEL",
> + "counter": "RBBM_PERFCTR_CCU",
> + "countable_type": "a8xx_ccu_perfcounter_select"
> + },
> + {
> + "name": "LRZ",
> + "pipe": "BR",
> + "num": 4,
> + "select": "GRAS_PERFCTR_LRZ_SEL",
> + "counter": "RBBM_PERFCTR_LRZ",
> + "countable_type": "a8xx_lrz_perfcounter_select"
> + },
> + {
> + "name": "CMP",
"pipe": "BR",
-Akhil