ARCv2: perf: Finally introduce HS perf unit
authorVineet Gupta <vgupta@synopsys.com>
Tue, 18 Nov 2014 12:06:11 +0000 (17:36 +0530)
committerVineet Gupta <vgupta@synopsys.com>
Thu, 27 Aug 2015 09:29:07 +0000 (14:59 +0530)
With all features in place, the ARC HS pct block can now be effectively
allowed to be probed/used

Acked-by: Peter Zijlstra <peterz@infradead.org>
Cc: Arnaldo Carvalho de Melo <acme@kernel.org>
Signed-off-by: Alexey Brodkin <abrodkin@synopsys.com>
Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
Documentation/devicetree/bindings/arc/archs-pct.txt [new file with mode: 0644]
MAINTAINERS
arch/arc/include/asm/perf_event.h
arch/arc/kernel/perf_event.c

diff --git a/Documentation/devicetree/bindings/arc/archs-pct.txt b/Documentation/devicetree/bindings/arc/archs-pct.txt
new file mode 100644 (file)
index 0000000..1ae98b8
--- /dev/null
@@ -0,0 +1,17 @@
+* ARC HS Performance Counters
+
+The ARC HS can be configured with a pipeline performance monitor for counting
+CPU and cache events like cache misses and hits. Like conventional PCT there
+are 100+ hardware conditions dynamically mapped to upto 32 counters.
+It also supports overflow interrupts.
+
+Required properties:
+
+- compatible : should contain
+       "snps,archs-pct"
+
+Example:
+
+pmu {
+        compatible = "snps,archs-pct";
+};
index d7ab7363b2637a1e1573309ec9235c109002c3d9..d4cda4273131dcb6398c8745b793a3a527c6d7b1 100644 (file)
@@ -9874,7 +9874,7 @@ SYNOPSYS ARC ARCHITECTURE
 M:     Vineet Gupta <vgupta@synopsys.com>
 S:     Supported
 F:     arch/arc/
-F:     Documentation/devicetree/bindings/arc/
+F:     Documentation/devicetree/bindings/arc/*
 F:     drivers/tty/serial/arc_uart.c
 T:     git git://git.kernel.org/pub/scm/linux/kernel/git/vgupta/arc.git
 
index 5824ab46cb71ebdb32c1097e638aadbe02068e10..5f071762fb1c7278d128b17c987cf96b4b7f73f3 100644 (file)
@@ -105,8 +105,11 @@ static const char * const arc_pmu_ev_hw_map[] = {
        [PERF_COUNT_HW_INSTRUCTIONS] = "iall",
        [PERF_COUNT_HW_BRANCH_INSTRUCTIONS] = "ijmp", /* Excludes ZOL jumps */
        [PERF_COUNT_ARC_BPOK]         = "bpok",   /* NP-NT, PT-T, PNT-NT */
+#ifdef CONFIG_ISA_ARCV2
+       [PERF_COUNT_HW_BRANCH_MISSES] = "bpmp",
+#else
        [PERF_COUNT_HW_BRANCH_MISSES] = "bpfail", /* NP-T, PT-NT, PNT-T */
-
+#endif
        [PERF_COUNT_ARC_LDC] = "imemrdc",       /* Instr: mem read cached */
        [PERF_COUNT_ARC_STC] = "imemwrc",       /* Instr: mem write cached */
 
index 743065251e232c2685eb12dd576666bf76c17d68..0c08bb1ce15aab114c344609879eaa86bfa59a9d 100644 (file)
@@ -551,6 +551,7 @@ static int arc_pmu_device_probe(struct platform_device *pdev)
 #ifdef CONFIG_OF
 static const struct of_device_id arc_pmu_match[] = {
        { .compatible = "snps,arc700-pct" },
+       { .compatible = "snps,archs-pct" },
        {},
 };
 MODULE_DEVICE_TABLE(of, arc_pmu_match);
@@ -558,7 +559,7 @@ MODULE_DEVICE_TABLE(of, arc_pmu_match);
 
 static struct platform_driver arc_pmu_driver = {
        .driver = {
-               .name           = "arc700-pct",
+               .name           = "arc-pct",
                .of_match_table = of_match_ptr(arc_pmu_match),
        },
        .probe          = arc_pmu_device_probe,