|
Packit |
577717 |
/*
|
|
Packit |
577717 |
* Copyright (c) 2011 University of Tennessee
|
|
Packit |
577717 |
* Contributed by Vince Weaver <vweaver1@utk.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_fam12h (AMD64 Fam12h)
|
|
Packit |
577717 |
*/
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_dispatched_fpu[]={
|
|
Packit |
577717 |
{ .uname = "OPS_ADD",
|
|
Packit |
577717 |
.udesc = "Add pipe ops excluding load ops and SSE move ops",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OPS_MULTIPLY",
|
|
Packit |
577717 |
.udesc = "Multiply pipe ops excluding load ops and SSE move ops",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OPS_STORE",
|
|
Packit |
577717 |
.udesc = "Store pipe ops excluding load ops and SSE move ops",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OPS_ADD_PIPE_LOAD_OPS",
|
|
Packit |
577717 |
.udesc = "Add pipe load ops and SSE move ops",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OPS_MULTIPLY_PIPE_LOAD_OPS",
|
|
Packit |
577717 |
.udesc = "Multiply pipe load ops and SSE move ops",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OPS_STORE_PIPE_LOAD_OPS",
|
|
Packit |
577717 |
.udesc = "Store pipe load ops and SSE move ops",
|
|
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 |
static const amd64_umask_t amd64_fam12h_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 = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DOUBLE_MUL_OPS",
|
|
Packit |
577717 |
.udesc = "Double precision multiply ops",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DOUBLE_DIV_OPS",
|
|
Packit |
577717 |
.udesc = "Double precision divide/square root ops",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "OP_TYPE",
|
|
Packit |
577717 |
.udesc = "Op type: 0=uops. 1=FLOPS",
|
|
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 |
static const amd64_umask_t amd64_fam12h_retired_move_ops[]={
|
|
Packit |
577717 |
{ .uname = "LOW_QW_MOVE_UOPS",
|
|
Packit |
577717 |
.udesc = "Merging low quadword move uops",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HIGH_QW_MOVE_UOPS",
|
|
Packit |
577717 |
.udesc = "Merging high quadword move uops",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL_OTHER_MERGING_MOVE_UOPS",
|
|
Packit |
577717 |
.udesc = "All other merging move uops",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL_OTHER_MOVE_UOPS",
|
|
Packit |
577717 |
.udesc = "All other move uops",
|
|
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_umask_t amd64_fam12h_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_BOTTOM_SERIALIZING_UOPS",
|
|
Packit |
577717 |
.udesc = "SSE bottom-serializing 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_BOTTOM_SERIALIZING_UOPS",
|
|
Packit |
577717 |
.udesc = "X87 bottom-serializing 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 |
static const amd64_umask_t amd64_fam12h_fp_scheduler_cycles[]={
|
|
Packit |
577717 |
{ .uname = "BOTTOM_EXECUTE_CYCLES",
|
|
Packit |
577717 |
.udesc = "Number of cycles a bottom-execute uop is in the FP scheduler",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "BOTTOM_SERIALIZING_CYCLES",
|
|
Packit |
577717 |
.udesc = "Number of cycles a bottom-serializing uop is in the FP scheduler",
|
|
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 |
static const amd64_umask_t amd64_fam12h_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 |
static const amd64_umask_t amd64_fam12h_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_SPECULATIVE_PHASE",
|
|
Packit |
577717 |
.udesc = "The number of cycles spent in speculative phase",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CYCLES_NON_SPECULATIVE_PHASE",
|
|
Packit |
577717 |
.udesc = "The number of cycles spent in non-speculative phase (including cache miss penalty)",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CYCLES_WAITING",
|
|
Packit |
577717 |
.udesc = "The number of cycles waiting for a cache hit (cache miss penalty).",
|
|
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_umask_t amd64_fam12h_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 |
static const amd64_umask_t amd64_fam12h_data_cache_refills[]={
|
|
Packit |
577717 |
{ .uname = "SYSTEM",
|
|
Packit |
577717 |
.udesc = "Refill from the Northbridge",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "L2_SHARED",
|
|
Packit |
577717 |
.udesc = "Shared-state line from L2",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "L2_EXCLUSIVE",
|
|
Packit |
577717 |
.udesc = "Exclusive-state line from L2",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "L2_OWNED",
|
|
Packit |
577717 |
.udesc = "Owned-state line from L2",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "L2_MODIFIED",
|
|
Packit |
577717 |
.udesc = "Modified-state line from L2",
|
|
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 |
static const amd64_umask_t amd64_fam12h_data_cache_refills_from_northbridge[]={
|
|
Packit |
577717 |
{ .uname = "INVALID",
|
|
Packit |
577717 |
.udesc = "Invalid",
|
|
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 |
static const amd64_umask_t amd64_fam12h_data_cache_lines_evicted[]={
|
|
Packit |
577717 |
{ .uname = "INVALID",
|
|
Packit |
577717 |
.udesc = "Invalid",
|
|
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 = "BY_PREFETCHNTA",
|
|
Packit |
577717 |
.udesc = "Cache line evicted was brought into the cache with by a PrefetchNTA instruction.",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "NOT_BY_PREFETCHNTA",
|
|
Packit |
577717 |
.udesc = "Cache line evicted was not brought into the cache with by a PrefetchNTA instruction.",
|
|
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 |
static const amd64_umask_t amd64_fam12h_l1_dtlb_miss_and_l2_dtlb_hit[]={
|
|
Packit |
577717 |
{ .uname = "L2_4K_TLB_HIT",
|
|
Packit |
577717 |
.udesc = "L2 4K TLB hit",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "L2_2M_TLB_HIT",
|
|
Packit |
577717 |
.udesc = "L2 2M TLB hit",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "L2_1G_TLB_HIT",
|
|
Packit |
577717 |
.udesc = "L2 1G TLB hit",
|
|
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 |
static const amd64_umask_t amd64_fam12h_l1_dtlb_and_l2_dtlb_miss[]={
|
|
Packit |
577717 |
{ .uname = "4K_TLB_RELOAD",
|
|
Packit |
577717 |
.udesc = "4K TLB reload",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "2M_TLB_RELOAD",
|
|
Packit |
577717 |
.udesc = "2M TLB reload",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "1G_TLB_RELOAD",
|
|
Packit |
577717 |
.udesc = "1G TLB reload",
|
|
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 |
static const amd64_umask_t amd64_fam12h_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 |
static const amd64_umask_t amd64_fam12h_dcache_misses_by_locked_instructions[]={
|
|
Packit |
577717 |
{ .uname = "DATA_CACHE_MISSES_BY_LOCKED_INSTRUCTIONS",
|
|
Packit |
577717 |
.udesc = "Data cache misses by locked instructions",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_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 = "L1_1G_TLB_HIT",
|
|
Packit |
577717 |
.udesc = "L1 1G TLB hit",
|
|
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 |
static const amd64_umask_t amd64_fam12h_ineffective_sw_prefetches[]={
|
|
Packit |
577717 |
{ .uname = "SW_PREFETCH_HIT_IN_L1",
|
|
Packit |
577717 |
.udesc = "Software prefetch hit in the L1.",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SW_PREFETCH_HIT_IN_L2",
|
|
Packit |
577717 |
.udesc = "Software prefetch hit in L2.",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x9,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_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 = "CACHE_DISABLED",
|
|
Packit |
577717 |
.udesc = "Requests to cache-disabled (CD) memory",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
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 = 0x87,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_data_prefetches[]={
|
|
Packit |
577717 |
{ .uname = "CANCELLED",
|
|
Packit |
577717 |
.udesc = "Cancelled prefetches",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ATTEMPTED",
|
|
Packit |
577717 |
.udesc = "Prefetch attempts",
|
|
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 |
static const amd64_umask_t amd64_fam12h_northbridge_read_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 = "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 |
static const amd64_umask_t amd64_fam12h_octwords_written_to_system[]={
|
|
Packit |
577717 |
{ .uname = "OCTWORD_WRITE_TRANSFER",
|
|
Packit |
577717 |
.udesc = "Octword write transfer",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_requests_to_l2[]={
|
|
Packit |
577717 |
{ .uname = "INSTRUCTIONS",
|
|
Packit |
577717 |
.udesc = "IC fill",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DATA",
|
|
Packit |
577717 |
.udesc = "DC fill",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "TLB_WALK",
|
|
Packit |
577717 |
.udesc = "TLB fill (page table walks)",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SNOOP",
|
|
Packit |
577717 |
.udesc = "Tag snoop request",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CANCELLED",
|
|
Packit |
577717 |
.udesc = "Cancelled request",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HW_PREFETCH_FROM_DC",
|
|
Packit |
577717 |
.udesc = "Hardware prefetch from DC",
|
|
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 |
static const amd64_umask_t amd64_fam12h_l2_cache_miss[]={
|
|
Packit |
577717 |
{ .uname = "INSTRUCTIONS",
|
|
Packit |
577717 |
.udesc = "IC fill",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DATA",
|
|
Packit |
577717 |
.udesc = "DC fill (includes possible replays, whereas EventSelect 041h does not)",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "TLB_WALK",
|
|
Packit |
577717 |
.udesc = "TLB page table walk",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HW_PREFETCH_FROM_DC",
|
|
Packit |
577717 |
.udesc = "Hardware prefetch from DC",
|
|
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_umask_t amd64_fam12h_l2_fill_writeback[]={
|
|
Packit |
577717 |
{ .uname = "L2_FILLS",
|
|
Packit |
577717 |
.udesc = "L2 fills (victims from L1 caches, TLB page table walks and data prefetches)",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "L2_WRITEBACKS",
|
|
Packit |
577717 |
.udesc = "L2 Writebacks to system.",
|
|
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 |
static const amd64_umask_t amd64_fam12h_l1_itlb_miss_and_l2_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 |
static const amd64_umask_t amd64_fam12h_instruction_cache_lines_invalidated[]={
|
|
Packit |
577717 |
{ .uname = "INVALIDATING_PROBE_NO_IN_FLIGHT",
|
|
Packit |
577717 |
.udesc = "Invalidating probe that did not hit any in-flight instructions.",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "INVALIDATING_PROBE_ONE_OR_MORE_IN_FLIGHT",
|
|
Packit |
577717 |
.udesc = "Invalidating probe that hit one or more in-flight instructions.",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SMC_NO_INFLIGHT",
|
|
Packit |
577717 |
.udesc = "SMC that did not hit any in-flight instructions.",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SMC_INFLIGHT",
|
|
Packit |
577717 |
.udesc = "SMC that hit one or more in-flight instructions.",
|
|
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_umask_t amd64_fam12h_retired_mmx_and_fp_instructions[]={
|
|
Packit |
577717 |
{ .uname = "X87",
|
|
Packit |
577717 |
.udesc = "X87 instructions",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MMX_AND_3DNOW",
|
|
Packit |
577717 |
.udesc = "MMX and 3DNow! instructions",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SSE_AND_SSE2",
|
|
Packit |
577717 |
.udesc = "SSE and SSE2 instructions",
|
|
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 |
static const amd64_umask_t amd64_fam12h_interrupt_events[]={
|
|
Packit |
577717 |
{ .uname = "FIXED_AND_LPA",
|
|
Packit |
577717 |
.udesc = "Fixed and LPA",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "LPA",
|
|
Packit |
577717 |
.udesc = "LPA",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SMI",
|
|
Packit |
577717 |
.udesc = "SMI",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "NMI",
|
|
Packit |
577717 |
.udesc = "NMI",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "INIT",
|
|
Packit |
577717 |
.udesc = "INIT",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "STARTUP",
|
|
Packit |
577717 |
.udesc = "STARTUP",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "INT",
|
|
Packit |
577717 |
.udesc = "INT",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "EOI",
|
|
Packit |
577717 |
.udesc = "EOI",
|
|
Packit |
577717 |
.ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xff,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_sideband_signals[]={
|
|
Packit |
577717 |
{ .uname = "STOPGRANT",
|
|
Packit |
577717 |
.udesc = "STOPGRANT",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SHUTDOWN",
|
|
Packit |
577717 |
.udesc = "SHUTDOWN",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "WBINVD",
|
|
Packit |
577717 |
.udesc = "WBINVD",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "INVD",
|
|
Packit |
577717 |
.udesc = "INVD",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x1e,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_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_umask_t amd64_fam12h_dram_accesses_page[]={
|
|
Packit |
577717 |
{ .uname = "DCT0_HIT",
|
|
Packit |
577717 |
.udesc = "DCT0 Page hit",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT0_MISS",
|
|
Packit |
577717 |
.udesc = "DCT0 Page Miss",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT0_CONFLICT",
|
|
Packit |
577717 |
.udesc = "DCT0 Page Conflict",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT1_PAGE_HIT",
|
|
Packit |
577717 |
.udesc = "DCT1 Page hit",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT1_PAGE_MISS",
|
|
Packit |
577717 |
.udesc = "DCT1 Page Miss",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT1_PAGE_CONFLICT",
|
|
Packit |
577717 |
.udesc = "DCT1 Page Conflict",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "WRITE_REQUEST",
|
|
Packit |
577717 |
.udesc = "Write request.",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_REQUEST",
|
|
Packit |
577717 |
.udesc = "Read request.",
|
|
Packit |
577717 |
.ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xff,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_memory_controller_page_table_events[]={
|
|
Packit |
577717 |
{ .uname = "PAGE_TABLE_OVERFLOW",
|
|
Packit |
577717 |
.udesc = "Page Table Overflow",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "STALE_TABLE_ENTRY_HITS",
|
|
Packit |
577717 |
.udesc = "Number of stale table entry hits. (hit on a page closed too soon).",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "PAGE_TABLE_IDLE_CYCLE_LIMIT_INCREMENTED",
|
|
Packit |
577717 |
.udesc = "Page table idle cycle limit incremented.",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "PAGE_TABLE_IDLE_CYCLE_LIMIT_DECREMENTED",
|
|
Packit |
577717 |
.udesc = "Page table idle cycle limit decremented.",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "PAGE_TABLE_CLOSED_INACTIVITY",
|
|
Packit |
577717 |
.udesc = "Page table is closed due to row inactivity.",
|
|
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 |
static const amd64_umask_t amd64_fam12h_memory_controller_slot_misses[]={
|
|
Packit |
577717 |
{ .uname = "DCT0_RBD",
|
|
Packit |
577717 |
.udesc = "DCT0 RBD.",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT1_RBD",
|
|
Packit |
577717 |
.udesc = "DCT1 RBD.",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT0_PREFETCH",
|
|
Packit |
577717 |
.udesc = "DCT0 Prefetch.",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT1_PREFETCH",
|
|
Packit |
577717 |
.udesc = "DCT1 Prefetch.",
|
|
Packit |
577717 |
.ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xf0,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_memory_controller_turnarounds[]={
|
|
Packit |
577717 |
{ .uname = "DCT0_READ_TO_WRITE",
|
|
Packit |
577717 |
.udesc = "DCT0 read-to-write turnaround.",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT0_WRITE_TO_READ",
|
|
Packit |
577717 |
.udesc = "DCT0 write-to-read turnaround",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT1_READ_TO_WRITE",
|
|
Packit |
577717 |
.udesc = "DCT1 read-to-write turnaround.",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCT1_WRITE_TO_READ",
|
|
Packit |
577717 |
.udesc = "DCT1 write-to-read turnaround",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x1b,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_memory_rbd_queue[]={
|
|
Packit |
577717 |
{ .uname = "COUNTER_REACHED",
|
|
Packit |
577717 |
.udesc = "D18F2x[1,0]94[DcqBypassMax] counter reached.",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "BANK_CLOSED",
|
|
Packit |
577717 |
.udesc = "Bank is closed due to bank conflict with an outstanding request in the RBD queue.",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xc,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_thermal_status[]={
|
|
Packit |
577717 |
{ .uname = "MEMHOT_L_ASSERTIONS",
|
|
Packit |
577717 |
.udesc = "MEMHOT_L assertions.",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HTC_TRANSITIONS",
|
|
Packit |
577717 |
.udesc = "Number of times the HTC transitions from inactive to active.",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CLOCKS_HTC_P_STATE_INACTIVE",
|
|
Packit |
577717 |
.udesc = "Number of clocks HTC P-state is inactive.",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CLOCKS_HTC_P_STATE_ACTIVE",
|
|
Packit |
577717 |
.udesc = "Number of clocks HTC P-state is active",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "PROCHOT_L_ASSERTIONS",
|
|
Packit |
577717 |
.udesc = "PROCHOT_L asserted by an external source and the assertion causes a P-state change.",
|
|
Packit |
577717 |
.ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xe5,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_cpu_io_requests_to_memory_io[]={
|
|
Packit |
577717 |
{ .uname = "I_O_TO_I_O",
|
|
Packit |
577717 |
.udesc = "IO to IO",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "I_O_TO_MEM",
|
|
Packit |
577717 |
.udesc = "IO to Mem",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CPU_TO_I_O",
|
|
Packit |
577717 |
.udesc = "CPU to IO",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "CPU_TO_MEM",
|
|
Packit |
577717 |
.udesc = "CPU to Mem",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x0f,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_cache_block[]={
|
|
Packit |
577717 |
{ .uname = "VICTIM_WRITEBACK",
|
|
Packit |
577717 |
.udesc = "Victim Block (Writeback)",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DCACHE_LOAD_MISS",
|
|
Packit |
577717 |
.udesc = "Read Block (Dcache load miss refill)",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "SHARED_ICACHE_REFILL",
|
|
Packit |
577717 |
.udesc = "Read Block Shared (Icache refill)",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_BLOCK_MODIFIED",
|
|
Packit |
577717 |
.udesc = "Read Block Modified (Dcache store miss refill)",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_TO_DIRTY",
|
|
Packit |
577717 |
.udesc = "Change-to-Dirty (first store to clean block already in cache)",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x3d,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_sized_commands[]={
|
|
Packit |
577717 |
{ .uname = "NON_POSTED_WRITE_BYTE",
|
|
Packit |
577717 |
.udesc = "Non-Posted SzWr Byte (1-32 bytes) Legacy or mapped IO, typically 1-4 bytes",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "NON_POSTED_WRITE_DWORD",
|
|
Packit |
577717 |
.udesc = "Non-Posted SzWr DW (1-16 dwords) Legacy or mapped IO, typically 1 DWORD",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "POSTED_WRITE_BYTE",
|
|
Packit |
577717 |
.udesc = "Posted SzWr Byte (1-32 bytes) Subcache-line DMA writes, size varies; also flushes of partially-filled Write Combining buffer",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "POSTED_WRITE_DWORD",
|
|
Packit |
577717 |
.udesc = "Posted SzWr DW (1-16 dwords) Block-oriented DMA writes, often cache-line sized; also processor Write Combining buffer flushes",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_BYTE_4_BYTES",
|
|
Packit |
577717 |
.udesc = "SzRd Byte (4 bytes) Legacy or mapped IO",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "READ_DWORD_1_16_DWORDS",
|
|
Packit |
577717 |
.udesc = "SzRd DW (1-16 dwords) Block-oriented DMA reads, typically cache-line size",
|
|
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 |
static const amd64_umask_t amd64_fam12h_probe[]={
|
|
Packit |
577717 |
{ .uname = "MISS",
|
|
Packit |
577717 |
.udesc = "Probe miss",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HIT_CLEAN",
|
|
Packit |
577717 |
.udesc = "Probe hit clean",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HIT_DIRTY_NO_MEMORY_CANCEL",
|
|
Packit |
577717 |
.udesc = "Probe hit dirty without memory cancel (probed by Sized Write or Change2Dirty)",
|
|
Packit |
577717 |
.ucode = 0x4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HIT_DIRTY_WITH_MEMORY_CANCEL",
|
|
Packit |
577717 |
.udesc = "Probe hit dirty with memory cancel (probed by DMA read or cache refill request)",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "UPSTREAM_HIGH_PRIORITY_READS",
|
|
Packit |
577717 |
.udesc = "Upstream high priority reads.",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "UPSTREAM_LOW_PRIORITY_READS",
|
|
Packit |
577717 |
.udesc = "Upstream low priority reads.",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "UPSTREAM_LOW_PRIORITY_WRITES",
|
|
Packit |
577717 |
.udesc = "Upstream low priority writes.",
|
|
Packit |
577717 |
.ucode = 0x80,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0xbf,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_dev[]={
|
|
Packit |
577717 |
{ .uname = "DEV_HIT",
|
|
Packit |
577717 |
.udesc = "DEV hit",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DEV_MISS",
|
|
Packit |
577717 |
.udesc = "DEV miss",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DEV_ERROR",
|
|
Packit |
577717 |
.udesc = "DEV error",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x70,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_memory_controller_requests[]={
|
|
Packit |
577717 |
{ .uname = "32_BYTES_WRITES",
|
|
Packit |
577717 |
.udesc = "32 Bytes Sized Writes",
|
|
Packit |
577717 |
.ucode = 0x8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "64_BYTES_WRITES",
|
|
Packit |
577717 |
.udesc = "64 Bytes Sized Writes",
|
|
Packit |
577717 |
.ucode = 0x10,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "32_BYTES_READS",
|
|
Packit |
577717 |
.udesc = "32 Bytes Sized Reads",
|
|
Packit |
577717 |
.ucode = 0x20,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "64_BYTES_READS",
|
|
Packit |
577717 |
.udesc = "64 Byte Sized Reads",
|
|
Packit |
577717 |
.ucode = 0x40,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "ALL",
|
|
Packit |
577717 |
.udesc = "All sub-events selected",
|
|
Packit |
577717 |
.ucode = 0x78,
|
|
Packit |
577717 |
.uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|
|
Packit |
577717 |
|
|
Packit |
577717 |
static const amd64_umask_t amd64_fam12h_page_size_mismatches[]={
|
|
Packit |
577717 |
{ .uname = "GUEST_LARGER",
|
|
Packit |
577717 |
.udesc = "Guest page size is larger than the host page size.",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MTRR_MISMATCH",
|
|
Packit |
577717 |
.udesc = "MTRR mismatch.",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "HOST_LARGER",
|
|
Packit |
577717 |
.udesc = "Host page size is larger than the guest page size.",
|
|
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 |
static const amd64_umask_t amd64_fam12h_retired_x87_ops[]={
|
|
Packit |
577717 |
{ .uname = "ADD_SUB_OPS",
|
|
Packit |
577717 |
.udesc = "Add/subtract ops",
|
|
Packit |
577717 |
.ucode = 0x1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "MUL_OPS",
|
|
Packit |
577717 |
.udesc = "Multiply ops",
|
|
Packit |
577717 |
.ucode = 0x2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .uname = "DIV_OPS",
|
|
Packit |
577717 |
.udesc = "Divide ops",
|
|
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 |
static const amd64_entry_t amd64_fam12h_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_fam12h_dispatched_fpu),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_dispatched_fpu,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "CYCLES_NO_FPU_OPS_RETIRED",
|
|
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_OPERATIONS",
|
|
Packit |
577717 |
.desc = "Retired SSE Operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x3,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_retired_sse_operations),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_retired_sse_operations,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "RETIRED_MOVE_OPS",
|
|
Packit |
577717 |
.desc = "Retired Move Ops",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x4,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_retired_move_ops),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_retired_move_ops,
|
|
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_fam12h_retired_serializing_ops),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_retired_serializing_ops,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "FP_SCHEDULER_CYCLES",
|
|
Packit |
577717 |
.desc = "Number of Cycles that a Serializing uop is in the FP Scheduler",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x6,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_fp_scheduler_cycles),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_fp_scheduler_cycles,
|
|
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_fam12h_segment_register_loads),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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 |
},
|
|
Packit |
577717 |
{ .name = "LS_BUFFER_2_FULL_CYCLES",
|
|
Packit |
577717 |
.desc = "LS Buffer 2 Full",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x23,
|
|
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_fam12h_locked_ops),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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 = "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_fam12h_cancelled_store_to_load_forward_operations),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_cancelled_store_to_load_forward_operations,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "SMIS_RECEIVED",
|
|
Packit |
577717 |
.desc = "SMIs Received",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x2b,
|
|
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_fam12h_data_cache_refills),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_data_cache_refills,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_CACHE_REFILLS_FROM_SYSTEM",
|
|
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_fam12h_data_cache_refills_from_northbridge),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_data_cache_refills_from_northbridge,
|
|
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_fam12h_data_cache_lines_evicted),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_l1_dtlb_miss_and_l2_dtlb_hit),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_l1_dtlb_miss_and_l2_dtlb_hit,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "L1_DTLB_AND_L2_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_fam12h_l1_dtlb_and_l2_dtlb_miss),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_l1_dtlb_and_l2_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 |
},
|
|
Packit |
577717 |
{ .name = "MICROARCHITECTURAL_LATE_CANCEL_OF_AN_ACCESS",
|
|
Packit |
577717 |
.desc = "Microarchitectural Late Cancel of an Access",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x48,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MICROARCHITECTURAL_EARLY_CANCEL_OF_AN_ACCESS",
|
|
Packit |
577717 |
.desc = "Microarchitectural Early Cancel of an Access",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x49,
|
|
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_fam12h_prefetch_instructions_dispatched),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_dcache_misses_by_locked_instructions),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_dcache_misses_by_locked_instructions,
|
|
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_fam12h_l1_dtlb_hit),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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_fam12h_ineffective_sw_prefetches),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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 |
{ .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_fam12h_memory_requests),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_memory_requests,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DATA_PREFETCHES",
|
|
Packit |
577717 |
.desc = "Data Prefetcher",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x67,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_data_prefetches),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_data_prefetches,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "NORTHBRIDGE_READ_RESPONSES",
|
|
Packit |
577717 |
.desc = "Northbridge Read Responses by Coherency State",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x6c,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_northbridge_read_responses),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_northbridge_read_responses,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "OCTWORDS_WRITTEN_TO_SYSTEM",
|
|
Packit |
577717 |
.desc = "Octwords Written to System",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x6d,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_octwords_written_to_system),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_octwords_written_to_system,
|
|
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 = "REQUESTS_TO_L2",
|
|
Packit |
577717 |
.desc = "Requests to L2 Cache",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x7d,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_requests_to_l2),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_requests_to_l2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "L2_CACHE_MISS",
|
|
Packit |
577717 |
.desc = "L2 Cache Misses",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x7e,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_l2_cache_miss),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_l2_cache_miss,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "L2_FILL_WRITEBACK",
|
|
Packit |
577717 |
.desc = "L2 Fill/Writeback",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x7f,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_l2_fill_writeback),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_l2_fill_writeback,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "PAGE_SIZE_MISMATCHES",
|
|
Packit |
577717 |
.desc = "Page Size Mismatches",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x165,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_page_size_mismatches),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_page_size_mismatches,
|
|
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 = "L1_ITLB_MISS_AND_L2_ITLB_MISS",
|
|
Packit |
577717 |
.desc = "L1 ITLB Miss and L2 ITLB Miss",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x85,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_l1_itlb_miss_and_l2_itlb_miss),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_l1_itlb_miss_and_l2_itlb_miss,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "PIPELINE_RESTART_DUE_TO_INSTRUCTION_STREAM_PROBE",
|
|
Packit |
577717 |
.desc = "Pipeline Restart Due to Instruction Stream Probe",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x86,
|
|
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_fam12h_instruction_cache_lines_invalidated),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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_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_INDIRECT_BRANCHES_MISPREDICTED",
|
|
Packit |
577717 |
.desc = "Retired Indirect Branches Mispredicted",
|
|
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_fam12h_retired_mmx_and_fp_instructions),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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 = "DECODER_EMPTY",
|
|
Packit |
577717 |
.desc = "Decoder Empty",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd0,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALLS",
|
|
Packit |
577717 |
.desc = "Dispatch Stalls",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd1,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_FOR_BRANCH_ABORT",
|
|
Packit |
577717 |
.desc = "Dispatch Stall for Branch Abort to Retire",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd2,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_FOR_SERIALIZATION",
|
|
Packit |
577717 |
.desc = "Dispatch Stall for Serialization",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd3,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_FOR_SEGMENT_LOAD",
|
|
Packit |
577717 |
.desc = "Dispatch Stall for Segment Load",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_FOR_REORDER_BUFFER_FULL",
|
|
Packit |
577717 |
.desc = "Dispatch Stall for Reorder Buffer Full",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd5,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_FOR_RESERVATION_STATION_FULL",
|
|
Packit |
577717 |
.desc = "Dispatch Stall for Reservation Station Full",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd6,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_FOR_FPU_FULL",
|
|
Packit |
577717 |
.desc = "Dispatch Stall for FPU Full",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd7,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_FOR_LS_FULL",
|
|
Packit |
577717 |
.desc = "Dispatch Stall for LS Full",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd8,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_WAITING_FOR_ALL_QUIET",
|
|
Packit |
577717 |
.desc = "Dispatch Stall Waiting for All Quiet",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xd9,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DISPATCH_STALL_FOR_FAR_TRANSFER_OR_RSYNC",
|
|
Packit |
577717 |
.desc = "Dispatch Stall for Far Transfer or Resync to Retire",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xda,
|
|
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_fam12h_fpu_exceptions),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_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 = "RETIRED_X87_OPS",
|
|
Packit |
577717 |
.desc = "Retired x87 Floating Point Operations",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1c0,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_retired_x87_ops),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_retired_x87_ops,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "LFENCE_INST_RETIRED",
|
|
Packit |
577717 |
.desc = "LFENCE Instructions Retired",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1d3,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "SFENCE_INST_RETIRED",
|
|
Packit |
577717 |
.desc = "SFENCE Instructions Retired",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1d4,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MFENCE_INST_RETIRED",
|
|
Packit |
577717 |
.desc = "MFENCE Instructions Retired",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1d5,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DRAM_ACCESSES_PAGE",
|
|
Packit |
577717 |
.desc = "DRAM Accesses",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xe0,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_dram_accesses_page),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_dram_accesses_page,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MEMORY_CONTROLLER_0_PAGE",
|
|
Packit |
577717 |
.desc = "DRAM Controller 0 Page Table Events",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xe1,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_memory_controller_page_table_events),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_memory_controller_page_table_events,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MEMORY_CONTROLLER_SLOT_MISSES",
|
|
Packit |
577717 |
.desc = "Memory Controller DRAM Command Slots Missed",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xe2,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_memory_controller_slot_misses),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_memory_controller_slot_misses,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MEMORY_CONTROLLER_TURNAROUNDS",
|
|
Packit |
577717 |
.desc = "Memory Controller Turnarounds",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xe3,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_memory_controller_turnarounds),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_memory_controller_turnarounds,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MEMORY_CONTROLLER_RBD_QUEUE",
|
|
Packit |
577717 |
.desc = "Memory Controller RBD Queue Events",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xe4,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_memory_rbd_queue),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_memory_rbd_queue,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MEMORY_CONTROLLER_1_PAGE",
|
|
Packit |
577717 |
.desc = "DRAM Controller 1 Page Table Events",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xe5,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_memory_controller_page_table_events),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_memory_controller_page_table_events,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "THERMAL_STATUS",
|
|
Packit |
577717 |
.desc = "Thermal Status",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xe8,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_thermal_status),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_thermal_status,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "CPU_IO_REQUESTS_TO_MEMORY_IO",
|
|
Packit |
577717 |
.desc = "CPU/IO Requests to Memory/IO",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xe9,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_cpu_io_requests_to_memory_io),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_cpu_io_requests_to_memory_io,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "CACHE_BLOCK",
|
|
Packit |
577717 |
.desc = "Cache Block Commands",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xea,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_cache_block),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_cache_block,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "SIZED_COMMANDS",
|
|
Packit |
577717 |
.desc = "Sized Commands",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xeb,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_sized_commands),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_sized_commands,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "PROBE",
|
|
Packit |
577717 |
.desc = "Probe Responses and Upstream Requests",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xec,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_probe),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_probe,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "DEV",
|
|
Packit |
577717 |
.desc = "DEV Events",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0xee,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_dev),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_dev,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "MEMORY_CONTROLLER_REQUESTS",
|
|
Packit |
577717 |
.desc = "Memory Controller Requests",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1f0,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_memory_controller_requests),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_memory_controller_requests,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "SIDEBAND_SIGNALS",
|
|
Packit |
577717 |
.desc = "Sideband Signals and Special Cycles",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1e9,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_sideband_signals),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_sideband_signals,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
{ .name = "INTERRUPT_EVENTS",
|
|
Packit |
577717 |
.desc = "Interrupt Events",
|
|
Packit |
577717 |
.modmsk = AMD64_FAM10H_ATTRS,
|
|
Packit |
577717 |
.code = 0x1ea,
|
|
Packit |
577717 |
.numasks = LIBPFM_ARRAY_SIZE(amd64_fam12h_interrupt_events),
|
|
Packit |
577717 |
.ngrp = 1,
|
|
Packit |
577717 |
.umasks = amd64_fam12h_interrupt_events,
|
|
Packit |
577717 |
},
|
|
Packit |
577717 |
};
|