|
Packit |
577717 |
/*
|
|
Packit |
577717 |
* Copyright (c) 2017 by Vince Weaver <vincent.weaver@maine.edu>
|
|
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 |
* PMU: amd64_fam16h (AMD64 Fam16h)
|
|
Packit |
577717 |
*/
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Dispatched FPU 0x0 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_dispatched_fpu[]={
|
|
Packit |
577717 |
{ .uname = "PIPE0",
|
|
Packit |
577717 |
.udesc = "Pipe0 dispatches",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "PIPE1",
|
|
Packit |
577717 |
.udesc = "Pipe1 dispatches",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Retired SSE/AVX 0x03 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_retired_sse_operations[]={
|
|
Packit |
577717 |
{ .uname = "SINGLE_ADD_SUB_OPS",
|
|
Packit |
577717 |
.udesc = "Single precision add/subtract ops",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SINGLE_MUL_OPS",
|
|
Packit |
577717 |
.udesc = "Single precision multiply ops",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SINGLE_DIV_OPS",
|
|
Packit |
577717 |
.udesc = "Single precision divide/square root ops",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DOUBLE_ADD_SUB_OPS",
|
|
Packit |
577717 |
.udesc = "Double precision add/subtract ops",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DOUBLE_MUL_OPS",
|
|
Packit |
577717 |
.udesc = "Double precision multiply ops",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DOUBLE_DIV_OPS",
|
|
Packit |
577717 |
.udesc = "Double precision divide/square root ops",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x7f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Retired serializing ops 0x05 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_retired_serializing_ops[]={
|
|
Packit |
577717 |
{ .uname = "SSE_BOTTOM_EXECUTING_UOPS",
|
|
Packit |
577717 |
.udesc = "SSE bottom-executing uops retired",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SSE_CONTROL_RENAMING_UOPS",
|
|
Packit |
577717 |
.udesc = "SSE control-renaming uops retired",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "X87_BOTTOM_EXECUTING_UOPS",
|
|
Packit |
577717 |
.udesc = "X87 bottom-executing uops retired",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "X87_CONTROL_RENAMING_UOPS",
|
|
Packit |
577717 |
.udesc = "X87 control-renaming uops retired",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xf,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Retired x87 ops 0x11 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_retired_x87_ops[]={
|
|
Packit |
577717 |
{ .uname = "ADD_AND_SUB",
|
|
Packit |
577717 |
.udesc = "Add and subtract",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MULTIPLY",
|
|
Packit |
577717 |
.udesc = "Multiply",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DIVIDE_AND_FSQRT",
|
|
Packit |
577717 |
.udesc = "Divide and fsqrt",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xf,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Segment Register Loads 0x20 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_segment_register_loads[]={
|
|
Packit |
577717 |
{ .uname = "ES",
|
|
Packit |
577717 |
.udesc = "ES",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CS",
|
|
Packit |
577717 |
.udesc = "CS",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SS",
|
|
Packit |
577717 |
.udesc = "SS",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DS",
|
|
Packit |
577717 |
.udesc = "DS",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "FS",
|
|
Packit |
577717 |
.udesc = "FS",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "GS",
|
|
Packit |
577717 |
.udesc = "GS",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HS",
|
|
Packit |
577717 |
.udesc = "HS",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x7f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Pipeline Restart 0x21 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_pipeline_restart[]={
|
|
Packit |
577717 |
{ .uname = "INVALIDATING_PROBES",
|
|
Packit |
577717 |
.udesc = "Evictions caused by invalidating probes",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "FILLS",
|
|
Packit |
577717 |
.udesc = "Evictions caused by fills",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Locked Operations 0x24 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_locked_ops[]={
|
|
Packit |
577717 |
{ .uname = "EXECUTED",
|
|
Packit |
577717 |
.udesc = "The number of locked instructions executed",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CYCLES_TO_ACQUIRE",
|
|
Packit |
577717 |
.udesc = "The number of cycles to acquire bus lock",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CYCLES_TO_UNLOCK",
|
|
Packit |
577717 |
.udesc = "The number of cycles to unlock cache line",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x7,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* LS Dispatch 0x29 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_ls_dispatch[]={
|
|
Packit |
577717 |
{ .uname = "LOADS",
|
|
Packit |
577717 |
.udesc = "The number of loads",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "STORES",
|
|
Packit |
577717 |
.udesc = "The number of stores",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "LOAD_OP_STORES",
|
|
Packit |
577717 |
.udesc = "The number of load-op-stores",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x7,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Cancells Store to Load 0x2a */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_cancelled_store_to_load_forward_operations[]={
|
|
Packit |
577717 |
{ .uname = "ADDRESS_MISMATCHES",
|
|
Packit |
577717 |
.udesc = "Address mismatches (starting byte not the same).",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "STORE_IS_SMALLER_THAN_LOAD",
|
|
Packit |
577717 |
.udesc = "Store is smaller than load.",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MISALIGNED",
|
|
Packit |
577717 |
.udesc = "Misaligned.",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x7,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Data cache refills 0x42 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_data_cache_refills[]={
|
|
Packit |
577717 |
{ .uname = "NON_CACHABLE",
|
|
Packit |
577717 |
.udesc = "Non-cachable",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SHARED",
|
|
Packit |
577717 |
.udesc = "Shared",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "EXCLUSIVE",
|
|
Packit |
577717 |
.udesc = "Exclusive",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OWNED",
|
|
Packit |
577717 |
.udesc = "Owned",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MODIFIED",
|
|
Packit |
577717 |
.udesc = "Modified",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x1f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Cache refills from northbridge 0x43 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_data_cache_refills_from_system[]={
|
|
Packit |
577717 |
{ .uname = "NON_CACHABLE",
|
|
Packit |
577717 |
.udesc = "non-cachable",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SHARED",
|
|
Packit |
577717 |
.udesc = "Shared",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "EXCLUSIVE",
|
|
Packit |
577717 |
.udesc = "Exclusive",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OWNED",
|
|
Packit |
577717 |
.udesc = "Owned",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MODIFIED",
|
|
Packit |
577717 |
.udesc = "Modified",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x1f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Data cache lines evicted 0x44 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_data_cache_lines_evicted[]={
|
|
Packit |
577717 |
{ .uname = "EVICTED",
|
|
Packit |
577717 |
.udesc = "Evicted from probe",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SHARED",
|
|
Packit |
577717 |
.udesc = "Shared eviction",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "EXCLUSIVE",
|
|
Packit |
577717 |
.udesc = "Exclusive eviction",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OWNED",
|
|
Packit |
577717 |
.udesc = "Owned eviction",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MODIFIED",
|
|
Packit |
577717 |
.udesc = "Modified eviction",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x1f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* DTLB Miss 0x46 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_dtlb_miss[]={
|
|
Packit |
577717 |
{ .uname = "STORES_L1TLB",
|
|
Packit |
577717 |
.udesc = "Stores that miss L1TLB",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "LOADS_L1TLB",
|
|
Packit |
577717 |
.udesc = "Loads that miss L1TLB",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "STORES_L2TLB",
|
|
Packit |
577717 |
.udesc = "Stores that miss L2TLB",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "LOADS_L2TLB",
|
|
Packit |
577717 |
.udesc = "Loads that miss L2TLB",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xf,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Misaligned accesses 0x47 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_misaligned_accesses[]={
|
|
Packit |
577717 |
{ .uname = "MISALIGN_16B",
|
|
Packit |
577717 |
.udesc = "Misaligns that cross 16 Byte boundary",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MISALIGN_4KB",
|
|
Packit |
577717 |
.udesc = "Misaligns that cross a 4kB boundary",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Prefetch Instruction Dispatched 0x4b */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_prefetch_instructions_dispatched[]={
|
|
Packit |
577717 |
{ .uname = "LOAD",
|
|
Packit |
577717 |
.udesc = "Load (Prefetch, PrefetchT0/T1/T2)",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "STORE",
|
|
Packit |
577717 |
.udesc = "Store (PrefetchW)",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "NTA",
|
|
Packit |
577717 |
.udesc = "NTA (PrefetchNTA)",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x7,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* L1 DTLB Hit 0x4d */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_l1_dtlb_hit[]={
|
|
Packit |
577717 |
{ .uname = "L1_4K_TLB_HIT",
|
|
Packit |
577717 |
.udesc = "L1 4K TLB hit",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "L1_2M_TLB_HIT",
|
|
Packit |
577717 |
.udesc = "L1 2M TLB hit",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Ineffective SW Prefetch 0x52 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_ineffective_sw_prefetches[]={
|
|
Packit |
577717 |
{ .uname = "SW_PREFETCH_DATA_CACHE",
|
|
Packit |
577717 |
.udesc = "Software prefetch hit in data cache",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SW_PREFETCH_PENDING_FILL",
|
|
Packit |
577717 |
.udesc = "Software prefetch hit a pending fill",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SW_PREFETCH_MAB",
|
|
Packit |
577717 |
.udesc = "Software prefetches that don't get a MAB",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SW_PREFETCH_HIT_L2",
|
|
Packit |
577717 |
.udesc = "Software prefetches that hit in L2",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xf,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Uncachable Memory 0x61 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_uncachable_memory[]={
|
|
Packit |
577717 |
{ .uname = "READ_BYTE",
|
|
Packit |
577717 |
.udesc = "Read byte",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_DOUBLEWORD",
|
|
Packit |
577717 |
.udesc = "Read doubleword",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "WRITE_BYTE",
|
|
Packit |
577717 |
.udesc = "Write byte",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "WRITE_DOUBLEWORD",
|
|
Packit |
577717 |
.udesc = "Write doubleword",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x33,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Read Block Operations 0x62 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_read_block[]={
|
|
Packit |
577717 |
{ .uname = "READ_BLOCK",
|
|
Packit |
577717 |
.udesc = "Read block",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "RDBLKMOD",
|
|
Packit |
577717 |
.udesc = "RdBlkMod",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_BLOCK_SHARED",
|
|
Packit |
577717 |
.udesc = "Read block shared",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_BLOCK_SPEC",
|
|
Packit |
577717 |
.udesc = "Read block speculative",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_BLOCK_SPEC_MOD",
|
|
Packit |
577717 |
.udesc = "Read block speculative modified",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_BLOCK_SPEC_SHARED",
|
|
Packit |
577717 |
.udesc = "Read block speculative shared",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x77,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Change to Dirty 0x63 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_change_dirty[]={
|
|
Packit |
577717 |
{ .uname = "CHANGE_DIRTY",
|
|
Packit |
577717 |
.udesc = "Change to dirty",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Memory Requests 0x65 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_memory_requests[]={
|
|
Packit |
577717 |
{ .uname = "NON_CACHEABLE",
|
|
Packit |
577717 |
.udesc = "Requests to non-cacheable (UC) memory",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "WRITE_COMBINING",
|
|
Packit |
577717 |
.udesc = "Requests to write-combining (WC) memory or WC buffer flushes to WB memory",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "STREAMING_STORE",
|
|
Packit |
577717 |
.udesc = "Streaming store (SS) requests",
|
|
Packit |
577717 |
.ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x83,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Data Cache Prefetches 0x67 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_data_prefetches[]={
|
|
Packit |
577717 |
{ .uname = "ATTEMPTED",
|
|
Packit |
577717 |
.udesc = "Prefetch attempts",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MAB",
|
|
Packit |
577717 |
.udesc = "Hits on MAB",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xa,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* MAB Requests 0x68 and 0x69 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_mab_requests[]={
|
|
Packit |
577717 |
{ .uname = "DC_MISS0",
|
|
Packit |
577717 |
.udesc = "Data cache miss buffer 0",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_MISS1",
|
|
Packit |
577717 |
.udesc = "Data cache miss buffer 1",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_MISS2",
|
|
Packit |
577717 |
.udesc = "Data cache miss buffer 2",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_MISS3",
|
|
Packit |
577717 |
.udesc = "Data cache miss buffer 3",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_MISS4",
|
|
Packit |
577717 |
.udesc = "Data cache miss buffer 4",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_MISS5",
|
|
Packit |
577717 |
.udesc = "Data cache miss buffer 5",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_MISS6",
|
|
Packit |
577717 |
.udesc = "Data cache miss buffer 6",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_MISS7",
|
|
Packit |
577717 |
.udesc = "Data cache miss buffer 7",
|
|
Packit |
577717 |
.ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "IC_MISS0",
|
|
Packit |
577717 |
.udesc = "Instruction cache miss buffer 0",
|
|
Packit |
577717 |
.ucode = 0x100,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "IC_MISS1",
|
|
Packit |
577717 |
.udesc = "Instruction cache miss buffer 1",
|
|
Packit |
577717 |
.ucode = 0x200,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_ANY",
|
|
Packit |
577717 |
.udesc = "Any data cache miss buffer",
|
|
Packit |
577717 |
.ucode = 0x800,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "IC_ANY",
|
|
Packit |
577717 |
.udesc = "Any instruction cache miss buffer",
|
|
Packit |
577717 |
.ucode = 0x1000,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* System Response by Coherence 0x6c */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_system_responses[]={
|
|
Packit |
577717 |
{ .uname = "EXCLUSIVE",
|
|
Packit |
577717 |
.udesc = "Exclusive",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MODIFIED",
|
|
Packit |
577717 |
.udesc = "Modified",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SHARED",
|
|
Packit |
577717 |
.udesc = "Shared",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OWNED",
|
|
Packit |
577717 |
.udesc = "Owned",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DATA_ERROR",
|
|
Packit |
577717 |
.udesc = "Data Error",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CHANGE_DIRTY",
|
|
Packit |
577717 |
.udesc = "Change to dirty success",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "UNCACHEABLE",
|
|
Packit |
577717 |
.udesc = "Uncacheable",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x7f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Data written to system 0x6d */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_data_written_to_system[]={
|
|
Packit |
577717 |
{ .uname = "DATA_LINE_EVICTIONS",
|
|
Packit |
577717 |
.udesc = "Data line evictions",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "INSTRUCTION_ATTRIBUTE_EVICTIONS",
|
|
Packit |
577717 |
.udesc = "Instruction attribute evictions",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "BYTE_ENABLE_MASK_UNCACHEABLE",
|
|
Packit |
577717 |
.udesc = "Byte enable mask for uncacheabe or I/O store",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DATA_FOR_UNCACHEABLE",
|
|
Packit |
577717 |
.udesc = "Data for uncacheabe or I/O store",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "BYTE_ENABLE_MASK_WRITE_COMBINE",
|
|
Packit |
577717 |
.udesc = "Byte enable mask for write combine context flush",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DATA_FOR_WRITE_COMBINE",
|
|
Packit |
577717 |
.udesc = "Data for write combine contet flush",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* cache cross invalidate 0x75 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_cache_cross_invalidates[]={
|
|
Packit |
577717 |
{ .uname = "DC_INVALIDATES_IC",
|
|
Packit |
577717 |
.udesc = "Modification of instructions of data too close to code",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_INVALIDATES_DC",
|
|
Packit |
577717 |
.udesc = "CD or WBINVD",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "IC_INVALIDATES_IC",
|
|
Packit |
577717 |
.udesc = "aliasing",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "IC_INVALIDATES_DC_DIRTY",
|
|
Packit |
577717 |
.udesc = "Exection of modified instruction or data too close to code",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "IC_HITS_DC_CLEAN_LINE",
|
|
Packit |
577717 |
.udesc = "Reading code",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_PROBE_REJECTED_EARLY",
|
|
Packit |
577717 |
.udesc = "DC probe rejected early",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DC_PROBE_REJECTED_LATE",
|
|
Packit |
577717 |
.udesc = "DC probe rejected late",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x7f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* PDC Miss 0x162 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_pdc_miss[]={
|
|
Packit |
577717 |
{ .uname = "HOST_PDE_LEVEL",
|
|
Packit |
577717 |
.udesc = "Host: PDE level",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HOST_PDPE_LEVEL",
|
|
Packit |
577717 |
.udesc = "Host: PDPE level",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HOST_PML4E_LEVEL",
|
|
Packit |
577717 |
.udesc = "Host: PML4E level",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "GUEST_PDE_LEVEL",
|
|
Packit |
577717 |
.udesc = "Guest: PDE level",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "GUEST_PDPE_LEVEL",
|
|
Packit |
577717 |
.udesc = "Guest: PDPE level",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "GUEST_PML4E_LEVEL",
|
|
Packit |
577717 |
.udesc = "Guest: PML4E level",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x77,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* ITLB Miss 0x85 */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_itlb_miss[]={
|
|
Packit |
577717 |
{ .uname = "4K_PAGE_FETCHES",
|
|
Packit |
577717 |
.udesc = "Instruction fetches to a 4K page.",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "2M_PAGE_FETCHES",
|
|
Packit |
577717 |
.udesc = "Instruction fetches to a 2M page.",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Instruction Cache Lines Invalidated 0x8c */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_instruction_cache_lines_invalidated[]={
|
|
Packit |
577717 |
{ .uname = "IC_INVALIDATE_LS_PROBE",
|
|
Packit |
577717 |
.udesc = "Instruction cache invalidate due to LS probe",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "IC_INVALIDATE_BU_PROBE",
|
|
Packit |
577717 |
.udesc = "Instruction cache invalidate due to BU probe",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Retired indirect branch info (0x19a) */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_retired_branch_info[]={
|
|
Packit |
577717 |
{ .uname = "RETIRED",
|
|
Packit |
577717 |
.udesc = "Retired indirect branch instruction.",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MISPREDICTED",
|
|
Packit |
577717 |
.udesc = "Retired mispredicted near unconditional jump.",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* Retired MMX/FP instructions 0xcb */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_retired_mmx_and_fp_instructions[]={
|
|
Packit |
577717 |
{ .uname = "X87",
|
|
Packit |
577717 |
.udesc = "X87 instructions",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SSE",
|
|
Packit |
577717 |
.udesc = "SSE, SSE2, SSE3, MNI instructions",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
/* FPU exceptions 0xdb */
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam16h_fpu_exceptions[]={
|
|
Packit |
577717 |
{ .uname = "X87_RECLASS_MICROFAULTS",
|
|
Packit |
577717 |
.udesc = "X87 reclass microfaults",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SSE_RETYPE_MICROFAULTS",
|
|
Packit |
577717 |
.udesc = "SSE retype microfaults",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SSE_RECLASS_MICROFAULTS",
|
|
Packit |
577717 |
.udesc = "SSE reclass microfaults",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SSE_AND_X87_MICROTRAPS",
|
|
Packit |
577717 |
.udesc = "SSE and x87 microtraps",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xf,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_entry_t amd64_fam16h_pe[]={
|
|
Packit |
577717 |
{ .name = "DISPATCHED_FPU",
|
|
Packit |
577717 |
.desc = "Dispatched FPU Operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x0,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_dispatched_fpu),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_dispatched_fpu,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "FP_SCHEDULER_EMPTY",
|
|
Packit |
577717 |
.desc = "Cycles in which the FPU is Empty",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCHED_FPU_OPS_FAST_FLAG",
|
|
Packit |
577717 |
.desc = "Dispatched Fast Flag FPU Operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_SSE_AVX_OPERATIONS",
|
|
Packit |
577717 |
.desc = "Retired SSE/AVX Operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x3,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_retired_sse_operations),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_retired_sse_operations,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_SERIALIZING_OPS",
|
|
Packit |
577717 |
.desc = "Retired Serializing Ops",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x5,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_retired_serializing_ops),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_retired_serializing_ops,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_X87_OPERATIONS",
|
|
Packit |
577717 |
.desc = "Retired x87 operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x11,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_retired_x87_ops),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_retired_x87_ops,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "SEGMENT_REGISTER_LOADS",
|
|
Packit |
577717 |
.desc = "Segment Register Loads",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x20,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_segment_register_loads),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_segment_register_loads,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "PIPELINE_RESTART_DUE_TO_SELF_MODIFYING_CODE",
|
|
Packit |
577717 |
.desc = "Pipeline Restart Due to Self-Modifying Code",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x21,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "PIPELINE_RESTART_DUE_TO_PROBE_HIT",
|
|
Packit |
577717 |
.desc = "Pipeline Restart Due to Probe Hit",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x22,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_pipeline_restart),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_pipeline_restart,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "LOCKED_OPS",
|
|
Packit |
577717 |
.desc = "Locked Operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x24,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_locked_ops),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_locked_ops,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_CLFLUSH_INSTRUCTIONS",
|
|
Packit |
577717 |
.desc = "Retired CLFLUSH Instructions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x26,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_CPUID_INSTRUCTIONS",
|
|
Packit |
577717 |
.desc = "Retired CPUID Instructions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x27,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "LS_DISPATCH",
|
|
Packit |
577717 |
.desc = "Transactions dispatched to load-store unit",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x29,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_ls_dispatch),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_ls_dispatch,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "CANCELLED_STORE_TO_LOAD_FORWARD_OPERATIONS",
|
|
Packit |
577717 |
.desc = "Cancelled Store to Load Forward Operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x2a,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_cancelled_store_to_load_forward_operations),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_cancelled_store_to_load_forward_operations,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_CACHE_ACCESSES",
|
|
Packit |
577717 |
.desc = "Data Cache Accesses",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_CACHE_MISSES",
|
|
Packit |
577717 |
.desc = "Data Cache Misses",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x41,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_CACHE_REFILLS",
|
|
Packit |
577717 |
.desc = "Data Cache Refills from L2 or Northbridge",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x42,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_data_cache_refills),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_data_cache_refills,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_CACHE_REFILLS_FROM_NORTHBRIDGE",
|
|
Packit |
577717 |
.desc = "Data Cache Refills from the Northbridge",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x43,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_data_cache_refills_from_system),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_data_cache_refills_from_system,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_CACHE_LINES_EVICTED",
|
|
Packit |
577717 |
.desc = "Data Cache Lines Evicted",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x44,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_data_cache_lines_evicted),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_data_cache_lines_evicted,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "L1_DTLB_MISS_AND_L2_DTLB_HIT",
|
|
Packit |
577717 |
.desc = "L1 DTLB Miss and L2 DTLB Hit",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x45,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DTLB_MISS",
|
|
Packit |
577717 |
.desc = "L1 DTLB and L2 DTLB Miss",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x46,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_dtlb_miss),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_dtlb_miss,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MISALIGNED_ACCESSES",
|
|
Packit |
577717 |
.desc = "Misaligned Accesses",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x47,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_misaligned_accesses),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_misaligned_accesses,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "PREFETCH_INSTRUCTIONS_DISPATCHED",
|
|
Packit |
577717 |
.desc = "Prefetch Instructions Dispatched",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x4b,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_prefetch_instructions_dispatched),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_prefetch_instructions_dispatched,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DCACHE_MISSES_BY_LOCKED_INSTRUCTIONS",
|
|
Packit |
577717 |
.desc = "DCACHE Misses by Locked Instructions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x4c,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "L1_DTLB_HIT",
|
|
Packit |
577717 |
.desc = "L1 DTLB Hit",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x4d,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_l1_dtlb_hit),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_l1_dtlb_hit,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INEFFECTIVE_SW_PREFETCHES",
|
|
Packit |
577717 |
.desc = "Ineffective Software Prefetches",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x52,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_ineffective_sw_prefetches),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_ineffective_sw_prefetches,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "GLOBAL_TLB_FLUSHES",
|
|
Packit |
577717 |
.desc = "Global TLB Flushes",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x54,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
/* fam30h only */
|
|
Packit |
577717 |
{ .name = "COMMAND_RELATED_UNCACHABLE",
|
|
Packit |
577717 |
.desc = "Commands realted to uncachable memory and I/O",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x61,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_uncachable_memory),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_uncachable_memory,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "COMMAND_RELATED_READ_BLOCK",
|
|
Packit |
577717 |
.desc = "Commands realted to read block operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x62,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_read_block),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_read_block,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "COMMAND_RELATED_DIRTY",
|
|
Packit |
577717 |
.desc = "Commands realted to change dirty operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x63,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_change_dirty),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_change_dirty,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MEMORY_REQUESTS",
|
|
Packit |
577717 |
.desc = "Memory Requests by Type",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x65,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_memory_requests),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_memory_requests,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_PREFETCHES",
|
|
Packit |
577717 |
.desc = "Data Prefetches",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x67,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_data_prefetches),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_data_prefetches,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MAB_REQUESTS",
|
|
Packit |
577717 |
.desc = "Miss address buffer requests",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x68,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_mab_requests),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_mab_requests,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MAB_WAIT_CYCLES",
|
|
Packit |
577717 |
.desc = "Miss address buffer wait cycles",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x69,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_mab_requests),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_mab_requests,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "SYSTEM_RESPONSES",
|
|
Packit |
577717 |
.desc = "L2I Responses by Coherency State",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x6c,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_system_responses),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_system_responses,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_WRITTEN_TO_SYSTEM",
|
|
Packit |
577717 |
.desc = "16-byte transfers written to system",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x6d,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_data_written_to_system),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_data_written_to_system,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "CACHE_CROSS_INVALIDATES",
|
|
Packit |
577717 |
.desc = "Internal probes causing cache lines to be invalidated",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x75,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_cache_cross_invalidates),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_cache_cross_invalidates,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "CPU_CLK_UNHALTED",
|
|
Packit |
577717 |
.desc = "CPU Clocks not Halted",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x76,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "PDC_MISS",
|
|
Packit |
577717 |
.desc = "Number of PDC misses",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x162,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_pdc_miss),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_pdc_miss,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INSTRUCTION_CACHE_FETCHES",
|
|
Packit |
577717 |
.desc = "Instruction Cache Fetches",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INSTRUCTION_CACHE_MISSES",
|
|
Packit |
577717 |
.desc = "Instruction Cache Misses",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x81,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INSTRUCTION_CACHE_REFILLS_FROM_L2",
|
|
Packit |
577717 |
.desc = "Instruction Cache Refills from L2",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x82,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INSTRUCTION_CACHE_REFILLS_FROM_SYSTEM",
|
|
Packit |
577717 |
.desc = "Instruction Cache Refills from System",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x83,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "L1_ITLB_MISS_AND_L2_ITLB_HIT",
|
|
Packit |
577717 |
.desc = "L1 ITLB Miss and L2 ITLB Hit",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x84,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "ITLB_MISS",
|
|
Packit |
577717 |
.desc = "Instruction fetches that miss in 4k and 2M ITLB",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x85,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_itlb_miss),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_itlb_miss,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INSTRUCTION_FETCH_STALL",
|
|
Packit |
577717 |
.desc = "Instruction Fetch Stall",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x87,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETURN_STACK_HITS",
|
|
Packit |
577717 |
.desc = "Return Stack Hits",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x88,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETURN_STACK_OVERFLOWS",
|
|
Packit |
577717 |
.desc = "Return Stack Overflows",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x89,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INSTRUCTION_CACHE_VICTIMS",
|
|
Packit |
577717 |
.desc = "Instruction Cache Victims",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x8b,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INSTRUCTION_CACHE_LINES_INVALIDATED",
|
|
Packit |
577717 |
.desc = "Instruction Cache Lines Invalidated",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x8c,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_instruction_cache_lines_invalidated),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_instruction_cache_lines_invalidated,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "ITLB_RELOADS",
|
|
Packit |
577717 |
.desc = "ITLB Reloads",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x99,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "ITLB_RELOADS_ABORTED",
|
|
Packit |
577717 |
.desc = "ITLB reloads aborted",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x9a,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_INDIRECT_BRANCH_INFO",
|
|
Packit |
577717 |
.desc = "Retired indirect branch info",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x19a,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_retired_branch_info),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_retired_branch_info,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_INSTRUCTIONS",
|
|
Packit |
577717 |
.desc = "Retired Instructions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc0,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_UOPS",
|
|
Packit |
577717 |
.desc = "Retired uops",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_BRANCH_INSTRUCTIONS",
|
|
Packit |
577717 |
.desc = "Retired Branch Instructions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_MISPREDICTED_BRANCH_INSTRUCTIONS",
|
|
Packit |
577717 |
.desc = "Retired Mispredicted Branch Instructions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc3,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_TAKEN_BRANCH_INSTRUCTIONS",
|
|
Packit |
577717 |
.desc = "Retired Taken Branch Instructions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_TAKEN_BRANCH_INSTRUCTIONS_MISPREDICTED",
|
|
Packit |
577717 |
.desc = "Retired Taken Branch Instructions Mispredicted",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc5,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_FAR_CONTROL_TRANSFERS",
|
|
Packit |
577717 |
.desc = "Retired Far Control Transfers",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc6,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_BRANCH_RESYNCS",
|
|
Packit |
577717 |
.desc = "Retired Branch Resyncs",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc7,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_NEAR_RETURNS",
|
|
Packit |
577717 |
.desc = "Retired Near Returns",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_NEAR_RETURNS_MISPREDICTED",
|
|
Packit |
577717 |
.desc = "Retired Near Returns Mispredicted",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xc9,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_MISPREDICTED_TAKEN",
|
|
Packit |
577717 |
.desc = "Retired mispredicted taken branches due to target mismatch",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xca,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_MMX_AND_FP_INSTRUCTIONS",
|
|
Packit |
577717 |
.desc = "Retired MMX/FP Instructions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xcb,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_retired_mmx_and_fp_instructions),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_retired_mmx_and_fp_instructions,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INTERRUPTS_MASKED_CYCLES",
|
|
Packit |
577717 |
.desc = "Interrupts-Masked Cycles",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xcd,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INTERRUPTS_MASKED_CYCLES_WITH_INTERRUPT_PENDING",
|
|
Packit |
577717 |
.desc = "Interrupts-Masked Cycles with Interrupt Pending",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xce,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INTERRUPTS_TAKEN",
|
|
Packit |
577717 |
.desc = "Interrupts Taken",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xcf,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "FPU_EXCEPTIONS",
|
|
Packit |
577717 |
.desc = "FPU Exceptions",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xdb,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam16h_fpu_exceptions),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam16h_fpu_exceptions,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DR0_BREAKPOINT_MATCHES",
|
|
Packit |
577717 |
.desc = "DR0 Breakpoint Matches",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xdc,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DR1_BREAKPOINT_MATCHES",
|
|
Packit |
577717 |
.desc = "DR1 Breakpoint Matches",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xdd,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DR2_BREAKPOINT_MATCHES",
|
|
Packit |
577717 |
.desc = "DR2 Breakpoint Matches",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xde,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DR3_BREAKPOINT_MATCHES",
|
|
Packit |
577717 |
.desc = "DR3 Breakpoint Matches",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xdf,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "TAGGED_IBS_OPS",
|
|
Packit |
577717 |
.desc = "Ops tagged by IBS",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1cf,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "TAGGED_IBS_OPS_RETIRED",
|
|
Packit |
577717 |
.desc = "Ops tagged by IBS that retired",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1d0,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|