Blame src/libpfm4/lib/events/amd64_events_k8.h

Packit 577717
/*
Packit 577717
 * Copyright (c) 2011 Google, Inc
Packit 577717
 * Contributed by Stephane Eranian <eranian@gmail.com>
Packit 577717
 *
Packit 577717
 * Regenerated from previous version by:
Packit 577717
 *
Packit 577717
 * Copyright (c) 2006, 2007 Advanced Micro Devices, Inc.
Packit 577717
 * Contributed by Ray Bryant <raybry@mpdtxmail.amd.com> 
Packit 577717
 * Contributed by Robert Richter <robert.richter@amd.com>
Packit 577717
 *
Packit 577717
 * Permission is hereby granted, free of charge, to any person obtaining a copy
Packit 577717
 * of this software and associated documentation files (the "Software"), to deal
Packit 577717
 * in the Software without restriction, including without limitation the rights
Packit 577717
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
Packit 577717
 * of the Software, and to permit persons to whom the Software is furnished to do so,
Packit 577717
 * subject to the following conditions:
Packit 577717
 *
Packit 577717
 * The above copyright notice and this permission notice shall be included in all
Packit 577717
 * copies or substantial portions of the Software.
Packit 577717
 *
Packit 577717
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
Packit 577717
 * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
Packit 577717
 * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
Packit 577717
 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
Packit 577717
 * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
Packit 577717
 * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Packit 577717
 *
Packit 577717
 * This file is part of libpfm, a performance monitoring support library for
Packit 577717
 * applications on Linux.
Packit 577717
 *
Packit 577717
 * This file has been automatically generated.
Packit 577717
 *
Packit 577717
 * PMU: amd64_k8 (AMD64 K8)
Packit 577717
 */
Packit 577717
Packit 577717
/* History
Packit 577717
 *
Packit 577717
 * Feb 10 2006 -- Ray Bryant, raybry@mpdtxmail.amd.com
Packit 577717
 *
Packit 577717
 * Brought event table up-to-date with the 3.85 (October 2005) version of the
Packit 577717
 * "BIOS and Kernel Developer's Guide for the AMD Athlon[tm] 64 and
Packit 577717
 * AMD Opteron[tm] Processors," AMD Publication # 26094.
Packit 577717
 * 
Packit 577717
 * Dec 12 2007 -- Robert Richter, robert.richter@amd.com
Packit 577717
 *
Packit 577717
 * Updated to: BIOS and Kernel Developer's Guide for AMD NPT Family
Packit 577717
 * 0Fh Processors, Publication # 32559, Revision: 3.08, Issue Date:
Packit 577717
 * July 2007
Packit 577717
 * 
Packit 577717
 * Feb 26 2009 -- Robert Richter, robert.richter@amd.com
Packit 577717
 *
Packit 577717
 * Updates and fixes of some revision flags and descriptions according
Packit 577717
 * to these documents:
Packit 577717
 * BIOS and Kernel Developer's Guide, #26094, Revision: 3.30
Packit 577717
 * BIOS and Kernel Developer's Guide, #32559, Revision: 3.12
Packit 577717
 */
