1[
2    {
3        "MetricExpr": "FETCH_BUBBLE / (4 * CPU_CYCLES)",
4        "PublicDescription": "Frontend bound L1 topdown metric",
5        "BriefDescription": "Frontend bound L1 topdown metric",
6        "MetricGroup": "TopDownL1",
7        "MetricName": "frontend_bound"
8    },
9    {
10        "MetricExpr": "(INST_SPEC - INST_RETIRED) / (4 * CPU_CYCLES)",
11        "PublicDescription": "Bad Speculation L1 topdown metric",
12        "BriefDescription": "Bad Speculation L1 topdown metric",
13        "MetricGroup": "TopDownL1",
14        "MetricName": "bad_speculation"
15    },
16    {
17        "MetricExpr": "INST_RETIRED / (CPU_CYCLES * 4)",
18        "PublicDescription": "Retiring L1 topdown metric",
19        "BriefDescription": "Retiring L1 topdown metric",
20        "MetricGroup": "TopDownL1",
21        "MetricName": "retiring"
22    },
23    {
24        "MetricExpr": "1 - (frontend_bound + bad_speculation + retiring)",
25        "PublicDescription": "Backend Bound L1 topdown metric",
26        "BriefDescription": "Backend Bound L1 topdown metric",
27        "MetricGroup": "TopDownL1",
28        "MetricName": "backend_bound"
29    },
30    {
31        "MetricExpr": "armv8_pmuv3_0@event\\=0x201d@ / CPU_CYCLES",
32        "PublicDescription": "Fetch latency bound L2 topdown metric",
33        "BriefDescription": "Fetch latency bound L2 topdown metric",
34        "MetricGroup": "TopDownL2",
35        "MetricName": "fetch_latency_bound"
36    },
37    {
38        "MetricExpr": "frontend_bound - fetch_latency_bound",
39        "PublicDescription": "Fetch bandwidth bound L2 topdown metric",
40        "BriefDescription": "Fetch bandwidth bound L2 topdown metric",
41        "MetricGroup": "TopDownL2",
42        "MetricName": "fetch_bandwidth_bound"
43    },
44    {
45        "MetricExpr": "(bad_speculation * BR_MIS_PRED) / (BR_MIS_PRED + armv8_pmuv3_0@event\\=0x2013@)",
46        "PublicDescription": "Branch mispredicts L2 topdown metric",
47        "BriefDescription": "Branch mispredicts L2 topdown metric",
48        "MetricGroup": "TopDownL2",
49        "MetricName": "branch_mispredicts"
50    },
51    {
52        "MetricExpr": "bad_speculation - branch_mispredicts",
53        "PublicDescription": "Machine clears L2 topdown metric",
54        "BriefDescription": "Machine clears L2 topdown metric",
55        "MetricGroup": "TopDownL2",
56        "MetricName": "machine_clears"
57    },
58    {
59        "MetricExpr": "(EXE_STALL_CYCLE - (MEM_STALL_ANYLOAD + armv8_pmuv3_0@event\\=0x7005@)) / CPU_CYCLES",
60        "PublicDescription": "Core bound L2 topdown metric",
61        "BriefDescription": "Core bound L2 topdown metric",
62        "MetricGroup": "TopDownL2",
63        "MetricName": "core_bound"
64    },
65    {
66        "MetricExpr": "(MEM_STALL_ANYLOAD + armv8_pmuv3_0@event\\=0x7005@) / CPU_CYCLES",
67        "PublicDescription": "Memory bound L2 topdown metric",
68        "BriefDescription": "Memory bound L2 topdown metric",
69        "MetricGroup": "TopDownL2",
70        "MetricName": "memory_bound"
71    },
72    {
73        "MetricExpr": "(((L2I_TLB - L2I_TLB_REFILL) * 15) + (L2I_TLB_REFILL * 100)) / CPU_CYCLES",
74        "PublicDescription": "Idle by itlb miss L3 topdown metric",
75        "BriefDescription": "Idle by itlb miss L3 topdown metric",
76        "MetricGroup": "TopDownL3",
77        "MetricName": "idle_by_itlb_miss"
78    },
79    {
80        "MetricExpr": "(((L2I_CACHE - L2I_CACHE_REFILL) * 15) + (L2I_CACHE_REFILL * 100)) / CPU_CYCLES",
81        "PublicDescription": "Idle by icache miss L3 topdown metric",
82        "BriefDescription": "Idle by icache miss L3 topdown metric",
83        "MetricGroup": "TopDownL3",
84        "MetricName": "idle_by_icache_miss"
85    },
86    {
87        "MetricExpr": "(BR_MIS_PRED * 5) / CPU_CYCLES",
88        "PublicDescription": "BP misp flush L3 topdown metric",
89        "BriefDescription": "BP misp flush L3 topdown metric",
90        "MetricGroup": "TopDownL3",
91        "MetricName": "bp_misp_flush"
92    },
93    {
94        "MetricExpr": "(armv8_pmuv3_0@event\\=0x2013@ * 5) / CPU_CYCLES",
95        "PublicDescription": "OOO flush L3 topdown metric",
96        "BriefDescription": "OOO flush L3 topdown metric",
97        "MetricGroup": "TopDownL3",
98        "MetricName": "ooo_flush"
99    },
100    {
101        "MetricExpr": "(armv8_pmuv3_0@event\\=0x1001@ * 5) / CPU_CYCLES",
102        "PublicDescription": "Static predictor flush L3 topdown metric",
103        "BriefDescription": "Static predictor flush L3 topdown metric",
104        "MetricGroup": "TopDownL3",
105        "MetricName": "sp_flush"
106    },
107    {
108        "MetricExpr": "armv8_pmuv3_0@event\\=0x1010@ / BR_MIS_PRED",
109        "PublicDescription": "Indirect branch L3 topdown metric",
110        "BriefDescription": "Indirect branch L3 topdown metric",
111        "MetricGroup": "TopDownL3",
112        "MetricName": "indirect_branch"
113    },
114    {
115        "MetricExpr": "(armv8_pmuv3_0@event\\=0x1013@ + armv8_pmuv3_0@event\\=0x1016@) / BR_MIS_PRED",
116        "PublicDescription": "Push branch L3 topdown metric",
117        "BriefDescription": "Push branch L3 topdown metric",
118        "MetricGroup": "TopDownL3",
119        "MetricName": "push_branch"
120    },
121    {
122        "MetricExpr": "armv8_pmuv3_0@event\\=0x100d@ / BR_MIS_PRED",
123        "PublicDescription": "Pop branch L3 topdown metric",
124        "BriefDescription": "Pop branch L3 topdown metric",
125        "MetricGroup": "TopDownL3",
126        "MetricName": "pop_branch"
127    },
128    {
129        "MetricExpr": "(BR_MIS_PRED - armv8_pmuv3_0@event\\=0x1010@ - armv8_pmuv3_0@event\\=0x1013@ - armv8_pmuv3_0@event\\=0x1016@ - armv8_pmuv3_0@event\\=0x100d@) / BR_MIS_PRED",
130        "PublicDescription": "Other branch L3 topdown metric",
131        "BriefDescription": "Other branch L3 topdown metric",
132        "MetricGroup": "TopDownL3",
133        "MetricName": "other_branch"
134    },
135    {
136        "MetricExpr": "armv8_pmuv3_0@event\\=0x2012@ / armv8_pmuv3_0@event\\=0x2013@",
137        "PublicDescription": "Nuke flush L3 topdown metric",
138        "BriefDescription": "Nuke flush L3 topdown metric",
139        "MetricGroup": "TopDownL3",
140        "MetricName": "nuke_flush"
141    },
142    {
143        "MetricExpr": "1 - nuke_flush",
144        "PublicDescription": "Other flush L3 topdown metric",
145        "BriefDescription": "Other flush L3 topdown metric",
146        "MetricGroup": "TopDownL3",
147        "MetricName": "other_flush"
148    },
149    {
150        "MetricExpr": "armv8_pmuv3_0@event\\=0x2010@ / CPU_CYCLES",
151        "PublicDescription": "Sync stall L3 topdown metric",
152        "BriefDescription": "Sync stall L3 topdown metric",
153        "MetricGroup": "TopDownL3",
154        "MetricName": "sync_stall"
155    },
156    {
157        "MetricExpr": "armv8_pmuv3_0@event\\=0x2004@ / CPU_CYCLES",
158        "PublicDescription": "Rob stall L3 topdown metric",
159        "BriefDescription": "Rob stall L3 topdown metric",
160        "MetricGroup": "TopDownL3",
161        "MetricName": "rob_stall"
162    },
163    {
164        "MetricExpr": "(armv8_pmuv3_0@event\\=0x2006@ + armv8_pmuv3_0@event\\=0x2007@ + armv8_pmuv3_0@event\\=0x2008@) / CPU_CYCLES",
165        "PublicDescription": "Ptag stall L3 topdown metric",
166        "BriefDescription": "Ptag stall L3 topdown metric",
167        "MetricGroup": "TopDownL3",
168        "MetricName": "ptag_stall"
169    },
170    {
171        "MetricExpr": "armv8_pmuv3_0@event\\=0x201e@ / CPU_CYCLES",
172        "PublicDescription": "SaveOpQ stall L3 topdown metric",
173        "BriefDescription": "SaveOpQ stall L3 topdown metric",
174        "MetricGroup": "TopDownL3",
175        "MetricName": "saveopq_stall"
176    },
177    {
178        "MetricExpr": "armv8_pmuv3_0@event\\=0x2005@ / CPU_CYCLES",
179        "PublicDescription": "PC buffer stall L3 topdown metric",
180        "BriefDescription": "PC buffer stall L3 topdown metric",
181        "MetricGroup": "TopDownL3",
182        "MetricName": "pc_buffer_stall"
183    },
184    {
185        "MetricExpr": "armv8_pmuv3_0@event\\=0x7002@ / CPU_CYCLES",
186        "PublicDescription": "Divider L3 topdown metric",
187        "BriefDescription": "Divider L3 topdown metric",
188        "MetricGroup": "TopDownL3",
189        "MetricName": "divider"
190    },
191    {
192        "MetricExpr": "armv8_pmuv3_0@event\\=0x7003@ / CPU_CYCLES",
193        "PublicDescription": "FSU stall L3 topdown metric",
194        "BriefDescription": "FSU stall L3 topdown metric",
195        "MetricGroup": "TopDownL3",
196        "MetricName": "fsu_stall"
197    },
198    {
199        "MetricExpr": "core_bound - divider - fsu_stall",
200        "PublicDescription": "EXE ports util L3 topdown metric",
201        "BriefDescription": "EXE ports util L3 topdown metric",
202        "MetricGroup": "TopDownL3",
203        "MetricName": "exe_ports_util"
204    },
205    {
206        "MetricExpr": "(MEM_STALL_ANYLOAD - MEM_STALL_L1MISS) / CPU_CYCLES",
207        "PublicDescription": "L1 bound L3 topdown metric",
208        "BriefDescription": "L1 bound L3 topdown metric",
209        "MetricGroup": "TopDownL3",
210        "MetricName": "l1_bound"
211    },
212    {
213        "MetricExpr": "(MEM_STALL_L1MISS - MEM_STALL_L2MISS) / CPU_CYCLES",
214        "PublicDescription": "L2 bound L3 topdown metric",
215        "BriefDescription": "L2 bound L3 topdown metric",
216        "MetricGroup": "TopDownL3",
217        "MetricName": "l2_bound"
218    },
219    {
220        "MetricExpr": "MEM_STALL_L2MISS / CPU_CYCLES",
221        "PublicDescription": "Mem bound L3 topdown metric",
222        "BriefDescription": "Mem bound L3 topdown metric",
223        "MetricGroup": "TopDownL3",
224        "MetricName": "mem_bound"
225    },
226    {
227        "MetricExpr": "armv8_pmuv3_0@event\\=0x7005@ / CPU_CYCLES",
228        "PublicDescription": "Store bound L3 topdown metric",
229        "BriefDescription": "Store bound L3 topdown metric",
230        "MetricGroup": "TopDownL3",
231        "MetricName": "store_bound"
232    }
233]
234