|
Packit |
577717 |
/*
|
|
Packit |
577717 |
* Copyright (c) 2006, 2007 Advanced Micro Devices, Inc.
|
|
Packit |
577717 |
* Contributed by Ray Bryant <raybry@mpdtxmail.amd.com>
|
|
Packit |
577717 |
* Contributed by Robert Richter <robert.richter@amd.com>
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
Packit |
577717 |
* of this software and associated documentation files (the "Software"), to deal
|
|
Packit |
577717 |
* in the Software without restriction, including without limitation the rights
|
|
Packit |
577717 |
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
Packit |
577717 |
* of the Software, and to permit persons to whom the Software is furnished to do so,
|
|
Packit |
577717 |
* subject to the following conditions:
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* The above copyright notice and this permission notice shall be included in all
|
|
Packit |
577717 |
* copies or substantial portions of the Software.
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
|
|
Packit |
577717 |
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
|
|
Packit |
577717 |
* PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
|
Packit |
577717 |
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
Packit |
577717 |
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
|
|
Packit |
577717 |
* OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* This file is part of libpfm, a performance monitoring support library for
|
|
Packit |
577717 |
* applications on Linux.
|
|
Packit |
577717 |
*/
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* History
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* Feb 10 2006 -- Ray Bryant, raybry@mpdtxmail.amd.com
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* Brought event table up-to-date with the 3.85 (October 2005) version of the
|
|
Packit |
577717 |
* "BIOS and Kernel Developer's Guide for the AMD Athlon[tm] 64 and
|
|
Packit |
577717 |
* AMD Opteron[tm] Processors," AMD Publication # 26094.
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* Dec 12 2007 -- Robert Richter, robert.richter@amd.com
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* Updated to: BIOS and Kernel Developer's Guide for AMD NPT Family
|
|
Packit |
577717 |
* 0Fh Processors, Publication # 32559, Revision: 3.08, Issue Date:
|
|
Packit |
577717 |
* July 2007
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* Feb 26 2009 -- Robert Richter, robert.richter@amd.com
|
|
Packit |
577717 |
*
|
|
Packit |
577717 |
* Updates and fixes of some revision flags and descriptions according
|
|
Packit |
577717 |
* to these documents:
|
|
Packit |
577717 |
* BIOS and Kernel Developer's Guide, #26094, Revision: 3.30
|
|
Packit |
577717 |
* BIOS and Kernel Developer's Guide, #32559, Revision: 3.12
|
|
Packit |
577717 |
*/
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static pme_amd64_entry_t amd64_k8_pe[]={
|
|
Packit |
577717 |
/* 0 */{.pme_name = "DISPATCHED_FPU",
|
|
Packit |
577717 |
.pme_code = 0x00,
|
|
Packit |
577717 |
.pme_desc = "Dispatched FPU Operations",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 7,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "OPS_ADD",
|
|
Packit |
577717 |
.pme_udesc = "Add pipe ops",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "OPS_MULTIPLY",
|
|
Packit |
577717 |
.pme_udesc = "Multiply pipe ops",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "OPS_STORE",
|
|
Packit |
577717 |
.pme_udesc = "Store pipe ops",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "OPS_ADD_PIPE_LOAD_OPS",
|
|
Packit |
577717 |
.pme_udesc = "Add pipe load ops",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "OPS_MULTIPLY_PIPE_LOAD_OPS",
|
|
Packit |
577717 |
.pme_udesc = "Multiply pipe load ops",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "OPS_STORE_PIPE_LOAD_OPS",
|
|
Packit |
577717 |
.pme_udesc = "Store pipe load ops",
|
|
Packit |
577717 |
.pme_ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x3F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 1 */{.pme_name = "CYCLES_NO_FPU_OPS_RETIRED",
|
|
Packit |
577717 |
.pme_code = 0x01,
|
|
Packit |
577717 |
.pme_desc = "Cycles with no FPU Ops Retired",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 2 */{.pme_name = "DISPATCHED_FPU_OPS_FAST_FLAG",
|
|
Packit |
577717 |
.pme_code = 0x02,
|
|
Packit |
577717 |
.pme_desc = "Dispatched Fast Flag FPU Operations",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 3 */{.pme_name = "SEGMENT_REGISTER_LOADS",
|
|
Packit |
577717 |
.pme_code = 0x20,
|
|
Packit |
577717 |
.pme_desc = "Segment Register Loads",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 8,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "ES",
|
|
Packit |
577717 |
.pme_udesc = "ES",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CS",
|
|
Packit |
577717 |
.pme_udesc = "CS",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SS",
|
|
Packit |
577717 |
.pme_udesc = "SS",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DS",
|
|
Packit |
577717 |
.pme_udesc = "DS",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "FS",
|
|
Packit |
577717 |
.pme_udesc = "FS",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "GS",
|
|
Packit |
577717 |
.pme_udesc = "GS",
|
|
Packit |
577717 |
.pme_ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "HS",
|
|
Packit |
577717 |
.pme_udesc = "HS",
|
|
Packit |
577717 |
.pme_ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All segments",
|
|
Packit |
577717 |
.pme_ucode = 0x7F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 4 */{.pme_name = "PIPELINE_RESTART_DUE_TO_SELF_MODIFYING_CODE",
|
|
Packit |
577717 |
.pme_code = 0x21,
|
|
Packit |
577717 |
.pme_desc = "Pipeline restart due to self-modifying code",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 5 */{.pme_name = "PIPELINE_RESTART_DUE_TO_PROBE_HIT",
|
|
Packit |
577717 |
.pme_code = 0x22,
|
|
Packit |
577717 |
.pme_desc = "Pipeline restart due to probe hit",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 6 */{.pme_name = "LS_BUFFER_2_FULL_CYCLES",
|
|
Packit |
577717 |
.pme_code = 0x23,
|
|
Packit |
577717 |
.pme_desc = "LS Buffer 2 Full",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 7 */{.pme_name = "LOCKED_OPS",
|
|
Packit |
577717 |
.pme_code = 0x24,
|
|
Packit |
577717 |
.pme_desc = "Locked Operations",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "EXECUTED",
|
|
Packit |
577717 |
.pme_udesc = "The number of locked instructions executed",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CYCLES_SPECULATIVE_PHASE",
|
|
Packit |
577717 |
.pme_udesc = "The number of cycles spent in speculative phase",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CYCLES_NON_SPECULATIVE_PHASE",
|
|
Packit |
577717 |
.pme_udesc = "The number of cycles spent in non-speculative phase (including cache miss penalty)",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x07,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 8 */{.pme_name = "MEMORY_REQUESTS",
|
|
Packit |
577717 |
.pme_code = 0x65,
|
|
Packit |
577717 |
.pme_desc = "Memory Requests by Type",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "NON_CACHEABLE",
|
|
Packit |
577717 |
.pme_udesc = "Requests to non-cacheable (UC) memory",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "WRITE_COMBINING",
|
|
Packit |
577717 |
.pme_udesc = "Requests to write-combining (WC) memory or WC buffer flushes to WB memory",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "STREAMING_STORE",
|
|
Packit |
577717 |
.pme_udesc = "Streaming store (SS) requests",
|
|
Packit |
577717 |
.pme_ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x83,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 9 */{.pme_name = "DATA_CACHE_ACCESSES",
|
|
Packit |
577717 |
.pme_code = 0x40,
|
|
Packit |
577717 |
.pme_desc = "Data Cache Accesses",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 10 */{.pme_name = "DATA_CACHE_MISSES",
|
|
Packit |
577717 |
.pme_code = 0x41,
|
|
Packit |
577717 |
.pme_desc = "Data Cache Misses",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 11 */{.pme_name = "DATA_CACHE_REFILLS",
|
|
Packit |
577717 |
.pme_code = 0x42,
|
|
Packit |
577717 |
.pme_desc = "Data Cache Refills from L2 or System",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 6,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "SYSTEM",
|
|
Packit |
577717 |
.pme_udesc = "Refill from System",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "L2_SHARED",
|
|
Packit |
577717 |
.pme_udesc = "Shared-state line from L2",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "L2_EXCLUSIVE",
|
|
Packit |
577717 |
.pme_udesc = "Exclusive-state line from L2",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "L2_OWNED",
|
|
Packit |
577717 |
.pme_udesc = "Owned-state line from L2",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "L2_MODIFIED",
|
|
Packit |
577717 |
.pme_udesc = "Modified-state line from L2",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "Shared, Exclusive, Owned, Modified State Refills",
|
|
Packit |
577717 |
.pme_ucode = 0x1F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 12 */{.pme_name = "DATA_CACHE_REFILLS_FROM_SYSTEM",
|
|
Packit |
577717 |
.pme_code = 0x43,
|
|
Packit |
577717 |
.pme_desc = "Data Cache Refills from System",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 6,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "INVALID",
|
|
Packit |
577717 |
.pme_udesc = "Invalid",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SHARED",
|
|
Packit |
577717 |
.pme_udesc = "Shared",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "EXCLUSIVE",
|
|
Packit |
577717 |
.pme_udesc = "Exclusive",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "OWNED",
|
|
Packit |
577717 |
.pme_udesc = "Owned",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "MODIFIED",
|
|
Packit |
577717 |
.pme_udesc = "Modified",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "Invalid, Shared, Exclusive, Owned, Modified",
|
|
Packit |
577717 |
.pme_ucode = 0x1F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 13 */{.pme_name = "DATA_CACHE_LINES_EVICTED",
|
|
Packit |
577717 |
.pme_code = 0x44,
|
|
Packit |
577717 |
.pme_desc = "Data Cache Lines Evicted",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 6,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "INVALID",
|
|
Packit |
577717 |
.pme_udesc = "Invalid",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SHARED",
|
|
Packit |
577717 |
.pme_udesc = "Shared",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "EXCLUSIVE",
|
|
Packit |
577717 |
.pme_udesc = "Exclusive",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "OWNED",
|
|
Packit |
577717 |
.pme_udesc = "Owned",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "MODIFIED",
|
|
Packit |
577717 |
.pme_udesc = "Modified",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "Invalid, Shared, Exclusive, Owned, Modified",
|
|
Packit |
577717 |
.pme_ucode = 0x1F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 14 */{.pme_name = "L1_DTLB_MISS_AND_L2_DTLB_HIT",
|
|
Packit |
577717 |
.pme_code = 0x45,
|
|
Packit |
577717 |
.pme_desc = "L1 DTLB Miss and L2 DTLB Hit",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 15 */{.pme_name = "L1_DTLB_AND_L2_DTLB_MISS",
|
|
Packit |
577717 |
.pme_code = 0x46,
|
|
Packit |
577717 |
.pme_desc = "L1 DTLB and L2 DTLB Miss",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 16 */{.pme_name = "MISALIGNED_ACCESSES",
|
|
Packit |
577717 |
.pme_code = 0x47,
|
|
Packit |
577717 |
.pme_desc = "Misaligned Accesses",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 17 */{.pme_name = "MICROARCHITECTURAL_LATE_CANCEL_OF_AN_ACCESS",
|
|
Packit |
577717 |
.pme_code = 0x48,
|
|
Packit |
577717 |
.pme_desc = "Microarchitectural Late Cancel of an Access",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 18 */{.pme_name = "MICROARCHITECTURAL_EARLY_CANCEL_OF_AN_ACCESS",
|
|
Packit |
577717 |
.pme_code = 0x49,
|
|
Packit |
577717 |
.pme_desc = "Microarchitectural Early Cancel of an Access",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 19 */{.pme_name = "SCRUBBER_SINGLE_BIT_ECC_ERRORS",
|
|
Packit |
577717 |
.pme_code = 0x4A,
|
|
Packit |
577717 |
.pme_desc = "Single-bit ECC Errors Recorded by Scrubber",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 3,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "SCRUBBER_ERROR",
|
|
Packit |
577717 |
.pme_udesc = "Scrubber error",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "PIGGYBACK_ERROR",
|
|
Packit |
577717 |
.pme_udesc = "Piggyback scrubber errors",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x03,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 20 */{.pme_name = "PREFETCH_INSTRUCTIONS_DISPATCHED",
|
|
Packit |
577717 |
.pme_code = 0x4B,
|
|
Packit |
577717 |
.pme_desc = "Prefetch Instructions Dispatched",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "LOAD",
|
|
Packit |
577717 |
.pme_udesc = "Load (Prefetch, PrefetchT0/T1/T2)",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "STORE",
|
|
Packit |
577717 |
.pme_udesc = "Store (PrefetchW)",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "NTA",
|
|
Packit |
577717 |
.pme_udesc = "NTA (PrefetchNTA)",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x07,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 21 */{.pme_name = "DCACHE_MISSES_BY_LOCKED_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0x4C,
|
|
Packit |
577717 |
.pme_desc = "DCACHE Misses by Locked Instructions",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 2,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "DATA_CACHE_MISSES_BY_LOCKED_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_udesc = "Data cache misses by locked instructions",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 22 */{.pme_name = "DATA_PREFETCHES",
|
|
Packit |
577717 |
.pme_code = 0x67,
|
|
Packit |
577717 |
.pme_desc = "Data Prefetcher",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 3,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "CANCELLED",
|
|
Packit |
577717 |
.pme_udesc = "Cancelled prefetches",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ATTEMPTED",
|
|
Packit |
577717 |
.pme_udesc = "Prefetch attempts",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x03,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 23 */{.pme_name = "SYSTEM_READ_RESPONSES",
|
|
Packit |
577717 |
.pme_code = 0x6C,
|
|
Packit |
577717 |
.pme_desc = "System Read Responses by Coherency State",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "EXCLUSIVE",
|
|
Packit |
577717 |
.pme_udesc = "Exclusive",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "MODIFIED",
|
|
Packit |
577717 |
.pme_udesc = "Modified",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SHARED",
|
|
Packit |
577717 |
.pme_udesc = "Shared",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "Exclusive, Modified, Shared",
|
|
Packit |
577717 |
.pme_ucode = 0x07,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 24 */{.pme_name = "QUADWORDS_WRITTEN_TO_SYSTEM",
|
|
Packit |
577717 |
.pme_code = 0x6D,
|
|
Packit |
577717 |
.pme_desc = "Quadwords Written to System",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 2,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "QUADWORD_WRITE_TRANSFER",
|
|
Packit |
577717 |
.pme_udesc = "Quadword write transfer",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 25 */{.pme_name = "REQUESTS_TO_L2",
|
|
Packit |
577717 |
.pme_code = 0x7D,
|
|
Packit |
577717 |
.pme_desc = "Requests to L2 Cache",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 6,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_udesc = "IC fill",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DATA",
|
|
Packit |
577717 |
.pme_udesc = "DC fill",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "TLB_WALK",
|
|
Packit |
577717 |
.pme_udesc = "TLB fill (page table walks)",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SNOOP",
|
|
Packit |
577717 |
.pme_udesc = "Tag snoop request",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CANCELLED",
|
|
Packit |
577717 |
.pme_udesc = "Cancelled request",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All non-cancelled requests",
|
|
Packit |
577717 |
.pme_ucode = 0x1F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 26 */{.pme_name = "L2_CACHE_MISS",
|
|
Packit |
577717 |
.pme_code = 0x7E,
|
|
Packit |
577717 |
.pme_desc = "L2 Cache Misses",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_udesc = "IC fill",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DATA",
|
|
Packit |
577717 |
.pme_udesc = "DC fill (includes possible replays, whereas event 41h does not)",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "TLB_WALK",
|
|
Packit |
577717 |
.pme_udesc = "TLB page table walk",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "Instructions, Data, TLB walk",
|
|
Packit |
577717 |
.pme_ucode = 0x07,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 27 */{.pme_name = "L2_FILL_WRITEBACK",
|
|
Packit |
577717 |
.pme_code = 0x7F,
|
|
Packit |
577717 |
.pme_desc = "L2 Fill/Writeback",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "L2_FILLS",
|
|
Packit |
577717 |
.pme_udesc = "L2 fills (victims from L1 caches, TLB page table walks and data prefetches)",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_TILL_K8_REV_E,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "L2_WRITEBACKS",
|
|
Packit |
577717 |
.pme_udesc = "L2 Writebacks to system.",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x03,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 28 */{.pme_name = "INSTRUCTION_CACHE_FETCHES",
|
|
Packit |
577717 |
.pme_code = 0x80,
|
|
Packit |
577717 |
.pme_desc = "Instruction Cache Fetches",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 29 */{.pme_name = "INSTRUCTION_CACHE_MISSES",
|
|
Packit |
577717 |
.pme_code = 0x81,
|
|
Packit |
577717 |
.pme_desc = "Instruction Cache Misses",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 30 */{.pme_name = "INSTRUCTION_CACHE_REFILLS_FROM_L2",
|
|
Packit |
577717 |
.pme_code = 0x82,
|
|
Packit |
577717 |
.pme_desc = "Instruction Cache Refills from L2",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 31 */{.pme_name = "INSTRUCTION_CACHE_REFILLS_FROM_SYSTEM",
|
|
Packit |
577717 |
.pme_code = 0x83,
|
|
Packit |
577717 |
.pme_desc = "Instruction Cache Refills from System",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 32 */{.pme_name = "L1_ITLB_MISS_AND_L2_ITLB_HIT",
|
|
Packit |
577717 |
.pme_code = 0x84,
|
|
Packit |
577717 |
.pme_desc = "L1 ITLB Miss and L2 ITLB Hit",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 33 */{.pme_name = "L1_ITLB_MISS_AND_L2_ITLB_MISS",
|
|
Packit |
577717 |
.pme_code = 0x85,
|
|
Packit |
577717 |
.pme_desc = "L1 ITLB Miss and L2 ITLB Miss",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 34 */{.pme_name = "PIPELINE_RESTART_DUE_TO_INSTRUCTION_STREAM_PROBE",
|
|
Packit |
577717 |
.pme_code = 0x86,
|
|
Packit |
577717 |
.pme_desc = "Pipeline Restart Due to Instruction Stream Probe",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 35 */{.pme_name = "INSTRUCTION_FETCH_STALL",
|
|
Packit |
577717 |
.pme_code = 0x87,
|
|
Packit |
577717 |
.pme_desc = "Instruction Fetch Stall",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 36 */{.pme_name = "RETURN_STACK_HITS",
|
|
Packit |
577717 |
.pme_code = 0x88,
|
|
Packit |
577717 |
.pme_desc = "Return Stack Hits",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 37 */{.pme_name = "RETURN_STACK_OVERFLOWS",
|
|
Packit |
577717 |
.pme_code = 0x89,
|
|
Packit |
577717 |
.pme_desc = "Return Stack Overflows",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 38 */{.pme_name = "RETIRED_CLFLUSH_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0x26,
|
|
Packit |
577717 |
.pme_desc = "Retired CLFLUSH Instructions",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 39 */{.pme_name = "RETIRED_CPUID_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0x27,
|
|
Packit |
577717 |
.pme_desc = "Retired CPUID Instructions",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 40 */{.pme_name = "CPU_CLK_UNHALTED",
|
|
Packit |
577717 |
.pme_code = 0x76,
|
|
Packit |
577717 |
.pme_desc = "CPU Clocks not Halted",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 41 */{.pme_name = "RETIRED_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0xC0,
|
|
Packit |
577717 |
.pme_desc = "Retired Instructions",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 42 */{.pme_name = "RETIRED_UOPS",
|
|
Packit |
577717 |
.pme_code = 0xC1,
|
|
Packit |
577717 |
.pme_desc = "Retired uops",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 43 */{.pme_name = "RETIRED_BRANCH_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0xC2,
|
|
Packit |
577717 |
.pme_desc = "Retired Branch Instructions",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 44 */{.pme_name = "RETIRED_MISPREDICTED_BRANCH_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0xC3,
|
|
Packit |
577717 |
.pme_desc = "Retired Mispredicted Branch Instructions",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 45 */{.pme_name = "RETIRED_TAKEN_BRANCH_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0xC4,
|
|
Packit |
577717 |
.pme_desc = "Retired Taken Branch Instructions",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 46 */{.pme_name = "RETIRED_TAKEN_BRANCH_INSTRUCTIONS_MISPREDICTED",
|
|
Packit |
577717 |
.pme_code = 0xC5,
|
|
Packit |
577717 |
.pme_desc = "Retired Taken Branch Instructions Mispredicted",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 47 */{.pme_name = "RETIRED_FAR_CONTROL_TRANSFERS",
|
|
Packit |
577717 |
.pme_code = 0xC6,
|
|
Packit |
577717 |
.pme_desc = "Retired Far Control Transfers",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 48 */{.pme_name = "RETIRED_BRANCH_RESYNCS",
|
|
Packit |
577717 |
.pme_code = 0xC7,
|
|
Packit |
577717 |
.pme_desc = "Retired Branch Resyncs",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 49 */{.pme_name = "RETIRED_NEAR_RETURNS",
|
|
Packit |
577717 |
.pme_code = 0xC8,
|
|
Packit |
577717 |
.pme_desc = "Retired Near Returns",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 50 */{.pme_name = "RETIRED_NEAR_RETURNS_MISPREDICTED",
|
|
Packit |
577717 |
.pme_code = 0xC9,
|
|
Packit |
577717 |
.pme_desc = "Retired Near Returns Mispredicted",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 51 */{.pme_name = "RETIRED_INDIRECT_BRANCHES_MISPREDICTED",
|
|
Packit |
577717 |
.pme_code = 0xCA,
|
|
Packit |
577717 |
.pme_desc = "Retired Indirect Branches Mispredicted",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 52 */{.pme_name = "RETIRED_MMX_AND_FP_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0xCB,
|
|
Packit |
577717 |
.pme_desc = "Retired MMX/FP Instructions",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 5,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "X87",
|
|
Packit |
577717 |
.pme_udesc = "x87 instructions",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "MMX_AND_3DNOW",
|
|
Packit |
577717 |
.pme_udesc = "MMX and 3DNow! instructions",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "PACKED_SSE_AND_SSE2",
|
|
Packit |
577717 |
.pme_udesc = "Packed SSE and SSE2 instructions",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SCALAR_SSE_AND_SSE2",
|
|
Packit |
577717 |
.pme_udesc = "Scalar SSE and SSE2 instructions",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "X87, MMX(TM), 3DNow!(TM), Scalar and Packed SSE and SSE2 instructions",
|
|
Packit |
577717 |
.pme_ucode = 0x0F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 53 */{.pme_name = "RETIRED_FASTPATH_DOUBLE_OP_INSTRUCTIONS",
|
|
Packit |
577717 |
.pme_code = 0xCC,
|
|
Packit |
577717 |
.pme_desc = "Retired Fastpath Double Op Instructions",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "POSITION_0",
|
|
Packit |
577717 |
.pme_udesc = "With low op in position 0",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "POSITION_1",
|
|
Packit |
577717 |
.pme_udesc = "With low op in position 1",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "POSITION_2",
|
|
Packit |
577717 |
.pme_udesc = "With low op in position 2",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "With low op in position 0, 1, or 2",
|
|
Packit |
577717 |
.pme_ucode = 0x07,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 54 */{.pme_name = "INTERRUPTS_MASKED_CYCLES",
|
|
Packit |
577717 |
.pme_code = 0xCD,
|
|
Packit |
577717 |
.pme_desc = "Interrupts-Masked Cycles",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 55 */{.pme_name = "INTERRUPTS_MASKED_CYCLES_WITH_INTERRUPT_PENDING",
|
|
Packit |
577717 |
.pme_code = 0xCE,
|
|
Packit |
577717 |
.pme_desc = "Interrupts-Masked Cycles with Interrupt Pending",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 56 */{.pme_name = "INTERRUPTS_TAKEN",
|
|
Packit |
577717 |
.pme_code = 0xCF,
|
|
Packit |
577717 |
.pme_desc = "Interrupts Taken",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 57 */{.pme_name = "DECODER_EMPTY",
|
|
Packit |
577717 |
.pme_code = 0xD0,
|
|
Packit |
577717 |
.pme_desc = "Decoder Empty",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 58 */{.pme_name = "DISPATCH_STALLS",
|
|
Packit |
577717 |
.pme_code = 0xD1,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stalls",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 59 */{.pme_name = "DISPATCH_STALL_FOR_BRANCH_ABORT",
|
|
Packit |
577717 |
.pme_code = 0xD2,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall for Branch Abort to Retire",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 60 */{.pme_name = "DISPATCH_STALL_FOR_SERIALIZATION",
|
|
Packit |
577717 |
.pme_code = 0xD3,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall for Serialization",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 61 */{.pme_name = "DISPATCH_STALL_FOR_SEGMENT_LOAD",
|
|
Packit |
577717 |
.pme_code = 0xD4,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall for Segment Load",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 62 */{.pme_name = "DISPATCH_STALL_FOR_REORDER_BUFFER_FULL",
|
|
Packit |
577717 |
.pme_code = 0xD5,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall for Reorder Buffer Full",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 63 */{.pme_name = "DISPATCH_STALL_FOR_RESERVATION_STATION_FULL",
|
|
Packit |
577717 |
.pme_code = 0xD6,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall for Reservation Station Full",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 64 */{.pme_name = "DISPATCH_STALL_FOR_FPU_FULL",
|
|
Packit |
577717 |
.pme_code = 0xD7,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall for FPU Full",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 65 */{.pme_name = "DISPATCH_STALL_FOR_LS_FULL",
|
|
Packit |
577717 |
.pme_code = 0xD8,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall for LS Full",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 66 */{.pme_name = "DISPATCH_STALL_WAITING_FOR_ALL_QUIET",
|
|
Packit |
577717 |
.pme_code = 0xD9,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall Waiting for All Quiet",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 67 */{.pme_name = "DISPATCH_STALL_FOR_FAR_TRANSFER_OR_RSYNC",
|
|
Packit |
577717 |
.pme_code = 0xDA,
|
|
Packit |
577717 |
.pme_desc = "Dispatch Stall for Far Transfer or Resync to Retire",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 68 */{.pme_name = "FPU_EXCEPTIONS",
|
|
Packit |
577717 |
.pme_code = 0xDB,
|
|
Packit |
577717 |
.pme_desc = "FPU Exceptions",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 5,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "X87_RECLASS_MICROFAULTS",
|
|
Packit |
577717 |
.pme_udesc = "x87 reclass microfaults",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SSE_RETYPE_MICROFAULTS",
|
|
Packit |
577717 |
.pme_udesc = "SSE retype microfaults",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SSE_RECLASS_MICROFAULTS",
|
|
Packit |
577717 |
.pme_udesc = "SSE reclass microfaults",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SSE_AND_X87_MICROTRAPS",
|
|
Packit |
577717 |
.pme_udesc = "SSE and x87 microtraps",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x0F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 69 */{.pme_name = "DR0_BREAKPOINT_MATCHES",
|
|
Packit |
577717 |
.pme_code = 0xDC,
|
|
Packit |
577717 |
.pme_desc = "DR0 Breakpoint Matches",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 70 */{.pme_name = "DR1_BREAKPOINT_MATCHES",
|
|
Packit |
577717 |
.pme_code = 0xDD,
|
|
Packit |
577717 |
.pme_desc = "DR1 Breakpoint Matches",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 71 */{.pme_name = "DR2_BREAKPOINT_MATCHES",
|
|
Packit |
577717 |
.pme_code = 0xDE,
|
|
Packit |
577717 |
.pme_desc = "DR2 Breakpoint Matches",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 72 */{.pme_name = "DR3_BREAKPOINT_MATCHES",
|
|
Packit |
577717 |
.pme_code = 0xDF,
|
|
Packit |
577717 |
.pme_desc = "DR3 Breakpoint Matches",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 73 */{.pme_name = "DRAM_ACCESSES_PAGE",
|
|
Packit |
577717 |
.pme_code = 0xE0,
|
|
Packit |
577717 |
.pme_desc = "DRAM Accesses",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "HIT",
|
|
Packit |
577717 |
.pme_udesc = "Page hit",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "MISS",
|
|
Packit |
577717 |
.pme_udesc = "Page Miss",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CONFLICT",
|
|
Packit |
577717 |
.pme_udesc = "Page Conflict",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "Page Hit, Miss, or Conflict",
|
|
Packit |
577717 |
.pme_ucode = 0x07,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 74 */{.pme_name = "MEMORY_CONTROLLER_PAGE_TABLE_OVERFLOWS",
|
|
Packit |
577717 |
.pme_code = 0xE1,
|
|
Packit |
577717 |
.pme_desc = "Memory Controller Page Table Overflows",
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 75 */{.pme_name = "MEMORY_CONTROLLER_TURNAROUNDS",
|
|
Packit |
577717 |
.pme_code = 0xE3,
|
|
Packit |
577717 |
.pme_desc = "Memory Controller Turnarounds",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "CHIP_SELECT",
|
|
Packit |
577717 |
.pme_udesc = "DIMM (chip select) turnaround",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "READ_TO_WRITE",
|
|
Packit |
577717 |
.pme_udesc = "Read to write turnaround",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "WRITE_TO_READ",
|
|
Packit |
577717 |
.pme_udesc = "Write to read turnaround",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All Memory Controller Turnarounds",
|
|
Packit |
577717 |
.pme_ucode = 0x07,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 76 */{.pme_name = "MEMORY_CONTROLLER_BYPASS",
|
|
Packit |
577717 |
.pme_code = 0xE4,
|
|
Packit |
577717 |
.pme_desc = "Memory Controller Bypass Counter Saturation",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 5,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "HIGH_PRIORITY",
|
|
Packit |
577717 |
.pme_udesc = "Memory controller high priority bypass",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "LOW_PRIORITY",
|
|
Packit |
577717 |
.pme_udesc = "Memory controller low priority bypass",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DRAM_INTERFACE",
|
|
Packit |
577717 |
.pme_udesc = "DRAM controller interface bypass",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DRAM_QUEUE",
|
|
Packit |
577717 |
.pme_udesc = "DRAM controller queue bypass",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x0F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 77 */{.pme_name = "SIZED_BLOCKS",
|
|
Packit |
577717 |
.pme_code = 0xE5,
|
|
Packit |
577717 |
.pme_desc = "Sized Blocks",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO | PFMLIB_AMD64_K8_REV_D,
|
|
Packit |
577717 |
.pme_numasks = 5,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "32_BYTE_WRITES",
|
|
Packit |
577717 |
.pme_udesc = "32-byte Sized Writes",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "64_BYTE_WRITES",
|
|
Packit |
577717 |
.pme_udesc = "64-byte Sized Writes",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "32_BYTE_READS",
|
|
Packit |
577717 |
.pme_udesc = "32-byte Sized Reads",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "64_BYTE_READS",
|
|
Packit |
577717 |
.pme_udesc = "64-byte Sized Reads",
|
|
Packit |
577717 |
.pme_ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x3C,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 78 */{.pme_name = "THERMAL_STATUS_AND_ECC_ERRORS",
|
|
Packit |
577717 |
.pme_code = 0xE8,
|
|
Packit |
577717 |
.pme_desc = "Thermal Status and ECC Errors",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO | PFMLIB_AMD64_K8_REV_E,
|
|
Packit |
577717 |
.pme_numasks = 7,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "CLKS_CPU_ACTIVE",
|
|
Packit |
577717 |
.pme_udesc = "Number of clocks CPU is active when HTC is active",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CLKS_CPU_INACTIVE",
|
|
Packit |
577717 |
.pme_udesc = "Number of clocks CPU clock is inactive when HTC is active",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CLKS_DIE_TEMP_TOO_HIGH",
|
|
Packit |
577717 |
.pme_udesc = "Number of clocks when die temperature is higher than the software high temperature threshold",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CLKS_TEMP_THRESHOLD_EXCEEDED",
|
|
Packit |
577717 |
.pme_udesc = "Number of clocks when high temperature threshold was exceeded",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DRAM_ECC_ERRORS",
|
|
Packit |
577717 |
.pme_udesc = "Number of correctable and Uncorrectable DRAM ECC errors",
|
|
Packit |
577717 |
.pme_ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x80,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_TILL_K8_REV_E,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x8F,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 79 */{.pme_name = "CPU_IO_REQUESTS_TO_MEMORY_IO",
|
|
Packit |
577717 |
.pme_code = 0xE9,
|
|
Packit |
577717 |
.pme_desc = "CPU/IO Requests to Memory/IO",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO | PFMLIB_AMD64_K8_REV_E,
|
|
Packit |
577717 |
.pme_numasks = 9,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "I_O_TO_I_O",
|
|
Packit |
577717 |
.pme_udesc = "I/O to I/O",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "I_O_TO_MEM",
|
|
Packit |
577717 |
.pme_udesc = "I/O to Mem",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CPU_TO_I_O",
|
|
Packit |
577717 |
.pme_udesc = "CPU to I/O",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "CPU_TO_MEM",
|
|
Packit |
577717 |
.pme_udesc = "CPU to Mem",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "TO_REMOTE_NODE",
|
|
Packit |
577717 |
.pme_udesc = "To remote node",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "TO_LOCAL_NODE",
|
|
Packit |
577717 |
.pme_udesc = "To local node",
|
|
Packit |
577717 |
.pme_ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "FROM_REMOTE_NODE",
|
|
Packit |
577717 |
.pme_udesc = "From remote node",
|
|
Packit |
577717 |
.pme_ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "FROM_LOCAL_NODE",
|
|
Packit |
577717 |
.pme_udesc = "From local node",
|
|
Packit |
577717 |
.pme_ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0xFF,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 80 */{.pme_name = "CACHE_BLOCK",
|
|
Packit |
577717 |
.pme_code = 0xEA,
|
|
Packit |
577717 |
.pme_desc = "Cache Block Commands",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO | PFMLIB_AMD64_K8_REV_E,
|
|
Packit |
577717 |
.pme_numasks = 6,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "VICTIM_WRITEBACK",
|
|
Packit |
577717 |
.pme_udesc = "Victim Block (Writeback)",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DCACHE_LOAD_MISS",
|
|
Packit |
577717 |
.pme_udesc = "Read Block (Dcache load miss refill)",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "SHARED_ICACHE_REFILL",
|
|
Packit |
577717 |
.pme_udesc = "Read Block Shared (Icache refill)",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "READ_BLOCK_MODIFIED",
|
|
Packit |
577717 |
.pme_udesc = "Read Block Modified (Dcache store miss refill)",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "READ_TO_DIRTY",
|
|
Packit |
577717 |
.pme_udesc = "Change to Dirty (first store to clean block already in cache)",
|
|
Packit |
577717 |
.pme_ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x3D,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 81 */{.pme_name = "SIZED_COMMANDS",
|
|
Packit |
577717 |
.pme_code = 0xEB,
|
|
Packit |
577717 |
.pme_desc = "Sized Commands",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 8,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "NON_POSTED_WRITE_BYTE",
|
|
Packit |
577717 |
.pme_udesc = "NonPosted SzWr Byte (1-32 bytes) Legacy or mapped I/O, typically 1-4 bytes",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "NON_POSTED_WRITE_DWORD",
|
|
Packit |
577717 |
.pme_udesc = "NonPosted SzWr Dword (1-16 dwords) Legacy or mapped I/O, typically 1 dword",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "POSTED_WRITE_BYTE",
|
|
Packit |
577717 |
.pme_udesc = "Posted SzWr Byte (1-32 bytes) Sub-cache-line DMA writes, size varies; also flushes of partially-filled Write Combining buffer",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "POSTED_WRITE_DWORD",
|
|
Packit |
577717 |
.pme_udesc = "Posted SzWr Dword (1-16 dwords) Block-oriented DMA writes, often cache-line sized; also processor Write Combining buffer flushes",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "READ_BYTE_4_BYTES",
|
|
Packit |
577717 |
.pme_udesc = "SzRd Byte (4 bytes) Legacy or mapped I/O",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "READ_DWORD_1_16_DWORDS",
|
|
Packit |
577717 |
.pme_udesc = "SzRd Dword (1-16 dwords) Block-oriented DMA reads, typically cache-line size",
|
|
Packit |
577717 |
.pme_ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "READ_MODIFY_WRITE",
|
|
Packit |
577717 |
.pme_udesc = "RdModWr",
|
|
Packit |
577717 |
.pme_ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x7F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 82 */{.pme_name = "PROBE",
|
|
Packit |
577717 |
.pme_code = 0xEC,
|
|
Packit |
577717 |
.pme_desc = "Probe Responses and Upstream Requests",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 9,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "MISS",
|
|
Packit |
577717 |
.pme_udesc = "Probe miss",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "HIT_CLEAN",
|
|
Packit |
577717 |
.pme_udesc = "Probe hit clean",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "HIT_DIRTY_NO_MEMORY_CANCEL",
|
|
Packit |
577717 |
.pme_udesc = "Probe hit dirty without memory cancel (probed by Sized Write or Change2Dirty)",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "HIT_DIRTY_WITH_MEMORY_CANCEL",
|
|
Packit |
577717 |
.pme_udesc = "Probe hit dirty with memory cancel (probed by DMA read or cache refill request)",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "UPSTREAM_DISPLAY_REFRESH_READS",
|
|
Packit |
577717 |
.pme_udesc = "Upstream display refresh reads",
|
|
Packit |
577717 |
.pme_ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "UPSTREAM_NON_DISPLAY_REFRESH_READS",
|
|
Packit |
577717 |
.pme_udesc = "Upstream non-display refresh reads",
|
|
Packit |
577717 |
.pme_ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x3F,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_TILL_K8_REV_C,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "UPSTREAM_WRITES",
|
|
Packit |
577717 |
.pme_udesc = "Upstream writes",
|
|
Packit |
577717 |
.pme_ucode = 0x40,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_D,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x7F,
|
|
Packit |
577717 |
.pme_uflags = PFMLIB_AMD64_K8_REV_D,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 83 */{.pme_name = "GART",
|
|
Packit |
577717 |
.pme_code = 0xEE,
|
|
Packit |
577717 |
.pme_desc = "GART Events",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 4,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "APERTURE_HIT_FROM_CPU",
|
|
Packit |
577717 |
.pme_udesc = "GART aperture hit on access from CPU",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "APERTURE_HIT_FROM_IO",
|
|
Packit |
577717 |
.pme_udesc = "GART aperture hit on access from I/O",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "MISS",
|
|
Packit |
577717 |
.pme_udesc = "GART miss",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x07,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 84 */{.pme_name = "HYPERTRANSPORT_LINK0",
|
|
Packit |
577717 |
.pme_code = 0xF6,
|
|
Packit |
577717 |
.pme_desc = "HyperTransport Link 0 Transmit Bandwidth",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 5,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "COMMAND_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Command dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DATA_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Data dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "BUFFER_RELEASE_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Buffer release dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "NOP_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Nop dword sent (idle)",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x0F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 85 */{.pme_name = "HYPERTRANSPORT_LINK1",
|
|
Packit |
577717 |
.pme_code = 0xF7,
|
|
Packit |
577717 |
.pme_desc = "HyperTransport Link 1 Transmit Bandwidth",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 5,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "COMMAND_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Command dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DATA_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Data dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "BUFFER_RELEASE_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Buffer release dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "NOP_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Nop dword sent (idle)",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x0F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* 86 */{.pme_name = "HYPERTRANSPORT_LINK2",
|
|
Packit |
577717 |
.pme_code = 0xF8,
|
|
Packit |
577717 |
.pme_desc = "HyperTransport Link 2 Transmit Bandwidth",
|
|
Packit |
577717 |
.pme_flags = PFMLIB_AMD64_UMASK_COMBO,
|
|
Packit |
577717 |
.pme_numasks = 5,
|
|
Packit |
577717 |
.pme_umasks = {
|
|
Packit |
577717 |
{ .pme_uname = "COMMAND_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Command dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x01,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "DATA_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Data dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x02,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "BUFFER_RELEASE_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Buffer release dword sent",
|
|
Packit |
577717 |
.pme_ucode = 0x04,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "NOP_DWORD_SENT",
|
|
Packit |
577717 |
.pme_udesc = "Nop dword sent (idle)",
|
|
Packit |
577717 |
.pme_ucode = 0x08,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .pme_uname = "ALL",
|
|
Packit |
577717 |
.pme_udesc = "All sub-events selected",
|
|
Packit |
577717 |
.pme_ucode = 0x0F,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
#define PME_AMD64_K8_EVENT_COUNT (sizeof(amd64_k8_pe)/sizeof(pme_amd64_entry_t))
|
|
Packit |
577717 |
#define PME_AMD64_K8_CPU_CLK_UNHALTED 40
|
|
Packit |
577717 |
#define PME_AMD64_K8_RETIRED_INSTRUCTIONS 41
|