PAPI 7.1.0.0
Loading...
Searching...
No Matches
amd64_events_k8.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2006, 2007 Advanced Micro Devices, Inc.
3 * Contributed by Ray Bryant <raybry@mpdtxmail.amd.com>
4 * Contributed by Robert Richter <robert.richter@amd.com>
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to deal
8 * in the Software without restriction, including without limitation the rights
9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
10 * of the Software, and to permit persons to whom the Software is furnished to do so,
11 * subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in all
14 * copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
17 * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
18 * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
19 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
20 * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
21 * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22 *
23 * This file is part of libpfm, a performance monitoring support library for
24 * applications on Linux.
25 */
26
27/* History
28 *
29 * Feb 10 2006 -- Ray Bryant, raybry@mpdtxmail.amd.com
30 *
31 * Brought event table up-to-date with the 3.85 (October 2005) version of the
32 * "BIOS and Kernel Developer's Guide for the AMD Athlon[tm] 64 and
33 * AMD Opteron[tm] Processors," AMD Publication # 26094.
34 *
35 * Dec 12 2007 -- Robert Richter, robert.richter@amd.com
36 *
37 * Updated to: BIOS and Kernel Developer's Guide for AMD NPT Family
38 * 0Fh Processors, Publication # 32559, Revision: 3.08, Issue Date:
39 * July 2007
40 *
41 * Feb 26 2009 -- Robert Richter, robert.richter@amd.com
42 *
43 * Updates and fixes of some revision flags and descriptions according
44 * to these documents:
45 * BIOS and Kernel Developer's Guide, #26094, Revision: 3.30
46 * BIOS and Kernel Developer's Guide, #32559, Revision: 3.12
47 */
48
50/* 0 */{.pme_name = "DISPATCHED_FPU",
51 .pme_code = 0x00,
52 .pme_desc = "Dispatched FPU Operations",
53 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
54 .pme_numasks = 7,
55 .pme_umasks = {
56 { .pme_uname = "OPS_ADD",
57 .pme_udesc = "Add pipe ops",
58 .pme_ucode = 0x01,
59 },
60 { .pme_uname = "OPS_MULTIPLY",
61 .pme_udesc = "Multiply pipe ops",
62 .pme_ucode = 0x02,
63 },
64 { .pme_uname = "OPS_STORE",
65 .pme_udesc = "Store pipe ops",
66 .pme_ucode = 0x04,
67 },
68 { .pme_uname = "OPS_ADD_PIPE_LOAD_OPS",
69 .pme_udesc = "Add pipe load ops",
70 .pme_ucode = 0x08,
71 },
72 { .pme_uname = "OPS_MULTIPLY_PIPE_LOAD_OPS",
73 .pme_udesc = "Multiply pipe load ops",
74 .pme_ucode = 0x10,
75 },
76 { .pme_uname = "OPS_STORE_PIPE_LOAD_OPS",
77 .pme_udesc = "Store pipe load ops",
78 .pme_ucode = 0x20,
79 },
80 { .pme_uname = "ALL",
81 .pme_udesc = "All sub-events selected",
82 .pme_ucode = 0x3F,
83 },
84 },
85 },
86/* 1 */{.pme_name = "CYCLES_NO_FPU_OPS_RETIRED",
87 .pme_code = 0x01,
88 .pme_desc = "Cycles with no FPU Ops Retired",
89 },
90/* 2 */{.pme_name = "DISPATCHED_FPU_OPS_FAST_FLAG",
91 .pme_code = 0x02,
92 .pme_desc = "Dispatched Fast Flag FPU Operations",
93 },
94/* 3 */{.pme_name = "SEGMENT_REGISTER_LOADS",
95 .pme_code = 0x20,
96 .pme_desc = "Segment Register Loads",
97 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
98 .pme_numasks = 8,
99 .pme_umasks = {
100 { .pme_uname = "ES",
101 .pme_udesc = "ES",
102 .pme_ucode = 0x01,
103 },
104 { .pme_uname = "CS",
105 .pme_udesc = "CS",
106 .pme_ucode = 0x02,
107 },
108 { .pme_uname = "SS",
109 .pme_udesc = "SS",
110 .pme_ucode = 0x04,
111 },
112 { .pme_uname = "DS",
113 .pme_udesc = "DS",
114 .pme_ucode = 0x08,
115 },
116 { .pme_uname = "FS",
117 .pme_udesc = "FS",
118 .pme_ucode = 0x10,
119 },
120 { .pme_uname = "GS",
121 .pme_udesc = "GS",
122 .pme_ucode = 0x20,
123 },
124 { .pme_uname = "HS",
125 .pme_udesc = "HS",
126 .pme_ucode = 0x40,
127 },
128 { .pme_uname = "ALL",
129 .pme_udesc = "All segments",
130 .pme_ucode = 0x7F,
131 },
132 },
133 },
134/* 4 */{.pme_name = "PIPELINE_RESTART_DUE_TO_SELF_MODIFYING_CODE",
135 .pme_code = 0x21,
136 .pme_desc = "Pipeline restart due to self-modifying code",
137 },
138/* 5 */{.pme_name = "PIPELINE_RESTART_DUE_TO_PROBE_HIT",
139 .pme_code = 0x22,
140 .pme_desc = "Pipeline restart due to probe hit",
141 },
142/* 6 */{.pme_name = "LS_BUFFER_2_FULL_CYCLES",
143 .pme_code = 0x23,
144 .pme_desc = "LS Buffer 2 Full",
145 },
146/* 7 */{.pme_name = "LOCKED_OPS",
147 .pme_code = 0x24,
148 .pme_desc = "Locked Operations",
149 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
150 .pme_numasks = 4,
151 .pme_umasks = {
152 { .pme_uname = "EXECUTED",
153 .pme_udesc = "The number of locked instructions executed",
154 .pme_ucode = 0x01,
155 },
156 { .pme_uname = "CYCLES_SPECULATIVE_PHASE",
157 .pme_udesc = "The number of cycles spent in speculative phase",
158 .pme_ucode = 0x02,
159 },
160 { .pme_uname = "CYCLES_NON_SPECULATIVE_PHASE",
161 .pme_udesc = "The number of cycles spent in non-speculative phase (including cache miss penalty)",
162 .pme_ucode = 0x04,
163 },
164 { .pme_uname = "ALL",
165 .pme_udesc = "All sub-events selected",
166 .pme_ucode = 0x07,
167 },
168 },
169 },
170/* 8 */{.pme_name = "MEMORY_REQUESTS",
171 .pme_code = 0x65,
172 .pme_desc = "Memory Requests by Type",
173 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
174 .pme_numasks = 4,
175 .pme_umasks = {
176 { .pme_uname = "NON_CACHEABLE",
177 .pme_udesc = "Requests to non-cacheable (UC) memory",
178 .pme_ucode = 0x01,
179 },
180 { .pme_uname = "WRITE_COMBINING",
181 .pme_udesc = "Requests to write-combining (WC) memory or WC buffer flushes to WB memory",
182 .pme_ucode = 0x02,
183 },
184 { .pme_uname = "STREAMING_STORE",
185 .pme_udesc = "Streaming store (SS) requests",
186 .pme_ucode = 0x80,
187 },
188 { .pme_uname = "ALL",
189 .pme_udesc = "All sub-events selected",
190 .pme_ucode = 0x83,
191 },
192 },
193 },
194/* 9 */{.pme_name = "DATA_CACHE_ACCESSES",
195 .pme_code = 0x40,
196 .pme_desc = "Data Cache Accesses",
197 },
198/* 10 */{.pme_name = "DATA_CACHE_MISSES",
199 .pme_code = 0x41,
200 .pme_desc = "Data Cache Misses",
201 },
202/* 11 */{.pme_name = "DATA_CACHE_REFILLS",
203 .pme_code = 0x42,
204 .pme_desc = "Data Cache Refills from L2 or System",
205 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
206 .pme_numasks = 6,
207 .pme_umasks = {
208 { .pme_uname = "SYSTEM",
209 .pme_udesc = "Refill from System",
210 .pme_ucode = 0x01,
211 },
212 { .pme_uname = "L2_SHARED",
213 .pme_udesc = "Shared-state line from L2",
214 .pme_ucode = 0x02,
215 },
216 { .pme_uname = "L2_EXCLUSIVE",
217 .pme_udesc = "Exclusive-state line from L2",
218 .pme_ucode = 0x04,
219 },
220 { .pme_uname = "L2_OWNED",
221 .pme_udesc = "Owned-state line from L2",
222 .pme_ucode = 0x08,
223 },
224 { .pme_uname = "L2_MODIFIED",
225 .pme_udesc = "Modified-state line from L2",
226 .pme_ucode = 0x10,
227 },
228 { .pme_uname = "ALL",
229 .pme_udesc = "Shared, Exclusive, Owned, Modified State Refills",
230 .pme_ucode = 0x1F,
231 },
232 },
233 },
234/* 12 */{.pme_name = "DATA_CACHE_REFILLS_FROM_SYSTEM",
235 .pme_code = 0x43,
236 .pme_desc = "Data Cache Refills from System",
237 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
238 .pme_numasks = 6,
239 .pme_umasks = {
240 { .pme_uname = "INVALID",
241 .pme_udesc = "Invalid",
242 .pme_ucode = 0x01,
243 },
244 { .pme_uname = "SHARED",
245 .pme_udesc = "Shared",
246 .pme_ucode = 0x02,
247 },
248 { .pme_uname = "EXCLUSIVE",
249 .pme_udesc = "Exclusive",
250 .pme_ucode = 0x04,
251 },
252 { .pme_uname = "OWNED",
253 .pme_udesc = "Owned",
254 .pme_ucode = 0x08,
255 },
256 { .pme_uname = "MODIFIED",
257 .pme_udesc = "Modified",
258 .pme_ucode = 0x10,
259 },
260 { .pme_uname = "ALL",
261 .pme_udesc = "Invalid, Shared, Exclusive, Owned, Modified",
262 .pme_ucode = 0x1F,
263 },
264 },
265 },
266/* 13 */{.pme_name = "DATA_CACHE_LINES_EVICTED",
267 .pme_code = 0x44,
268 .pme_desc = "Data Cache Lines Evicted",
269 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
270 .pme_numasks = 6,
271 .pme_umasks = {
272 { .pme_uname = "INVALID",
273 .pme_udesc = "Invalid",
274 .pme_ucode = 0x01,
275 },
276 { .pme_uname = "SHARED",
277 .pme_udesc = "Shared",
278 .pme_ucode = 0x02,
279 },
280 { .pme_uname = "EXCLUSIVE",
281 .pme_udesc = "Exclusive",
282 .pme_ucode = 0x04,
283 },
284 { .pme_uname = "OWNED",
285 .pme_udesc = "Owned",
286 .pme_ucode = 0x08,
287 },
288 { .pme_uname = "MODIFIED",
289 .pme_udesc = "Modified",
290 .pme_ucode = 0x10,
291 },
292 { .pme_uname = "ALL",
293 .pme_udesc = "Invalid, Shared, Exclusive, Owned, Modified",
294 .pme_ucode = 0x1F,
295 },
296 },
297 },
298/* 14 */{.pme_name = "L1_DTLB_MISS_AND_L2_DTLB_HIT",
299 .pme_code = 0x45,
300 .pme_desc = "L1 DTLB Miss and L2 DTLB Hit",
301 },
302/* 15 */{.pme_name = "L1_DTLB_AND_L2_DTLB_MISS",
303 .pme_code = 0x46,
304 .pme_desc = "L1 DTLB and L2 DTLB Miss",
305 },
306/* 16 */{.pme_name = "MISALIGNED_ACCESSES",
307 .pme_code = 0x47,
308 .pme_desc = "Misaligned Accesses",
309 },
310/* 17 */{.pme_name = "MICROARCHITECTURAL_LATE_CANCEL_OF_AN_ACCESS",
311 .pme_code = 0x48,
312 .pme_desc = "Microarchitectural Late Cancel of an Access",
313 },
314/* 18 */{.pme_name = "MICROARCHITECTURAL_EARLY_CANCEL_OF_AN_ACCESS",
315 .pme_code = 0x49,
316 .pme_desc = "Microarchitectural Early Cancel of an Access",
317 },
318/* 19 */{.pme_name = "SCRUBBER_SINGLE_BIT_ECC_ERRORS",
319 .pme_code = 0x4A,
320 .pme_desc = "Single-bit ECC Errors Recorded by Scrubber",
321 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
322 .pme_numasks = 3,
323 .pme_umasks = {
324 { .pme_uname = "SCRUBBER_ERROR",
325 .pme_udesc = "Scrubber error",
326 .pme_ucode = 0x01,
327 },
328 { .pme_uname = "PIGGYBACK_ERROR",
329 .pme_udesc = "Piggyback scrubber errors",
330 .pme_ucode = 0x02,
331 },
332 { .pme_uname = "ALL",
333 .pme_udesc = "All sub-events selected",
334 .pme_ucode = 0x03,
335 },
336 },
337 },
338/* 20 */{.pme_name = "PREFETCH_INSTRUCTIONS_DISPATCHED",
339 .pme_code = 0x4B,
340 .pme_desc = "Prefetch Instructions Dispatched",
341 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
342 .pme_numasks = 4,
343 .pme_umasks = {
344 { .pme_uname = "LOAD",
345 .pme_udesc = "Load (Prefetch, PrefetchT0/T1/T2)",
346 .pme_ucode = 0x01,
347 },
348 { .pme_uname = "STORE",
349 .pme_udesc = "Store (PrefetchW)",
350 .pme_ucode = 0x02,
351 },
352 { .pme_uname = "NTA",
353 .pme_udesc = "NTA (PrefetchNTA)",
354 .pme_ucode = 0x04,
355 },
356 { .pme_uname = "ALL",
357 .pme_udesc = "All sub-events selected",
358 .pme_ucode = 0x07,
359 },
360 },
361 },
362/* 21 */{.pme_name = "DCACHE_MISSES_BY_LOCKED_INSTRUCTIONS",
363 .pme_code = 0x4C,
364 .pme_desc = "DCACHE Misses by Locked Instructions",
365 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
366 .pme_numasks = 2,
367 .pme_umasks = {
368 { .pme_uname = "DATA_CACHE_MISSES_BY_LOCKED_INSTRUCTIONS",
369 .pme_udesc = "Data cache misses by locked instructions",
370 .pme_ucode = 0x02,
371 },
372 { .pme_uname = "ALL",
373 .pme_udesc = "All sub-events selected",
374 .pme_ucode = 0x02,
375 },
376 },
377 },
378/* 22 */{.pme_name = "DATA_PREFETCHES",
379 .pme_code = 0x67,
380 .pme_desc = "Data Prefetcher",
381 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
382 .pme_numasks = 3,
383 .pme_umasks = {
384 { .pme_uname = "CANCELLED",
385 .pme_udesc = "Cancelled prefetches",
386 .pme_ucode = 0x01,
387 },
388 { .pme_uname = "ATTEMPTED",
389 .pme_udesc = "Prefetch attempts",
390 .pme_ucode = 0x02,
391 },
392 { .pme_uname = "ALL",
393 .pme_udesc = "All sub-events selected",
394 .pme_ucode = 0x03,
395 },
396 },
397 },
398/* 23 */{.pme_name = "SYSTEM_READ_RESPONSES",
399 .pme_code = 0x6C,
400 .pme_desc = "System Read Responses by Coherency State",
401 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
402 .pme_numasks = 4,
403 .pme_umasks = {
404 { .pme_uname = "EXCLUSIVE",
405 .pme_udesc = "Exclusive",
406 .pme_ucode = 0x01,
407 },
408 { .pme_uname = "MODIFIED",
409 .pme_udesc = "Modified",
410 .pme_ucode = 0x02,
411 },
412 { .pme_uname = "SHARED",
413 .pme_udesc = "Shared",
414 .pme_ucode = 0x04,
415 },
416 { .pme_uname = "ALL",
417 .pme_udesc = "Exclusive, Modified, Shared",
418 .pme_ucode = 0x07,
419 },
420 },
421 },
422/* 24 */{.pme_name = "QUADWORDS_WRITTEN_TO_SYSTEM",
423 .pme_code = 0x6D,
424 .pme_desc = "Quadwords Written to System",
425 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
426 .pme_numasks = 2,
427 .pme_umasks = {
428 { .pme_uname = "QUADWORD_WRITE_TRANSFER",
429 .pme_udesc = "Quadword write transfer",
430 .pme_ucode = 0x01,
431 },
432 { .pme_uname = "ALL",
433 .pme_udesc = "All sub-events selected",
434 .pme_ucode = 0x01,
435 },
436 },
437 },
438/* 25 */{.pme_name = "REQUESTS_TO_L2",
439 .pme_code = 0x7D,
440 .pme_desc = "Requests to L2 Cache",
441 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
442 .pme_numasks = 6,
443 .pme_umasks = {
444 { .pme_uname = "INSTRUCTIONS",
445 .pme_udesc = "IC fill",
446 .pme_ucode = 0x01,
447 },
448 { .pme_uname = "DATA",
449 .pme_udesc = "DC fill",
450 .pme_ucode = 0x02,
451 },
452 { .pme_uname = "TLB_WALK",
453 .pme_udesc = "TLB fill (page table walks)",
454 .pme_ucode = 0x04,
455 },
456 { .pme_uname = "SNOOP",
457 .pme_udesc = "Tag snoop request",
458 .pme_ucode = 0x08,
459 },
460 { .pme_uname = "CANCELLED",
461 .pme_udesc = "Cancelled request",
462 .pme_ucode = 0x10,
463 },
464 { .pme_uname = "ALL",
465 .pme_udesc = "All non-cancelled requests",
466 .pme_ucode = 0x1F,
467 },
468 },
469 },
470/* 26 */{.pme_name = "L2_CACHE_MISS",
471 .pme_code = 0x7E,
472 .pme_desc = "L2 Cache Misses",
473 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
474 .pme_numasks = 4,
475 .pme_umasks = {
476 { .pme_uname = "INSTRUCTIONS",
477 .pme_udesc = "IC fill",
478 .pme_ucode = 0x01,
479 },
480 { .pme_uname = "DATA",
481 .pme_udesc = "DC fill (includes possible replays, whereas event 41h does not)",
482 .pme_ucode = 0x02,
483 },
484 { .pme_uname = "TLB_WALK",
485 .pme_udesc = "TLB page table walk",
486 .pme_ucode = 0x04,
487 },
488 { .pme_uname = "ALL",
489 .pme_udesc = "Instructions, Data, TLB walk",
490 .pme_ucode = 0x07,
491 },
492 },
493 },
494/* 27 */{.pme_name = "L2_FILL_WRITEBACK",
495 .pme_code = 0x7F,
496 .pme_desc = "L2 Fill/Writeback",
497 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
498 .pme_numasks = 4,
499 .pme_umasks = {
500 { .pme_uname = "L2_FILLS",
501 .pme_udesc = "L2 fills (victims from L1 caches, TLB page table walks and data prefetches)",
502 .pme_ucode = 0x01,
503 },
504 { .pme_uname = "ALL",
505 .pme_udesc = "All sub-events selected",
506 .pme_ucode = 0x01,
507 .pme_uflags = PFMLIB_AMD64_TILL_K8_REV_E,
508 },
509 { .pme_uname = "L2_WRITEBACKS",
510 .pme_udesc = "L2 Writebacks to system.",
511 .pme_ucode = 0x02,
512 .pme_uflags = PFMLIB_AMD64_K8_REV_F,
513 },
514 { .pme_uname = "ALL",
515 .pme_udesc = "All sub-events selected",
516 .pme_ucode = 0x03,
517 .pme_uflags = PFMLIB_AMD64_K8_REV_F,
518 },
519 },
520 },
521/* 28 */{.pme_name = "INSTRUCTION_CACHE_FETCHES",
522 .pme_code = 0x80,
523 .pme_desc = "Instruction Cache Fetches",
524 },
525/* 29 */{.pme_name = "INSTRUCTION_CACHE_MISSES",
526 .pme_code = 0x81,
527 .pme_desc = "Instruction Cache Misses",
528 },
529/* 30 */{.pme_name = "INSTRUCTION_CACHE_REFILLS_FROM_L2",
530 .pme_code = 0x82,
531 .pme_desc = "Instruction Cache Refills from L2",
532 },
533/* 31 */{.pme_name = "INSTRUCTION_CACHE_REFILLS_FROM_SYSTEM",
534 .pme_code = 0x83,
535 .pme_desc = "Instruction Cache Refills from System",
536 },
537/* 32 */{.pme_name = "L1_ITLB_MISS_AND_L2_ITLB_HIT",
538 .pme_code = 0x84,
539 .pme_desc = "L1 ITLB Miss and L2 ITLB Hit",
540 },
541/* 33 */{.pme_name = "L1_ITLB_MISS_AND_L2_ITLB_MISS",
542 .pme_code = 0x85,
543 .pme_desc = "L1 ITLB Miss and L2 ITLB Miss",
544 },
545/* 34 */{.pme_name = "PIPELINE_RESTART_DUE_TO_INSTRUCTION_STREAM_PROBE",
546 .pme_code = 0x86,
547 .pme_desc = "Pipeline Restart Due to Instruction Stream Probe",
548 },
549/* 35 */{.pme_name = "INSTRUCTION_FETCH_STALL",
550 .pme_code = 0x87,
551 .pme_desc = "Instruction Fetch Stall",
552 },
553/* 36 */{.pme_name = "RETURN_STACK_HITS",
554 .pme_code = 0x88,
555 .pme_desc = "Return Stack Hits",
556 },
557/* 37 */{.pme_name = "RETURN_STACK_OVERFLOWS",
558 .pme_code = 0x89,
559 .pme_desc = "Return Stack Overflows",
560 },
561/* 38 */{.pme_name = "RETIRED_CLFLUSH_INSTRUCTIONS",
562 .pme_code = 0x26,
563 .pme_desc = "Retired CLFLUSH Instructions",
564 },
565/* 39 */{.pme_name = "RETIRED_CPUID_INSTRUCTIONS",
566 .pme_code = 0x27,
567 .pme_desc = "Retired CPUID Instructions",
568 },
569/* 40 */{.pme_name = "CPU_CLK_UNHALTED",
570 .pme_code = 0x76,
571 .pme_desc = "CPU Clocks not Halted",
572 },
573/* 41 */{.pme_name = "RETIRED_INSTRUCTIONS",
574 .pme_code = 0xC0,
575 .pme_desc = "Retired Instructions",
576 },
577/* 42 */{.pme_name = "RETIRED_UOPS",
578 .pme_code = 0xC1,
579 .pme_desc = "Retired uops",
580 },
581/* 43 */{.pme_name = "RETIRED_BRANCH_INSTRUCTIONS",
582 .pme_code = 0xC2,
583 .pme_desc = "Retired Branch Instructions",
584 },
585/* 44 */{.pme_name = "RETIRED_MISPREDICTED_BRANCH_INSTRUCTIONS",
586 .pme_code = 0xC3,
587 .pme_desc = "Retired Mispredicted Branch Instructions",
588 },
589/* 45 */{.pme_name = "RETIRED_TAKEN_BRANCH_INSTRUCTIONS",
590 .pme_code = 0xC4,
591 .pme_desc = "Retired Taken Branch Instructions",
592 },
593/* 46 */{.pme_name = "RETIRED_TAKEN_BRANCH_INSTRUCTIONS_MISPREDICTED",
594 .pme_code = 0xC5,
595 .pme_desc = "Retired Taken Branch Instructions Mispredicted",
596 },
597/* 47 */{.pme_name = "RETIRED_FAR_CONTROL_TRANSFERS",
598 .pme_code = 0xC6,
599 .pme_desc = "Retired Far Control Transfers",
600 },
601/* 48 */{.pme_name = "RETIRED_BRANCH_RESYNCS",
602 .pme_code = 0xC7,
603 .pme_desc = "Retired Branch Resyncs",
604 },
605/* 49 */{.pme_name = "RETIRED_NEAR_RETURNS",
606 .pme_code = 0xC8,
607 .pme_desc = "Retired Near Returns",
608 },
609/* 50 */{.pme_name = "RETIRED_NEAR_RETURNS_MISPREDICTED",
610 .pme_code = 0xC9,
611 .pme_desc = "Retired Near Returns Mispredicted",
612 },
613/* 51 */{.pme_name = "RETIRED_INDIRECT_BRANCHES_MISPREDICTED",
614 .pme_code = 0xCA,
615 .pme_desc = "Retired Indirect Branches Mispredicted",
616 },
617/* 52 */{.pme_name = "RETIRED_MMX_AND_FP_INSTRUCTIONS",
618 .pme_code = 0xCB,
619 .pme_desc = "Retired MMX/FP Instructions",
620 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
621 .pme_numasks = 5,
622 .pme_umasks = {
623 { .pme_uname = "X87",
624 .pme_udesc = "x87 instructions",
625 .pme_ucode = 0x01,
626 },
627 { .pme_uname = "MMX_AND_3DNOW",
628 .pme_udesc = "MMX and 3DNow! instructions",
629 .pme_ucode = 0x02,
630 },
631 { .pme_uname = "PACKED_SSE_AND_SSE2",
632 .pme_udesc = "Packed SSE and SSE2 instructions",
633 .pme_ucode = 0x04,
634 },
635 { .pme_uname = "SCALAR_SSE_AND_SSE2",
636 .pme_udesc = "Scalar SSE and SSE2 instructions",
637 .pme_ucode = 0x08,
638 },
639 { .pme_uname = "ALL",
640 .pme_udesc = "X87, MMX(TM), 3DNow!(TM), Scalar and Packed SSE and SSE2 instructions",
641 .pme_ucode = 0x0F,
642 },
643 },
644 },
645/* 53 */{.pme_name = "RETIRED_FASTPATH_DOUBLE_OP_INSTRUCTIONS",
646 .pme_code = 0xCC,
647 .pme_desc = "Retired Fastpath Double Op Instructions",
648 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
649 .pme_numasks = 4,
650 .pme_umasks = {
651 { .pme_uname = "POSITION_0",
652 .pme_udesc = "With low op in position 0",
653 .pme_ucode = 0x01,
654 },
655 { .pme_uname = "POSITION_1",
656 .pme_udesc = "With low op in position 1",
657 .pme_ucode = 0x02,
658 },
659 { .pme_uname = "POSITION_2",
660 .pme_udesc = "With low op in position 2",
661 .pme_ucode = 0x04,
662 },
663 { .pme_uname = "ALL",
664 .pme_udesc = "With low op in position 0, 1, or 2",
665 .pme_ucode = 0x07,
666 },
667 },
668 },
669/* 54 */{.pme_name = "INTERRUPTS_MASKED_CYCLES",
670 .pme_code = 0xCD,
671 .pme_desc = "Interrupts-Masked Cycles",
672 },
673/* 55 */{.pme_name = "INTERRUPTS_MASKED_CYCLES_WITH_INTERRUPT_PENDING",
674 .pme_code = 0xCE,
675 .pme_desc = "Interrupts-Masked Cycles with Interrupt Pending",
676 },
677/* 56 */{.pme_name = "INTERRUPTS_TAKEN",
678 .pme_code = 0xCF,
679 .pme_desc = "Interrupts Taken",
680 },
681/* 57 */{.pme_name = "DECODER_EMPTY",
682 .pme_code = 0xD0,
683 .pme_desc = "Decoder Empty",
684 },
685/* 58 */{.pme_name = "DISPATCH_STALLS",
686 .pme_code = 0xD1,
687 .pme_desc = "Dispatch Stalls",
688 },
689/* 59 */{.pme_name = "DISPATCH_STALL_FOR_BRANCH_ABORT",
690 .pme_code = 0xD2,
691 .pme_desc = "Dispatch Stall for Branch Abort to Retire",
692 },
693/* 60 */{.pme_name = "DISPATCH_STALL_FOR_SERIALIZATION",
694 .pme_code = 0xD3,
695 .pme_desc = "Dispatch Stall for Serialization",
696 },
697/* 61 */{.pme_name = "DISPATCH_STALL_FOR_SEGMENT_LOAD",
698 .pme_code = 0xD4,
699 .pme_desc = "Dispatch Stall for Segment Load",
700 },
701/* 62 */{.pme_name = "DISPATCH_STALL_FOR_REORDER_BUFFER_FULL",
702 .pme_code = 0xD5,
703 .pme_desc = "Dispatch Stall for Reorder Buffer Full",
704 },
705/* 63 */{.pme_name = "DISPATCH_STALL_FOR_RESERVATION_STATION_FULL",
706 .pme_code = 0xD6,
707 .pme_desc = "Dispatch Stall for Reservation Station Full",
708 },
709/* 64 */{.pme_name = "DISPATCH_STALL_FOR_FPU_FULL",
710 .pme_code = 0xD7,
711 .pme_desc = "Dispatch Stall for FPU Full",
712 },
713/* 65 */{.pme_name = "DISPATCH_STALL_FOR_LS_FULL",
714 .pme_code = 0xD8,
715 .pme_desc = "Dispatch Stall for LS Full",
716 },
717/* 66 */{.pme_name = "DISPATCH_STALL_WAITING_FOR_ALL_QUIET",
718 .pme_code = 0xD9,
719 .pme_desc = "Dispatch Stall Waiting for All Quiet",
720 },
721/* 67 */{.pme_name = "DISPATCH_STALL_FOR_FAR_TRANSFER_OR_RSYNC",
722 .pme_code = 0xDA,
723 .pme_desc = "Dispatch Stall for Far Transfer or Resync to Retire",
724 },
725/* 68 */{.pme_name = "FPU_EXCEPTIONS",
726 .pme_code = 0xDB,
727 .pme_desc = "FPU Exceptions",
728 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
729 .pme_numasks = 5,
730 .pme_umasks = {
731 { .pme_uname = "X87_RECLASS_MICROFAULTS",
732 .pme_udesc = "x87 reclass microfaults",
733 .pme_ucode = 0x01,
734 },
735 { .pme_uname = "SSE_RETYPE_MICROFAULTS",
736 .pme_udesc = "SSE retype microfaults",
737 .pme_ucode = 0x02,
738 },
739 { .pme_uname = "SSE_RECLASS_MICROFAULTS",
740 .pme_udesc = "SSE reclass microfaults",
741 .pme_ucode = 0x04,
742 },
743 { .pme_uname = "SSE_AND_X87_MICROTRAPS",
744 .pme_udesc = "SSE and x87 microtraps",
745 .pme_ucode = 0x08,
746 },
747 { .pme_uname = "ALL",
748 .pme_udesc = "All sub-events selected",
749 .pme_ucode = 0x0F,
750 },
751 },
752 },
753/* 69 */{.pme_name = "DR0_BREAKPOINT_MATCHES",
754 .pme_code = 0xDC,
755 .pme_desc = "DR0 Breakpoint Matches",
756 },
757/* 70 */{.pme_name = "DR1_BREAKPOINT_MATCHES",
758 .pme_code = 0xDD,
759 .pme_desc = "DR1 Breakpoint Matches",
760 },
761/* 71 */{.pme_name = "DR2_BREAKPOINT_MATCHES",
762 .pme_code = 0xDE,
763 .pme_desc = "DR2 Breakpoint Matches",
764 },
765/* 72 */{.pme_name = "DR3_BREAKPOINT_MATCHES",
766 .pme_code = 0xDF,
767 .pme_desc = "DR3 Breakpoint Matches",
768 },
769/* 73 */{.pme_name = "DRAM_ACCESSES_PAGE",
770 .pme_code = 0xE0,
771 .pme_desc = "DRAM Accesses",
772 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
773 .pme_numasks = 4,
774 .pme_umasks = {
775 { .pme_uname = "HIT",
776 .pme_udesc = "Page hit",
777 .pme_ucode = 0x01,
778 },
779 { .pme_uname = "MISS",
780 .pme_udesc = "Page Miss",
781 .pme_ucode = 0x02,
782 },
783 { .pme_uname = "CONFLICT",
784 .pme_udesc = "Page Conflict",
785 .pme_ucode = 0x04,
786 },
787 { .pme_uname = "ALL",
788 .pme_udesc = "Page Hit, Miss, or Conflict",
789 .pme_ucode = 0x07,
790 },
791 },
792 },
793/* 74 */{.pme_name = "MEMORY_CONTROLLER_PAGE_TABLE_OVERFLOWS",
794 .pme_code = 0xE1,
795 .pme_desc = "Memory Controller Page Table Overflows",
796 },
797/* 75 */{.pme_name = "MEMORY_CONTROLLER_TURNAROUNDS",
798 .pme_code = 0xE3,
799 .pme_desc = "Memory Controller Turnarounds",
800 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
801 .pme_numasks = 4,
802 .pme_umasks = {
803 { .pme_uname = "CHIP_SELECT",
804 .pme_udesc = "DIMM (chip select) turnaround",
805 .pme_ucode = 0x01,
806 },
807 { .pme_uname = "READ_TO_WRITE",
808 .pme_udesc = "Read to write turnaround",
809 .pme_ucode = 0x02,
810 },
811 { .pme_uname = "WRITE_TO_READ",
812 .pme_udesc = "Write to read turnaround",
813 .pme_ucode = 0x04,
814 },
815 { .pme_uname = "ALL",
816 .pme_udesc = "All Memory Controller Turnarounds",
817 .pme_ucode = 0x07,
818 },
819 },
820 },
821/* 76 */{.pme_name = "MEMORY_CONTROLLER_BYPASS",
822 .pme_code = 0xE4,
823 .pme_desc = "Memory Controller Bypass Counter Saturation",
824 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
825 .pme_numasks = 5,
826 .pme_umasks = {
827 { .pme_uname = "HIGH_PRIORITY",
828 .pme_udesc = "Memory controller high priority bypass",
829 .pme_ucode = 0x01,
830 },
831 { .pme_uname = "LOW_PRIORITY",
832 .pme_udesc = "Memory controller low priority bypass",
833 .pme_ucode = 0x02,
834 },
835 { .pme_uname = "DRAM_INTERFACE",
836 .pme_udesc = "DRAM controller interface bypass",
837 .pme_ucode = 0x04,
838 },
839 { .pme_uname = "DRAM_QUEUE",
840 .pme_udesc = "DRAM controller queue bypass",
841 .pme_ucode = 0x08,
842 },
843 { .pme_uname = "ALL",
844 .pme_udesc = "All sub-events selected",
845 .pme_ucode = 0x0F,
846 },
847 },
848 },
849/* 77 */{.pme_name = "SIZED_BLOCKS",
850 .pme_code = 0xE5,
851 .pme_desc = "Sized Blocks",
853 .pme_numasks = 5,
854 .pme_umasks = {
855 { .pme_uname = "32_BYTE_WRITES",
856 .pme_udesc = "32-byte Sized Writes",
857 .pme_ucode = 0x04,
858 },
859 { .pme_uname = "64_BYTE_WRITES",
860 .pme_udesc = "64-byte Sized Writes",
861 .pme_ucode = 0x08,
862 },
863 { .pme_uname = "32_BYTE_READS",
864 .pme_udesc = "32-byte Sized Reads",
865 .pme_ucode = 0x10,
866 },
867 { .pme_uname = "64_BYTE_READS",
868 .pme_udesc = "64-byte Sized Reads",
869 .pme_ucode = 0x20,
870 },
871 { .pme_uname = "ALL",
872 .pme_udesc = "All sub-events selected",
873 .pme_ucode = 0x3C,
874 },
875 },
876 },
877/* 78 */{.pme_name = "THERMAL_STATUS_AND_ECC_ERRORS",
878 .pme_code = 0xE8,
879 .pme_desc = "Thermal Status and ECC Errors",
881 .pme_numasks = 7,
882 .pme_umasks = {
883 { .pme_uname = "CLKS_CPU_ACTIVE",
884 .pme_udesc = "Number of clocks CPU is active when HTC is active",
885 .pme_ucode = 0x01,
886 .pme_uflags = PFMLIB_AMD64_K8_REV_F,
887 },
888 { .pme_uname = "CLKS_CPU_INACTIVE",
889 .pme_udesc = "Number of clocks CPU clock is inactive when HTC is active",
890 .pme_ucode = 0x02,
891 .pme_uflags = PFMLIB_AMD64_K8_REV_F,
892 },
893 { .pme_uname = "CLKS_DIE_TEMP_TOO_HIGH",
894 .pme_udesc = "Number of clocks when die temperature is higher than the software high temperature threshold",
895 .pme_ucode = 0x04,
896 .pme_uflags = PFMLIB_AMD64_K8_REV_F,
897 },
898 { .pme_uname = "CLKS_TEMP_THRESHOLD_EXCEEDED",
899 .pme_udesc = "Number of clocks when high temperature threshold was exceeded",
900 .pme_ucode = 0x08,
901 .pme_uflags = PFMLIB_AMD64_K8_REV_F,
902 },
903 { .pme_uname = "DRAM_ECC_ERRORS",
904 .pme_udesc = "Number of correctable and Uncorrectable DRAM ECC errors",
905 .pme_ucode = 0x80,
906 },
907 { .pme_uname = "ALL",
908 .pme_udesc = "All sub-events selected",
909 .pme_ucode = 0x80,
910 .pme_uflags = PFMLIB_AMD64_TILL_K8_REV_E,
911 },
912 { .pme_uname = "ALL",
913 .pme_udesc = "All sub-events selected",
914 .pme_ucode = 0x8F,
915 .pme_uflags = PFMLIB_AMD64_K8_REV_F,
916 },
917 },
918 },
919/* 79 */{.pme_name = "CPU_IO_REQUESTS_TO_MEMORY_IO",
920 .pme_code = 0xE9,
921 .pme_desc = "CPU/IO Requests to Memory/IO",
923 .pme_numasks = 9,
924 .pme_umasks = {
925 { .pme_uname = "I_O_TO_I_O",
926 .pme_udesc = "I/O to I/O",
927 .pme_ucode = 0x01,
928 },
929 { .pme_uname = "I_O_TO_MEM",
930 .pme_udesc = "I/O to Mem",
931 .pme_ucode = 0x02,
932 },
933 { .pme_uname = "CPU_TO_I_O",
934 .pme_udesc = "CPU to I/O",
935 .pme_ucode = 0x04,
936 },
937 { .pme_uname = "CPU_TO_MEM",
938 .pme_udesc = "CPU to Mem",
939 .pme_ucode = 0x08,
940 },
941 { .pme_uname = "TO_REMOTE_NODE",
942 .pme_udesc = "To remote node",
943 .pme_ucode = 0x10,
944 },
945 { .pme_uname = "TO_LOCAL_NODE",
946 .pme_udesc = "To local node",
947 .pme_ucode = 0x20,
948 },
949 { .pme_uname = "FROM_REMOTE_NODE",
950 .pme_udesc = "From remote node",
951 .pme_ucode = 0x40,
952 },
953 { .pme_uname = "FROM_LOCAL_NODE",
954 .pme_udesc = "From local node",
955 .pme_ucode = 0x80,
956 },
957 { .pme_uname = "ALL",
958 .pme_udesc = "All sub-events selected",
959 .pme_ucode = 0xFF,
960 },
961 },
962 },
963/* 80 */{.pme_name = "CACHE_BLOCK",
964 .pme_code = 0xEA,
965 .pme_desc = "Cache Block Commands",
967 .pme_numasks = 6,
968 .pme_umasks = {
969 { .pme_uname = "VICTIM_WRITEBACK",
970 .pme_udesc = "Victim Block (Writeback)",
971 .pme_ucode = 0x01,
972 },
973 { .pme_uname = "DCACHE_LOAD_MISS",
974 .pme_udesc = "Read Block (Dcache load miss refill)",
975 .pme_ucode = 0x04,
976 },
977 { .pme_uname = "SHARED_ICACHE_REFILL",
978 .pme_udesc = "Read Block Shared (Icache refill)",
979 .pme_ucode = 0x08,
980 },
981 { .pme_uname = "READ_BLOCK_MODIFIED",
982 .pme_udesc = "Read Block Modified (Dcache store miss refill)",
983 .pme_ucode = 0x10,
984 },
985 { .pme_uname = "READ_TO_DIRTY",
986 .pme_udesc = "Change to Dirty (first store to clean block already in cache)",
987 .pme_ucode = 0x20,
988 },
989 { .pme_uname = "ALL",
990 .pme_udesc = "All sub-events selected",
991 .pme_ucode = 0x3D,
992 },
993 },
994 },
995/* 81 */{.pme_name = "SIZED_COMMANDS",
996 .pme_code = 0xEB,
997 .pme_desc = "Sized Commands",
998 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
999 .pme_numasks = 8,
1000 .pme_umasks = {
1001 { .pme_uname = "NON_POSTED_WRITE_BYTE",
1002 .pme_udesc = "NonPosted SzWr Byte (1-32 bytes) Legacy or mapped I/O, typically 1-4 bytes",
1003 .pme_ucode = 0x01,
1004 },
1005 { .pme_uname = "NON_POSTED_WRITE_DWORD",
1006 .pme_udesc = "NonPosted SzWr Dword (1-16 dwords) Legacy or mapped I/O, typically 1 dword",
1007 .pme_ucode = 0x02,
1008 },
1009 { .pme_uname = "POSTED_WRITE_BYTE",
1010 .pme_udesc = "Posted SzWr Byte (1-32 bytes) Sub-cache-line DMA writes, size varies; also flushes of partially-filled Write Combining buffer",
1011 .pme_ucode = 0x04,
1012 },
1013 { .pme_uname = "POSTED_WRITE_DWORD",
1014 .pme_udesc = "Posted SzWr Dword (1-16 dwords) Block-oriented DMA writes, often cache-line sized; also processor Write Combining buffer flushes",
1015 .pme_ucode = 0x08,
1016 },
1017 { .pme_uname = "READ_BYTE_4_BYTES",
1018 .pme_udesc = "SzRd Byte (4 bytes) Legacy or mapped I/O",
1019 .pme_ucode = 0x10,
1020 },
1021 { .pme_uname = "READ_DWORD_1_16_DWORDS",
1022 .pme_udesc = "SzRd Dword (1-16 dwords) Block-oriented DMA reads, typically cache-line size",
1023 .pme_ucode = 0x20,
1024 },
1025 { .pme_uname = "READ_MODIFY_WRITE",
1026 .pme_udesc = "RdModWr",
1027 .pme_ucode = 0x40,
1028 },
1029 { .pme_uname = "ALL",
1030 .pme_udesc = "All sub-events selected",
1031 .pme_ucode = 0x7F,
1032 },
1033 },
1034 },
1035/* 82 */{.pme_name = "PROBE",
1036 .pme_code = 0xEC,
1037 .pme_desc = "Probe Responses and Upstream Requests",
1038 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
1039 .pme_numasks = 9,
1040 .pme_umasks = {
1041 { .pme_uname = "MISS",
1042 .pme_udesc = "Probe miss",
1043 .pme_ucode = 0x01,
1044 },
1045 { .pme_uname = "HIT_CLEAN",
1046 .pme_udesc = "Probe hit clean",
1047 .pme_ucode = 0x02,
1048 },
1049 { .pme_uname = "HIT_DIRTY_NO_MEMORY_CANCEL",
1050 .pme_udesc = "Probe hit dirty without memory cancel (probed by Sized Write or Change2Dirty)",
1051 .pme_ucode = 0x04,
1052 },
1053 { .pme_uname = "HIT_DIRTY_WITH_MEMORY_CANCEL",
1054 .pme_udesc = "Probe hit dirty with memory cancel (probed by DMA read or cache refill request)",
1055 .pme_ucode = 0x08,
1056 },
1057 { .pme_uname = "UPSTREAM_DISPLAY_REFRESH_READS",
1058 .pme_udesc = "Upstream display refresh reads",
1059 .pme_ucode = 0x10,
1060 },
1061 { .pme_uname = "UPSTREAM_NON_DISPLAY_REFRESH_READS",
1062 .pme_udesc = "Upstream non-display refresh reads",
1063 .pme_ucode = 0x20,
1064 },
1065 { .pme_uname = "ALL",
1066 .pme_udesc = "All sub-events selected",
1067 .pme_ucode = 0x3F,
1068 .pme_uflags = PFMLIB_AMD64_TILL_K8_REV_C,
1069 },
1070 { .pme_uname = "UPSTREAM_WRITES",
1071 .pme_udesc = "Upstream writes",
1072 .pme_ucode = 0x40,
1073 .pme_uflags = PFMLIB_AMD64_K8_REV_D,
1074 },
1075 { .pme_uname = "ALL",
1076 .pme_udesc = "All sub-events selected",
1077 .pme_ucode = 0x7F,
1078 .pme_uflags = PFMLIB_AMD64_K8_REV_D,
1079 },
1080 },
1081 },
1082/* 83 */{.pme_name = "GART",
1083 .pme_code = 0xEE,
1084 .pme_desc = "GART Events",
1085 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
1086 .pme_numasks = 4,
1087 .pme_umasks = {
1088 { .pme_uname = "APERTURE_HIT_FROM_CPU",
1089 .pme_udesc = "GART aperture hit on access from CPU",
1090 .pme_ucode = 0x01,
1091 },
1092 { .pme_uname = "APERTURE_HIT_FROM_IO",
1093 .pme_udesc = "GART aperture hit on access from I/O",
1094 .pme_ucode = 0x02,
1095 },
1096 { .pme_uname = "MISS",
1097 .pme_udesc = "GART miss",
1098 .pme_ucode = 0x04,
1099 },
1100 { .pme_uname = "ALL",
1101 .pme_udesc = "All sub-events selected",
1102 .pme_ucode = 0x07,
1103 },
1104 },
1105 },
1106/* 84 */{.pme_name = "HYPERTRANSPORT_LINK0",
1107 .pme_code = 0xF6,
1108 .pme_desc = "HyperTransport Link 0 Transmit Bandwidth",
1109 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
1110 .pme_numasks = 5,
1111 .pme_umasks = {
1112 { .pme_uname = "COMMAND_DWORD_SENT",
1113 .pme_udesc = "Command dword sent",
1114 .pme_ucode = 0x01,
1115 },
1116 { .pme_uname = "DATA_DWORD_SENT",
1117 .pme_udesc = "Data dword sent",
1118 .pme_ucode = 0x02,
1119 },
1120 { .pme_uname = "BUFFER_RELEASE_DWORD_SENT",
1121 .pme_udesc = "Buffer release dword sent",
1122 .pme_ucode = 0x04,
1123 },
1124 { .pme_uname = "NOP_DWORD_SENT",
1125 .pme_udesc = "Nop dword sent (idle)",
1126 .pme_ucode = 0x08,
1127 },
1128 { .pme_uname = "ALL",
1129 .pme_udesc = "All sub-events selected",
1130 .pme_ucode = 0x0F,
1131 },
1132 },
1133 },
1134/* 85 */{.pme_name = "HYPERTRANSPORT_LINK1",
1135 .pme_code = 0xF7,
1136 .pme_desc = "HyperTransport Link 1 Transmit Bandwidth",
1137 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
1138 .pme_numasks = 5,
1139 .pme_umasks = {
1140 { .pme_uname = "COMMAND_DWORD_SENT",
1141 .pme_udesc = "Command dword sent",
1142 .pme_ucode = 0x01,
1143 },
1144 { .pme_uname = "DATA_DWORD_SENT",
1145 .pme_udesc = "Data dword sent",
1146 .pme_ucode = 0x02,
1147 },
1148 { .pme_uname = "BUFFER_RELEASE_DWORD_SENT",
1149 .pme_udesc = "Buffer release dword sent",
1150 .pme_ucode = 0x04,
1151 },
1152 { .pme_uname = "NOP_DWORD_SENT",
1153 .pme_udesc = "Nop dword sent (idle)",
1154 .pme_ucode = 0x08,
1155 },
1156 { .pme_uname = "ALL",
1157 .pme_udesc = "All sub-events selected",
1158 .pme_ucode = 0x0F,
1159 },
1160 },
1161 },
1162/* 86 */{.pme_name = "HYPERTRANSPORT_LINK2",
1163 .pme_code = 0xF8,
1164 .pme_desc = "HyperTransport Link 2 Transmit Bandwidth",
1165 .pme_flags = PFMLIB_AMD64_UMASK_COMBO,
1166 .pme_numasks = 5,
1167 .pme_umasks = {
1168 { .pme_uname = "COMMAND_DWORD_SENT",
1169 .pme_udesc = "Command dword sent",
1170 .pme_ucode = 0x01,
1171 },
1172 { .pme_uname = "DATA_DWORD_SENT",
1173 .pme_udesc = "Data dword sent",
1174 .pme_ucode = 0x02,
1175 },
1176 { .pme_uname = "BUFFER_RELEASE_DWORD_SENT",
1177 .pme_udesc = "Buffer release dword sent",
1178 .pme_ucode = 0x04,
1179 },
1180 { .pme_uname = "NOP_DWORD_SENT",
1181 .pme_udesc = "Nop dword sent (idle)",
1182 .pme_ucode = 0x08,
1183 },
1184 { .pme_uname = "ALL",
1185 .pme_udesc = "All sub-events selected",
1186 .pme_ucode = 0x0F,
1187 },
1188 },
1189 },
1190};
1191
1192#define PME_AMD64_K8_EVENT_COUNT (sizeof(amd64_k8_pe)/sizeof(pme_amd64_entry_t))
1193#define PME_AMD64_K8_CPU_CLK_UNHALTED 40
1194#define PME_AMD64_K8_RETIRED_INSTRUCTIONS 41
static pme_amd64_entry_t amd64_k8_pe[]
#define PFMLIB_AMD64_K8_REV_D
#define PFMLIB_AMD64_UMASK_COMBO
#define PFMLIB_AMD64_K8_REV_F
#define PFMLIB_AMD64_TILL_K8_REV_E
#define PFMLIB_AMD64_K8_REV_E
#define PFMLIB_AMD64_TILL_K8_REV_C
char * pme_name