Packit 577717
Packit 577717
static const amd64_umask_t amd64_k8_dispatched_fpu[]={
Packit 577717
   { .uname  = "OPS_ADD",
Packit 577717
     .udesc  = "Add pipe ops",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "OPS_MULTIPLY",
Packit 577717
     .udesc  = "Multiply pipe ops",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "OPS_STORE",
Packit 577717
     .udesc  = "Store pipe ops",
Packit 577717
     .ucode = 0x4,
Packit 577717
   },
Packit 577717
   { .uname  = "OPS_ADD_PIPE_LOAD_OPS",
Packit 577717
     .udesc  = "Add pipe load ops",
Packit 577717
     .ucode = 0x8,
Packit 577717
   },
Packit 577717
   { .uname  = "OPS_MULTIPLY_PIPE_LOAD_OPS",
Packit 577717
     .udesc  = "Multiply pipe load ops",
Packit 577717
     .ucode = 0x10,
Packit 577717
   },
Packit 577717
   { .uname  = "OPS_STORE_PIPE_LOAD_OPS",
Packit 577717
     .udesc  = "Store pipe load 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_k8_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 segments",
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_k8_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  = "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_k8_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
static const amd64_umask_t amd64_k8_data_cache_refills[]={
Packit 577717
   { .uname  = "SYSTEM",
Packit 577717
     .udesc  = "Refill from System",
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  = "Shared, Exclusive, Owned, Modified State Refills",
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_k8_data_cache_refills_from_system[]={
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  = "Invalid, Shared, Exclusive, Owned, Modified",
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_k8_scrubber_single_bit_ecc_errors[]={
Packit 577717
   { .uname  = "SCRUBBER_ERROR",
Packit 577717
     .udesc  = "Scrubber error",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "PIGGYBACK_ERROR",
Packit 577717
     .udesc  = "Piggyback scrubber errors",
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_k8_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_k8_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_k8_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_k8_system_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  = "ALL",
Packit 577717
     .udesc  = "Exclusive, Modified, Shared",
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_k8_quadwords_written_to_system[]={
Packit 577717
   { .uname  = "QUADWORD_WRITE_TRANSFER",
Packit 577717
     .udesc  = "Quadword 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_k8_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  = "ALL",
Packit 577717
     .udesc  = "All non-cancelled requests",
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_k8_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 event 41h 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  = "ALL",
Packit 577717
     .udesc  = "Instructions, Data, TLB walk",
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_k8_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  = "ALL",
Packit 577717
     .udesc  = "All sub-events selected",
Packit 577717
     .ucode = 0x1,
Packit 577717
     .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL | AMD64_FL_TILL_K8_REV_E,
Packit 577717
   },
Packit 577717
   { .uname  = "L2_WRITEBACKS",
Packit 577717
     .udesc  = "L2 Writebacks to system.",
Packit 577717
     .ucode = 0x2,
Packit 577717
     .uflags= AMD64_FL_K8_REV_F,
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 | AMD64_FL_K8_REV_F,
Packit 577717
   },
Packit 577717
};
Packit 577717
Packit 577717
static const amd64_umask_t amd64_k8_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  = "PACKED_SSE_AND_SSE2",
Packit 577717
     .udesc  = "Packed SSE and SSE2 instructions",
Packit 577717
     .ucode = 0x4,
Packit 577717
   },
Packit 577717
   { .uname  = "SCALAR_SSE_AND_SSE2",
Packit 577717
     .udesc  = "Scalar SSE and SSE2 instructions",
Packit 577717
     .ucode = 0x8,
Packit 577717
   },
Packit 577717
   { .uname  = "ALL",
Packit 577717
     .udesc  = "X87, MMX(TM), 3DNow!(TM), Scalar and Packed SSE and SSE2 instructions",
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_k8_retired_fastpath_double_op_instructions[]={
Packit 577717
   { .uname  = "POSITION_0",
Packit 577717
     .udesc  = "With low op in position 0",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "POSITION_1",
Packit 577717
     .udesc  = "With low op in position 1",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "POSITION_2",
Packit 577717
     .udesc  = "With low op in position 2",
Packit 577717
     .ucode = 0x4,
Packit 577717
   },
Packit 577717
   { .uname  = "ALL",
Packit 577717
     .udesc  = "With low op in position 0, 1, or 2",
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_k8_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_k8_dram_accesses_page[]={
Packit 577717
   { .uname  = "HIT",
Packit 577717
     .udesc  = "Page hit",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "MISS",
Packit 577717
     .udesc  = "Page Miss",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "CONFLICT",
Packit 577717
     .udesc  = "Page Conflict",
Packit 577717
     .ucode = 0x4,
Packit 577717
   },
Packit 577717
   { .uname  = "ALL",
Packit 577717
     .udesc  = "Page Hit, Miss, or Conflict",
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_k8_memory_controller_turnarounds[]={
Packit 577717
   { .uname  = "CHIP_SELECT",
Packit 577717
     .udesc  = "DIMM (chip select) turnaround",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "READ_TO_WRITE",
Packit 577717
     .udesc  = "Read to write turnaround",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "WRITE_TO_READ",
Packit 577717
     .udesc  = "Write to read turnaround",
Packit 577717
     .ucode = 0x4,
Packit 577717
   },
Packit 577717
   { .uname  = "ALL",
Packit 577717
     .udesc  = "All Memory Controller Turnarounds",
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_k8_memory_controller_bypass[]={
Packit 577717
   { .uname  = "HIGH_PRIORITY",
Packit 577717
     .udesc  = "Memory controller high priority bypass",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "LOW_PRIORITY",
Packit 577717
     .udesc  = "Memory controller low priority bypass",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "DRAM_INTERFACE",
Packit 577717
     .udesc  = "DRAM controller interface bypass",
Packit 577717
     .ucode = 0x4,
Packit 577717
   },
Packit 577717
   { .uname  = "DRAM_QUEUE",
Packit 577717
     .udesc  = "DRAM controller queue bypass",
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_k8_sized_blocks[]={
Packit 577717
   { .uname  = "32_BYTE_WRITES",
Packit 577717
     .udesc  = "32-byte Sized Writes",
Packit 577717
     .ucode = 0x4,
Packit 577717
   },
Packit 577717
   { .uname  = "64_BYTE_WRITES",
Packit 577717
     .udesc  = "64-byte Sized Writes",
Packit 577717
     .ucode = 0x8,
Packit 577717
   },
Packit 577717
   { .uname  = "32_BYTE_READS",
Packit 577717
     .udesc  = "32-byte Sized Reads",
Packit 577717
     .ucode = 0x10,
Packit 577717
   },
Packit 577717
   { .uname  = "64_BYTE_READS",
Packit 577717
     .udesc  = "64-byte Sized Reads",
Packit 577717
     .ucode = 0x20,
Packit 577717
   },
Packit 577717
   { .uname  = "ALL",
Packit 577717
     .udesc  = "All sub-events selected",
Packit 577717
     .ucode = 0x3c,
Packit 577717
     .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL,
Packit 577717
   },
Packit 577717
};
Packit 577717
Packit 577717
static const amd64_umask_t amd64_k8_thermal_status_and_ecc_errors[]={
Packit 577717
   { .uname  = "CLKS_CPU_ACTIVE",
Packit 577717
     .udesc  = "Number of clocks CPU is active when HTC is active",
Packit 577717
     .ucode = 0x1,
Packit 577717
     .uflags= AMD64_FL_K8_REV_F,
Packit 577717
   },
Packit 577717
   { .uname  = "CLKS_CPU_INACTIVE",
Packit 577717
     .udesc  = "Number of clocks CPU clock is inactive when HTC is active",
Packit 577717
     .ucode = 0x2,
Packit 577717
     .uflags= AMD64_FL_K8_REV_F,
Packit 577717
   },
Packit 577717
   { .uname  = "CLKS_DIE_TEMP_TOO_HIGH",
Packit 577717
     .udesc  = "Number of clocks when die temperature is higher than the software high temperature threshold",
Packit 577717
     .ucode = 0x4,
Packit 577717
     .uflags= AMD64_FL_K8_REV_F,
Packit 577717
   },
Packit 577717
   { .uname  = "CLKS_TEMP_THRESHOLD_EXCEEDED",
Packit 577717
     .udesc  = "Number of clocks when high temperature threshold was exceeded",
Packit 577717
     .ucode = 0x8,
Packit 577717
     .uflags= AMD64_FL_K8_REV_F,
Packit 577717
   },
Packit 577717
   { .uname  = "DRAM_ECC_ERRORS",
Packit 577717
     .udesc  = "Number of correctable and Uncorrectable DRAM ECC errors",
Packit 577717
     .ucode = 0x80,
Packit 577717
   },
Packit 577717
   { .uname  = "ALL",
Packit 577717
     .udesc  = "All sub-events selected",
Packit 577717
     .ucode = 0x80,
Packit 577717
     .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL | AMD64_FL_TILL_K8_REV_E,
Packit 577717
   },
Packit 577717
   { .uname  = "ALL",
Packit 577717
     .udesc  = "All sub-events selected",
Packit 577717
     .ucode = 0x8f,
Packit 577717
     .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL | AMD64_FL_K8_REV_F,
Packit 577717
   },
Packit 577717
};
Packit 577717
Packit 577717
static const amd64_umask_t amd64_k8_cpu_io_requests_to_memory_io[]={
Packit 577717
   { .uname  = "I_O_TO_I_O",
Packit 577717
     .udesc  = "I/O to I/O",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "I_O_TO_MEM",
Packit 577717
     .udesc  = "I/O to Mem",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "CPU_TO_I_O",
Packit 577717
     .udesc  = "CPU to I/O",
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  = "TO_REMOTE_NODE",
Packit 577717
     .udesc  = "To remote node",
Packit 577717
     .ucode = 0x10,
Packit 577717
   },
Packit 577717
   { .uname  = "TO_LOCAL_NODE",
Packit 577717
     .udesc  = "To local node",
Packit 577717
     .ucode = 0x20,
Packit 577717
   },
Packit 577717
   { .uname  = "FROM_REMOTE_NODE",
Packit 577717
     .udesc  = "From remote node",
Packit 577717
     .ucode = 0x40,
Packit 577717
   },
Packit 577717
   { .uname  = "FROM_LOCAL_NODE",
Packit 577717
     .udesc  = "From local node",
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_k8_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_k8_sized_commands[]={
Packit 577717
   { .uname  = "NON_POSTED_WRITE_BYTE",
Packit 577717
     .udesc  = "NonPosted SzWr Byte (1-32 bytes) Legacy or mapped I/O, typically 1-4 bytes",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "NON_POSTED_WRITE_DWORD",
Packit 577717
     .udesc  = "NonPosted SzWr Dword (1-16 dwords) Legacy or mapped I/O, typically 1 dword",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "POSTED_WRITE_BYTE",
Packit 577717
     .udesc  = "Posted SzWr Byte (1-32 bytes) Sub-cache-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 Dword (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 I/O",
Packit 577717
     .ucode = 0x10,
Packit 577717
   },
Packit 577717
   { .uname  = "READ_DWORD_1_16_DWORDS",
Packit 577717
     .udesc  = "SzRd Dword (1-16 dwords) Block-oriented DMA reads, typically cache-line size",
Packit 577717
     .ucode = 0x20,
Packit 577717
   },
Packit 577717
   { .uname  = "READ_MODIFY_WRITE",
Packit 577717
     .udesc  = "RdModWr",
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_k8_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_DISPLAY_REFRESH_READS",
Packit 577717
     .udesc  = "Upstream display refresh reads",
Packit 577717
     .ucode = 0x10,
Packit 577717
   },
Packit 577717
   { .uname  = "UPSTREAM_NON_DISPLAY_REFRESH_READS",
Packit 577717
     .udesc  = "Upstream non-display refresh reads",
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 | AMD64_FL_TILL_K8_REV_C,
Packit 577717
   },
Packit 577717
   { .uname  = "UPSTREAM_WRITES",
Packit 577717
     .udesc  = "Upstream writes",
Packit 577717
     .ucode = 0x40,
Packit 577717
     .uflags= AMD64_FL_K8_REV_D,
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 | AMD64_FL_K8_REV_D,
Packit 577717
   },
Packit 577717
};
Packit 577717
Packit 577717
static const amd64_umask_t amd64_k8_gart[]={
Packit 577717
   { .uname  = "APERTURE_HIT_FROM_CPU",
Packit 577717
     .udesc  = "GART aperture hit on access from CPU",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "APERTURE_HIT_FROM_IO",
Packit 577717
     .udesc  = "GART aperture hit on access from I/O",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "MISS",
Packit 577717
     .udesc  = "GART miss",
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_k8_hypertransport_link0[]={
Packit 577717
   { .uname  = "COMMAND_DWORD_SENT",
Packit 577717
     .udesc  = "Command dword sent",
Packit 577717
     .ucode = 0x1,
Packit 577717
   },
Packit 577717
   { .uname  = "DATA_DWORD_SENT",
Packit 577717
     .udesc  = "Data dword sent",
Packit 577717
     .ucode = 0x2,
Packit 577717
   },
Packit 577717
   { .uname  = "BUFFER_RELEASE_DWORD_SENT",
Packit 577717
     .udesc  = "Buffer release dword sent",
Packit 577717
     .ucode = 0x4,
Packit 577717
   },
Packit 577717
   { .uname  = "NOP_DWORD_SENT",
Packit 577717
     .udesc  = "Nop dword sent (idle)",
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_k8_pe[]={
Packit 577717
{ .name    = "DISPATCHED_FPU",
Packit 577717
  .desc    = "Dispatched FPU Operations",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x0,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_dispatched_fpu),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_dispatched_fpu,
Packit 577717
},
Packit 577717
{ .name    = "CYCLES_NO_FPU_OPS_RETIRED",
Packit 577717
  .desc    = "Cycles with no FPU Ops Retired",
Packit 577717
  .modmsk  = AMD64_BASIC_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_BASIC_ATTRS,
Packit 577717
  .code    = 0x2,
Packit 577717
},
Packit 577717
{ .name    = "SEGMENT_REGISTER_LOADS",
Packit 577717
  .desc    = "Segment Register Loads",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x20,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_segment_register_loads),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_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_BASIC_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_BASIC_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_BASIC_ATTRS,
Packit 577717
  .code    = 0x23,
Packit 577717
},
Packit 577717
{ .name    = "LOCKED_OPS",
Packit 577717
  .desc    = "Locked Operations",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x24,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_locked_ops),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_locked_ops,
Packit 577717
},
Packit 577717
{ .name    = "MEMORY_REQUESTS",
Packit 577717
  .desc    = "Memory Requests by Type",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x65,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_memory_requests),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_memory_requests,
Packit 577717
},
Packit 577717
{ .name    = "DATA_CACHE_ACCESSES",
Packit 577717
  .desc    = "Data Cache Accesses",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x40,
Packit 577717
},
Packit 577717
{ .name    = "DATA_CACHE_MISSES",
Packit 577717
  .desc    = "Data Cache Misses",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x41,
Packit 577717
},
Packit 577717
{ .name    = "DATA_CACHE_REFILLS",
Packit 577717
  .desc    = "Data Cache Refills from L2 or System",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x42,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_data_cache_refills),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_data_cache_refills,
Packit 577717
},
Packit 577717
{ .name    = "DATA_CACHE_REFILLS_FROM_SYSTEM",
Packit 577717
  .desc    = "Data Cache Refills from System",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x43,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_data_cache_refills_from_system),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_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_BASIC_ATTRS,
Packit 577717
  .code    = 0x44,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_data_cache_refills_from_system),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_data_cache_refills_from_system, /* identical to actual umasks list for this event */
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_BASIC_ATTRS,
Packit 577717
  .code    = 0x45,
Packit 577717
},
Packit 577717
{ .name    = "L1_DTLB_AND_L2_DTLB_MISS",
Packit 577717
  .desc    = "L1 DTLB and L2 DTLB Miss",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x46,
Packit 577717
},
Packit 577717
{ .name    = "MISALIGNED_ACCESSES",
Packit 577717
  .desc    = "Misaligned Accesses",
Packit 577717
  .modmsk  = AMD64_BASIC_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_BASIC_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_BASIC_ATTRS,
Packit 577717
  .code    = 0x49,
Packit 577717
},
Packit 577717
{ .name    = "SCRUBBER_SINGLE_BIT_ECC_ERRORS",
Packit 577717
  .desc    = "Single-bit ECC Errors Recorded by Scrubber",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x4a,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_scrubber_single_bit_ecc_errors),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_scrubber_single_bit_ecc_errors,
Packit 577717
},
Packit 577717
{ .name    = "PREFETCH_INSTRUCTIONS_DISPATCHED",
Packit 577717
  .desc    = "Prefetch Instructions Dispatched",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x4b,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_prefetch_instructions_dispatched),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_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_BASIC_ATTRS,
Packit 577717
  .code    = 0x4c,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_dcache_misses_by_locked_instructions),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_dcache_misses_by_locked_instructions,
Packit 577717
},
Packit 577717
{ .name    = "DATA_PREFETCHES",
Packit 577717
  .desc    = "Data Prefetcher",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x67,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_data_prefetches),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_data_prefetches,
Packit 577717
},
Packit 577717
{ .name    = "SYSTEM_READ_RESPONSES",
Packit 577717
  .desc    = "System Read Responses by Coherency State",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x6c,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_system_read_responses),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_system_read_responses,
Packit 577717
},
Packit 577717
{ .name    = "QUADWORDS_WRITTEN_TO_SYSTEM",
Packit 577717
  .desc    = "Quadwords Written to System",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x6d,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_quadwords_written_to_system),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_quadwords_written_to_system,
Packit 577717
},
Packit 577717
{ .name    = "REQUESTS_TO_L2",
Packit 577717
  .desc    = "Requests to L2 Cache",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x7d,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_requests_to_l2),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_requests_to_l2,
Packit 577717
},
Packit 577717
{ .name    = "L2_CACHE_MISS",
Packit 577717
  .desc    = "L2 Cache Misses",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x7e,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_l2_cache_miss),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_l2_cache_miss,
Packit 577717
},
Packit 577717
{ .name    = "L2_FILL_WRITEBACK",
Packit 577717
  .desc    = "L2 Fill/Writeback",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x7f,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_l2_fill_writeback),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_l2_fill_writeback,
Packit 577717
},
Packit 577717
{ .name    = "INSTRUCTION_CACHE_FETCHES",
Packit 577717
  .desc    = "Instruction Cache Fetches",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x80,
Packit 577717
},
Packit 577717
{ .name    = "INSTRUCTION_CACHE_MISSES",
Packit 577717
  .desc    = "Instruction Cache Misses",
Packit 577717
  .modmsk  = AMD64_BASIC_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_BASIC_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_BASIC_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_BASIC_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_BASIC_ATTRS,
Packit 577717
  .code    = 0x85,
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_BASIC_ATTRS,
Packit 577717
  .code    = 0x86,
Packit 577717
},
Packit 577717
{ .name    = "INSTRUCTION_FETCH_STALL",
Packit 577717
  .desc    = "Instruction Fetch Stall",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x87,
Packit 577717
},
Packit 577717
{ .name    = "RETURN_STACK_HITS",
Packit 577717
  .desc    = "Return Stack Hits",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x88,
Packit 577717
},
Packit 577717
{ .name    = "RETURN_STACK_OVERFLOWS",
Packit 577717
  .desc    = "Return Stack Overflows",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x89,
Packit 577717
},
Packit 577717
{ .name    = "RETIRED_CLFLUSH_INSTRUCTIONS",
Packit 577717
  .desc    = "Retired CLFLUSH Instructions",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x26,
Packit 577717
},
Packit 577717
{ .name    = "RETIRED_CPUID_INSTRUCTIONS",
Packit 577717
  .desc    = "Retired CPUID Instructions",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x27,
Packit 577717
},
Packit 577717
{ .name    = "CPU_CLK_UNHALTED",
Packit 577717
  .desc    = "CPU Clocks not Halted",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0x76,
Packit 577717
},
Packit 577717
{ .name    = "RETIRED_INSTRUCTIONS",
Packit 577717
  .desc    = "Retired Instructions",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xc0,
Packit 577717
},
Packit 577717
{ .name    = "RETIRED_UOPS",
Packit 577717
  .desc    = "Retired uops",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xc1,
Packit 577717
},
Packit 577717
{ .name    = "RETIRED_BRANCH_INSTRUCTIONS",
Packit 577717
  .desc    = "Retired Branch Instructions",
Packit 577717
  .modmsk  = AMD64_BASIC_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_BASIC_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_BASIC_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_BASIC_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_BASIC_ATTRS,
Packit 577717
  .code    = 0xc6,
Packit 577717
},
Packit 577717
{ .name    = "RETIRED_BRANCH_RESYNCS",
Packit 577717
  .desc    = "Retired Branch Resyncs",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xc7,
Packit 577717
},
Packit 577717
{ .name    = "RETIRED_NEAR_RETURNS",
Packit 577717
  .desc    = "Retired Near Returns",
Packit 577717
  .modmsk  = AMD64_BASIC_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_BASIC_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_BASIC_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_BASIC_ATTRS,
Packit 577717
  .code    = 0xcb,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_retired_mmx_and_fp_instructions),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_retired_mmx_and_fp_instructions,
Packit 577717
},
Packit 577717
{ .name    = "RETIRED_FASTPATH_DOUBLE_OP_INSTRUCTIONS",
Packit 577717
  .desc    = "Retired Fastpath Double Op Instructions",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xcc,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_retired_fastpath_double_op_instructions),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_retired_fastpath_double_op_instructions,
Packit 577717
},
Packit 577717
{ .name    = "INTERRUPTS_MASKED_CYCLES",
Packit 577717
  .desc    = "Interrupts-Masked Cycles",
Packit 577717
  .modmsk  = AMD64_BASIC_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_BASIC_ATTRS,
Packit 577717
  .code    = 0xce,
Packit 577717
},
Packit 577717
{ .name    = "INTERRUPTS_TAKEN",
Packit 577717
  .desc    = "Interrupts Taken",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xcf,
Packit 577717
},
Packit 577717
{ .name    = "DECODER_EMPTY",
Packit 577717
  .desc    = "Decoder Empty",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xd0,
Packit 577717
},
Packit 577717
{ .name    = "DISPATCH_STALLS",
Packit 577717
  .desc    = "Dispatch Stalls",
Packit 577717
  .modmsk  = AMD64_BASIC_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_BASIC_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_BASIC_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_BASIC_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_BASIC_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_BASIC_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_BASIC_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_BASIC_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_BASIC_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_BASIC_ATTRS,
Packit 577717
  .code    = 0xda,
Packit 577717
},
Packit 577717
{ .name    = "FPU_EXCEPTIONS",
Packit 577717
  .desc    = "FPU Exceptions",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xdb,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_fpu_exceptions),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_fpu_exceptions,
Packit 577717
},
Packit 577717
{ .name    = "DR0_BREAKPOINT_MATCHES",
Packit 577717
  .desc    = "DR0 Breakpoint Matches",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xdc,
Packit 577717
},
Packit 577717
{ .name    = "DR1_BREAKPOINT_MATCHES",
Packit 577717
  .desc    = "DR1 Breakpoint Matches",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xdd,
Packit 577717
},
Packit 577717
{ .name    = "DR2_BREAKPOINT_MATCHES",
Packit 577717
  .desc    = "DR2 Breakpoint Matches",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xde,
Packit 577717
},
Packit 577717
{ .name    = "DR3_BREAKPOINT_MATCHES",
Packit 577717
  .desc    = "DR3 Breakpoint Matches",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xdf,
Packit 577717
},
Packit 577717
{ .name    = "DRAM_ACCESSES_PAGE",
Packit 577717
  .desc    = "DRAM Accesses",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xe0,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_dram_accesses_page),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_dram_accesses_page,
Packit 577717
},
Packit 577717
{ .name    = "MEMORY_CONTROLLER_PAGE_TABLE_OVERFLOWS",
Packit 577717
  .desc    = "Memory Controller Page Table Overflows",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xe1,
Packit 577717
},
Packit 577717
{ .name    = "MEMORY_CONTROLLER_TURNAROUNDS",
Packit 577717
  .desc    = "Memory Controller Turnarounds",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xe3,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_memory_controller_turnarounds),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_memory_controller_turnarounds,
Packit 577717
},
Packit 577717
{ .name    = "MEMORY_CONTROLLER_BYPASS",
Packit 577717
  .desc    = "Memory Controller Bypass Counter Saturation",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xe4,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_memory_controller_bypass),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_memory_controller_bypass,
Packit 577717
},
Packit 577717
{ .name    = "SIZED_BLOCKS",
Packit 577717
  .desc    = "Sized Blocks",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xe5,
Packit 577717
  .flags   = AMD64_FL_K8_REV_D,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_sized_blocks),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_sized_blocks,
