On Wed, May 20, 2026 at 5:30 AM Rob Clark <[email protected]> wrote:
>
> On Wed, May 20, 2026 at 1:36 AM Akhil P Oommen <[email protected]> 
> wrote:
> >
> > 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.
>
> Yes, so far we only support the counters that mesa has been using.
> There are some missing.  Although RBBM and CMP look straightforward to
> add.

Oh, actually, it looks like we need to use RBBM_PERFCTR_LOAD_VALUE on
a6xx gen1/gen2.  So I'll leave out RBBM until we have a way of dealing
with mid-gen counter changes.  But adding CMP looks doable.

BR,
-R

>
> > > +    "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
>
> We don't yet have a way of dealing with mid-gen changes like this..  I
> have some ideas, but nothing implemented yet.  The same situation
> comes up for a8xx, where some new counter groups are added.
>
> > > +            "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,
>
> ack
>
> >
> > > +            "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",
>
> ack
>
> BR,
> -R

Reply via email to