perf cs-etm: Update deduction of TRCCONFIGR register for branch broadcast
authorJames Clark <james.clark@arm.com>
Thu, 13 Jan 2022 09:10:52 +0000 (09:10 +0000)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Tue, 15 Feb 2022 20:15:32 +0000 (17:15 -0300)
Now that a config flag for branch broadcast has been added, take it into
account when trying to deduce what the driver would have programmed the
TRCCONFIGR register to.

Reviewed-by: Leo Yan <leo.yan@linaro.org>
Reviewed-by: Mike Leach <mike.leach@linaro.org>
Reviewed-by: Suzuki Poulouse <suzuki.poulose@arm.com>
Signed-off-by: James Clark <james.clark@arm.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: John Garry <john.garry@huawei.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Will Deacon <will@kernel.org>
Cc: coresight@lists.linaro.org
Cc: linux-arm-kernel@lists.infradead.org
Cc: linux-doc@vger.kernel.org
Link: https://lore.kernel.org/r/20220113091056.1297982-4-james.clark@arm.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/include/linux/coresight-pmu.h
tools/perf/arch/arm/util/cs-etm.c

index 4ac5c08..6c2fd6c 100644 (file)
@@ -18,6 +18,7 @@
  * ETMv3.5/PTM doesn't define ETMCR config bits with prefix "ETM3_" and
  * directly use below macros as config bits.
  */
+#define ETM_OPT_BRANCH_BROADCAST 8
 #define ETM_OPT_CYCACC         12
 #define ETM_OPT_CTXTID         14
 #define ETM_OPT_CTXTID2                15
@@ -25,6 +26,7 @@
 #define ETM_OPT_RETSTK         29
 
 /* ETMv4 CONFIGR programming bits for the ETM OPTs */
+#define ETM4_CFG_BIT_BB         3
 #define ETM4_CFG_BIT_CYCACC    4
 #define ETM4_CFG_BIT_CTXTID    6
 #define ETM4_CFG_BIT_VMID      7
index 2e8b2c4..cbc5552 100644 (file)
@@ -510,6 +510,9 @@ static u64 cs_etmv4_get_config(struct auxtrace_record *itr)
        if (config_opts & BIT(ETM_OPT_CTXTID2))
                config |= BIT(ETM4_CFG_BIT_VMID) |
                          BIT(ETM4_CFG_BIT_VMID_OPT);
+       if (config_opts & BIT(ETM_OPT_BRANCH_BROADCAST))
+               config |= BIT(ETM4_CFG_BIT_BB);
+
        return config;
 }