Packit 577717
},
Packit 577717
{ .name    = "THERMAL_STATUS_AND_ECC_ERRORS",
Packit 577717
  .desc    = "Thermal Status and ECC Errors",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xe8,
Packit 577717
  .flags   = AMD64_FL_K8_REV_E,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_thermal_status_and_ecc_errors),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_thermal_status_and_ecc_errors,
Packit 577717
},
Packit 577717
{ .name    = "CPU_IO_REQUESTS_TO_MEMORY_IO",
Packit 577717
  .desc    = "CPU/IO Requests to Memory/IO",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xe9,
Packit 577717
  .flags   = AMD64_FL_K8_REV_E,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_cpu_io_requests_to_memory_io),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_cpu_io_requests_to_memory_io,
Packit 577717
},
Packit 577717
{ .name    = "CACHE_BLOCK",
Packit 577717
  .desc    = "Cache Block Commands",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xea,
Packit 577717
  .flags   = AMD64_FL_K8_REV_E,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_cache_block),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_cache_block,
Packit 577717
},
Packit 577717
{ .name    = "SIZED_COMMANDS",
Packit 577717
  .desc    = "Sized Commands",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xeb,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_sized_commands),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_sized_commands,
Packit 577717
},
Packit 577717
{ .name    = "PROBE",
Packit 577717
  .desc    = "Probe Responses and Upstream Requests",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xec,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_probe),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_probe,
Packit 577717
},
Packit 577717
{ .name    = "GART",
Packit 577717
  .desc    = "GART Events",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xee,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_gart),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_gart,
Packit 577717
},
Packit 577717
{ .name    = "HYPERTRANSPORT_LINK0",
Packit 577717
  .desc    = "HyperTransport Link 0 Transmit Bandwidth",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xf6,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_hypertransport_link0),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_hypertransport_link0,
Packit 577717
},
Packit 577717
{ .name    = "HYPERTRANSPORT_LINK1",
Packit 577717
  .desc    = "HyperTransport Link 1 Transmit Bandwidth",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xf7,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_hypertransport_link0),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_hypertransport_link0, /* identical to actual umasks list for this event */
Packit 577717
},
Packit 577717
{ .name    = "HYPERTRANSPORT_LINK2",
Packit 577717
  .desc    = "HyperTransport Link 2 Transmit Bandwidth",
Packit 577717
  .modmsk  = AMD64_BASIC_ATTRS,
Packit 577717
  .code    = 0xf8,
Packit 577717
  .numasks = LIBPFM_ARRAY_SIZE(amd64_k8_hypertransport_link0),
Packit 577717
  .ngrp    = 1,
Packit 577717
  .umasks  = amd64_k8_hypertransport_link0, /* identical to actual umasks list for this event */
Packit 577717
},
Packit 577717
};