|  | /* | 
|  | * Copyright (c) 2011 Google, Inc | 
|  | * Contributed by Stephane Eranian <eranian@gmail.com> | 
|  | * | 
|  | * Regenerated from previous version by: | 
|  | * Copyright (c) 2007 Advanced Micro Devices, Inc. | 
|  | * Contributed by Robert Richter <robert.richter@amd.com> | 
|  | * | 
|  | * Permission is hereby granted, free of charge, to any person obtaining a copy | 
|  | * of this software and associated documentation files (the "Software"), to deal | 
|  | * in the Software without restriction, including without limitation the rights | 
|  | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies | 
|  | * of the Software, and to permit persons to whom the Software is furnished to do so, | 
|  | * subject to the following conditions: | 
|  | * | 
|  | * The above copyright notice and this permission notice shall be included in all | 
|  | * copies or substantial portions of the Software. | 
|  | * | 
|  | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, | 
|  | * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A | 
|  | * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT | 
|  | * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF | 
|  | * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE | 
|  | * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | 
|  | * | 
|  | * This file is part of libpfm, a performance monitoring support library for | 
|  | * applications on Linux. | 
|  | * | 
|  | * This file has been automatically generated. | 
|  | * | 
|  | * PMU: amd64_fam10h (AMD64 Fam10h) | 
|  | */ | 
|  |  | 
|  | /* History | 
|  | * | 
|  | * May 28 2010 -- Robert Richter, robert.richter@amd.com: | 
|  | * | 
|  | * Update from: BIOS and Kernel Developer's Guide (BKDG) For AMD | 
|  | * Family 10h Processors, 31116 Rev 3.48 - April 22, 2010 | 
|  | * | 
|  | * Feb 06 2009 -- Robert Richter, robert.richter@amd.com: | 
|  | * | 
|  | * Update for Family 10h RevD (Istanbul) from: BIOS and Kernel | 
|  | * Developer's Guide (BKDG) For AMD Family 10h Processors, 31116 Rev | 
|  | * 3.20 - February 04, 2009 | 
|  | * This file has been automatically generated. | 
|  | * | 
|  | * Update for Family 10h RevC (Shanghai) from: BIOS and Kernel | 
|  | * Developer's Guide (BKDG) For AMD Family 10h Processors, 31116 Rev | 
|  | * 3.20 - February 04, 2009 | 
|  | * | 
|  | * | 
|  | * Dec 12 2007 -- Robert Richter, robert.richter@amd.com: | 
|  | * | 
|  | * Created from: BIOS and Kernel Developer's Guide (BKDG) For AMD | 
|  | * Family 10h Processors, 31116 Rev 3.00 - September 07, 2007 | 
|  | * PMU: amd64_fam10h (AMD64 Fam10h) | 
|  | */ | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_dispatched_fpu[]={ | 
|  | { .uname  = "OPS_ADD", | 
|  | .udesc  = "Add pipe ops excluding load ops and SSE move ops", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "OPS_MULTIPLY", | 
|  | .udesc  = "Multiply pipe ops excluding load ops and SSE move ops", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "OPS_STORE", | 
|  | .udesc  = "Store pipe ops excluding load ops and SSE move ops", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "OPS_ADD_PIPE_LOAD_OPS", | 
|  | .udesc  = "Add pipe load ops and SSE move ops", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "OPS_MULTIPLY_PIPE_LOAD_OPS", | 
|  | .udesc  = "Multiply pipe load ops and SSE move ops", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "OPS_STORE_PIPE_LOAD_OPS", | 
|  | .udesc  = "Store pipe load ops and SSE move ops", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_retired_sse_operations[]={ | 
|  | { .uname  = "SINGLE_ADD_SUB_OPS", | 
|  | .udesc  = "Single precision add/subtract ops", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "SINGLE_MUL_OPS", | 
|  | .udesc  = "Single precision multiply ops", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "SINGLE_DIV_OPS", | 
|  | .udesc  = "Single precision divide/square root ops", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "DOUBLE_ADD_SUB_OPS", | 
|  | .udesc  = "Double precision add/subtract ops", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "DOUBLE_MUL_OPS", | 
|  | .udesc  = "Double precision multiply ops", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "DOUBLE_DIV_OPS", | 
|  | .udesc  = "Double precision divide/square root ops", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "OP_TYPE", | 
|  | .udesc  = "Op type: 0=uops. 1=FLOPS", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_retired_move_ops[]={ | 
|  | { .uname  = "LOW_QW_MOVE_UOPS", | 
|  | .udesc  = "Merging low quadword move uops", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "HIGH_QW_MOVE_UOPS", | 
|  | .udesc  = "Merging high quadword move uops", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL_OTHER_MERGING_MOVE_UOPS", | 
|  | .udesc  = "All other merging move uops", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL_OTHER_MOVE_UOPS", | 
|  | .udesc  = "All other move uops", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_retired_serializing_ops[]={ | 
|  | { .uname  = "SSE_BOTTOM_EXECUTING_UOPS", | 
|  | .udesc  = "SSE bottom-executing uops retired", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "SSE_BOTTOM_SERIALIZING_UOPS", | 
|  | .udesc  = "SSE bottom-serializing uops retired", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "X87_BOTTOM_EXECUTING_UOPS", | 
|  | .udesc  = "X87 bottom-executing uops retired", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "X87_BOTTOM_SERIALIZING_UOPS", | 
|  | .udesc  = "X87 bottom-serializing uops retired", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_fp_scheduler_cycles[]={ | 
|  | { .uname  = "BOTTOM_EXECUTE_CYCLES", | 
|  | .udesc  = "Number of cycles a bottom-execute uop is in the FP scheduler", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "BOTTOM_SERIALIZING_CYCLES", | 
|  | .udesc  = "Number of cycles a bottom-serializing uop is in the FP scheduler", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_segment_register_loads[]={ | 
|  | { .uname  = "ES", | 
|  | .udesc  = "ES", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "CS", | 
|  | .udesc  = "CS", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "SS", | 
|  | .udesc  = "SS", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "DS", | 
|  | .udesc  = "DS", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "FS", | 
|  | .udesc  = "FS", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "GS", | 
|  | .udesc  = "GS", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "HS", | 
|  | .udesc  = "HS", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_locked_ops[]={ | 
|  | { .uname  = "EXECUTED", | 
|  | .udesc  = "The number of locked instructions executed", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "CYCLES_SPECULATIVE_PHASE", | 
|  | .udesc  = "The number of cycles spent in speculative phase", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "CYCLES_NON_SPECULATIVE_PHASE", | 
|  | .udesc  = "The number of cycles spent in non-speculative phase (including cache miss penalty)", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "CYCLES_WAITING", | 
|  | .udesc  = "The number of cycles waiting for a cache hit (cache miss penalty).", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_cancelled_store_to_load_forward_operations[]={ | 
|  | { .uname  = "ADDRESS_MISMATCHES", | 
|  | .udesc  = "Address mismatches (starting byte not the same).", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "STORE_IS_SMALLER_THAN_LOAD", | 
|  | .udesc  = "Store is smaller than load.", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "MISALIGNED", | 
|  | .udesc  = "Misaligned.", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_data_cache_refills[]={ | 
|  | { .uname  = "SYSTEM", | 
|  | .udesc  = "Refill from the Northbridge", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "L2_SHARED", | 
|  | .udesc  = "Shared-state line from L2", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "L2_EXCLUSIVE", | 
|  | .udesc  = "Exclusive-state line from L2", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "L2_OWNED", | 
|  | .udesc  = "Owned-state line from L2", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "L2_MODIFIED", | 
|  | .udesc  = "Modified-state line from L2", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x1f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_data_cache_refills_from_system[]={ | 
|  | { .uname  = "INVALID", | 
|  | .udesc  = "Invalid", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "SHARED", | 
|  | .udesc  = "Shared", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "EXCLUSIVE", | 
|  | .udesc  = "Exclusive", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "OWNED", | 
|  | .udesc  = "Owned", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "MODIFIED", | 
|  | .udesc  = "Modified", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x1f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_data_cache_lines_evicted[]={ | 
|  | { .uname  = "INVALID", | 
|  | .udesc  = "Invalid", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "SHARED", | 
|  | .udesc  = "Shared", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "EXCLUSIVE", | 
|  | .udesc  = "Exclusive", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "OWNED", | 
|  | .udesc  = "Owned", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "MODIFIED", | 
|  | .udesc  = "Modified", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "BY_PREFETCHNTA", | 
|  | .udesc  = "Cache line evicted was brought into the cache with by a PrefetchNTA instruction.", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "NOT_BY_PREFETCHNTA", | 
|  | .udesc  = "Cache line evicted was not brought into the cache with by a PrefetchNTA instruction.", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l1_dtlb_miss_and_l2_dtlb_hit[]={ | 
|  | { .uname  = "L2_4K_TLB_HIT", | 
|  | .udesc  = "L2 4K TLB hit", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "L2_2M_TLB_HIT", | 
|  | .udesc  = "L2 2M TLB hit", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL | AMD64_FL_TILL_FAM10H_REV_B, | 
|  | }, | 
|  | { .uname  = "L2_1G_TLB_HIT", | 
|  | .udesc  = "L2 1G TLB hit", | 
|  | .ucode = 0x4, | 
|  | .uflags= AMD64_FL_FAM10H_REV_C, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL | AMD64_FL_FAM10H_REV_C, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l1_dtlb_and_l2_dtlb_miss[]={ | 
|  | { .uname  = "4K_TLB_RELOAD", | 
|  | .udesc  = "4K TLB reload", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "2M_TLB_RELOAD", | 
|  | .udesc  = "2M TLB reload", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "1G_TLB_RELOAD", | 
|  | .udesc  = "1G TLB reload", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_scrubber_single_bit_ecc_errors[]={ | 
|  | { .uname  = "SCRUBBER_ERROR", | 
|  | .udesc  = "Scrubber error", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "PIGGYBACK_ERROR", | 
|  | .udesc  = "Piggyback scrubber errors", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "LOAD_PIPE_ERROR", | 
|  | .udesc  = "Load pipe error", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "STORE_WRITE_PIPE_ERROR", | 
|  | .udesc  = "Store write pipe error", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_prefetch_instructions_dispatched[]={ | 
|  | { .uname  = "LOAD", | 
|  | .udesc  = "Load (Prefetch, PrefetchT0/T1/T2)", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "STORE", | 
|  | .udesc  = "Store (PrefetchW)", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "NTA", | 
|  | .udesc  = "NTA (PrefetchNTA)", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_dcache_misses_by_locked_instructions[]={ | 
|  | { .uname  = "DATA_CACHE_MISSES_BY_LOCKED_INSTRUCTIONS", | 
|  | .udesc  = "Data cache misses by locked instructions", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x2, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l1_dtlb_hit[]={ | 
|  | { .uname  = "L1_4K_TLB_HIT", | 
|  | .udesc  = "L1 4K TLB hit", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "L1_2M_TLB_HIT", | 
|  | .udesc  = "L1 2M TLB hit", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "L1_1G_TLB_HIT", | 
|  | .udesc  = "L1 1G TLB hit", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_ineffective_sw_prefetches[]={ | 
|  | { .uname  = "SW_PREFETCH_HIT_IN_L1", | 
|  | .udesc  = "Software prefetch hit in the L1.", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "SW_PREFETCH_HIT_IN_L2", | 
|  | .udesc  = "Software prefetch hit in L2.", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x9, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_memory_requests[]={ | 
|  | { .uname  = "NON_CACHEABLE", | 
|  | .udesc  = "Requests to non-cacheable (UC) memory", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "WRITE_COMBINING", | 
|  | .udesc  = "Requests to write-combining (WC) memory or WC buffer flushes to WB memory", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "STREAMING_STORE", | 
|  | .udesc  = "Streaming store (SS) requests", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x83, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_data_prefetches[]={ | 
|  | { .uname  = "CANCELLED", | 
|  | .udesc  = "Cancelled prefetches", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "ATTEMPTED", | 
|  | .udesc  = "Prefetch attempts", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_mab_requests[]={ | 
|  | { .uname  = "BUFFER_0", | 
|  | .udesc  = "Buffer 0", | 
|  | .ucode = 0x0, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_1", | 
|  | .udesc  = "Buffer 1", | 
|  | .ucode = 0x1, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_2", | 
|  | .udesc  = "Buffer 2", | 
|  | .ucode = 0x2, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_3", | 
|  | .udesc  = "Buffer 3", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_4", | 
|  | .udesc  = "Buffer 4", | 
|  | .ucode = 0x4, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_5", | 
|  | .udesc  = "Buffer 5", | 
|  | .ucode = 0x5, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_6", | 
|  | .udesc  = "Buffer 6", | 
|  | .ucode = 0x6, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_7", | 
|  | .udesc  = "Buffer 7", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_8", | 
|  | .udesc  = "Buffer 8", | 
|  | .ucode = 0x8, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | { .uname  = "BUFFER_9", | 
|  | .udesc  = "Buffer 9", | 
|  | .ucode = 0x9, | 
|  | .uflags= AMD64_FL_NCOMBO, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_system_read_responses[]={ | 
|  | { .uname  = "EXCLUSIVE", | 
|  | .udesc  = "Exclusive", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "MODIFIED", | 
|  | .udesc  = "Modified", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "SHARED", | 
|  | .udesc  = "Shared", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "OWNED", | 
|  | .udesc  = "Owned", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "DATA_ERROR", | 
|  | .udesc  = "Data Error", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x1f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_quadwords_written_to_system[]={ | 
|  | { .uname  = "QUADWORD_WRITE_TRANSFER", | 
|  | .udesc  = "Octword write transfer", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x1, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_requests_to_l2[]={ | 
|  | { .uname  = "INSTRUCTIONS", | 
|  | .udesc  = "IC fill", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "DATA", | 
|  | .udesc  = "DC fill", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "TLB_WALK", | 
|  | .udesc  = "TLB fill (page table walks)", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "SNOOP", | 
|  | .udesc  = "Tag snoop request", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "CANCELLED", | 
|  | .udesc  = "Cancelled request", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "HW_PREFETCH_FROM_DC", | 
|  | .udesc  = "Hardware prefetch from DC", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l2_cache_miss[]={ | 
|  | { .uname  = "INSTRUCTIONS", | 
|  | .udesc  = "IC fill", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "DATA", | 
|  | .udesc  = "DC fill (includes possible replays, whereas EventSelect 041h does not)", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "TLB_WALK", | 
|  | .udesc  = "TLB page table walk", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "HW_PREFETCH_FROM_DC", | 
|  | .udesc  = "Hardware prefetch from DC", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l2_fill_writeback[]={ | 
|  | { .uname  = "L2_FILLS", | 
|  | .udesc  = "L2 fills (victims from L1 caches, TLB page table walks and data prefetches)", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "L2_WRITEBACKS", | 
|  | .udesc  = "L2 Writebacks to system.", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l1_itlb_miss_and_l2_itlb_miss[]={ | 
|  | { .uname  = "4K_PAGE_FETCHES", | 
|  | .udesc  = "Instruction fetches to a 4K page.", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "2M_PAGE_FETCHES", | 
|  | .udesc  = "Instruction fetches to a 2M page.", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_instruction_cache_lines_invalidated[]={ | 
|  | { .uname  = "INVALIDATING_PROBE_NO_IN_FLIGHT", | 
|  | .udesc  = "Invalidating probe that did not hit any in-flight instructions.", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "INVALIDATING_PROBE_ONE_OR_MORE_IN_FLIGHT", | 
|  | .udesc  = "Invalidating probe that hit one or more in-flight instructions.", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_retired_mmx_and_fp_instructions[]={ | 
|  | { .uname  = "X87", | 
|  | .udesc  = "X87 instructions", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "MMX_AND_3DNOW", | 
|  | .udesc  = "MMX and 3DNow! instructions", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "PACKED_SSE_AND_SSE2", | 
|  | .udesc  = "SSE instructions (SSE, SSE2, SSE3, and SSE4A)", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_retired_fastpath_double_op_instructions[]={ | 
|  | { .uname  = "POSITION_0", | 
|  | .udesc  = "With low op in position 0", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "POSITION_1", | 
|  | .udesc  = "With low op in position 1", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "POSITION_2", | 
|  | .udesc  = "With low op in position 2", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_fpu_exceptions[]={ | 
|  | { .uname  = "X87_RECLASS_MICROFAULTS", | 
|  | .udesc  = "X87 reclass microfaults", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "SSE_RETYPE_MICROFAULTS", | 
|  | .udesc  = "SSE retype microfaults", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "SSE_RECLASS_MICROFAULTS", | 
|  | .udesc  = "SSE reclass microfaults", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "SSE_AND_X87_MICROTRAPS", | 
|  | .udesc  = "SSE and x87 microtraps", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_dram_accesses_page[]={ | 
|  | { .uname  = "HIT", | 
|  | .udesc  = "DCT0 Page hit", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "MISS", | 
|  | .udesc  = "DCT0 Page Miss", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "CONFLICT", | 
|  | .udesc  = "DCT0 Page Conflict", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "DCT1_PAGE_HIT", | 
|  | .udesc  = "DCT1 Page hit", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "DCT1_PAGE_MISS", | 
|  | .udesc  = "DCT1 Page Miss", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "DCT1_PAGE_CONFLICT", | 
|  | .udesc  = "DCT1 Page Conflict", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_memory_controller_page_table_overflows[]={ | 
|  | { .uname  = "DCT0_PAGE_TABLE_OVERFLOW", | 
|  | .udesc  = "DCT0 Page Table Overflow", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "DCT1_PAGE_TABLE_OVERFLOW", | 
|  | .udesc  = "DCT1 Page Table Overflow", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_memory_controller_slot_misses[]={ | 
|  | { .uname  = "DCT0_COMMAND_SLOTS_MISSED", | 
|  | .udesc  = "DCT0 Command Slots Missed", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "DCT1_COMMAND_SLOTS_MISSED", | 
|  | .udesc  = "DCT1 Command Slots Missed", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_memory_controller_turnarounds[]={ | 
|  | { .uname  = "CHIP_SELECT", | 
|  | .udesc  = "DCT0 DIMM (chip select) turnaround", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "READ_TO_WRITE", | 
|  | .udesc  = "DCT0 Read to write turnaround", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "WRITE_TO_READ", | 
|  | .udesc  = "DCT0 Write to read turnaround", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "DCT1_DIMM", | 
|  | .udesc  = "DCT1 DIMM (chip select) turnaround", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "DCT1_READ_TO_WRITE_TURNAROUND", | 
|  | .udesc  = "DCT1 Read to write turnaround", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "DCT1_WRITE_TO_READ_TURNAROUND", | 
|  | .udesc  = "DCT1 Write to read turnaround", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_memory_controller_bypass[]={ | 
|  | { .uname  = "HIGH_PRIORITY", | 
|  | .udesc  = "Memory controller high priority bypass", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "LOW_PRIORITY", | 
|  | .udesc  = "Memory controller medium priority bypass", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "DRAM_INTERFACE", | 
|  | .udesc  = "DCT0 DCQ bypass", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "DRAM_QUEUE", | 
|  | .udesc  = "DCT1 DCQ bypass", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_thermal_status_and_ecc_errors[]={ | 
|  | { .uname  = "CLKS_DIE_TEMP_TOO_HIGH", | 
|  | .udesc  = "Number of times the HTC trip point is crossed", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "CLKS_TEMP_THRESHOLD_EXCEEDED", | 
|  | .udesc  = "Number of clocks when STC trip point active", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "STC_TRIP_POINTS_CROSSED", | 
|  | .udesc  = "Number of times the STC trip point is crossed", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "CLOCKS_HTC_P_STATE_INACTIVE", | 
|  | .udesc  = "Number of clocks HTC P-state is inactive.", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "CLOCKS_HTC_P_STATE_ACTIVE", | 
|  | .udesc  = "Number of clocks HTC P-state is active", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7c, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_cpu_io_requests_to_memory_io[]={ | 
|  | { .uname  = "I_O_TO_I_O", | 
|  | .udesc  = "IO to IO", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "I_O_TO_MEM", | 
|  | .udesc  = "IO to Mem", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "CPU_TO_I_O", | 
|  | .udesc  = "CPU to IO", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "CPU_TO_MEM", | 
|  | .udesc  = "CPU to Mem", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "TO_REMOTE_NODE", | 
|  | .udesc  = "To remote node", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "TO_LOCAL_NODE", | 
|  | .udesc  = "To local node", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "FROM_REMOTE_NODE", | 
|  | .udesc  = "From remote node", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "FROM_LOCAL_NODE", | 
|  | .udesc  = "From local node", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xff, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_cache_block[]={ | 
|  | { .uname  = "VICTIM_WRITEBACK", | 
|  | .udesc  = "Victim Block (Writeback)", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "DCACHE_LOAD_MISS", | 
|  | .udesc  = "Read Block (Dcache load miss refill)", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "SHARED_ICACHE_REFILL", | 
|  | .udesc  = "Read Block Shared (Icache refill)", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_MODIFIED", | 
|  | .udesc  = "Read Block Modified (Dcache store miss refill)", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "READ_TO_DIRTY", | 
|  | .udesc  = "Change-to-Dirty (first store to clean block already in cache)", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3d, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_sized_commands[]={ | 
|  | { .uname  = "NON_POSTED_WRITE_BYTE", | 
|  | .udesc  = "Non-Posted SzWr Byte (1-32 bytes) Legacy or mapped IO, typically 1-4 bytes", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "NON_POSTED_WRITE_DWORD", | 
|  | .udesc  = "Non-Posted SzWr DW (1-16 dwords) Legacy or mapped IO, typically 1 DWORD", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "POSTED_WRITE_BYTE", | 
|  | .udesc  = "Posted SzWr Byte (1-32 bytes) Subcache-line DMA writes, size varies; also flushes of partially-filled Write Combining buffer", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "POSTED_WRITE_DWORD", | 
|  | .udesc  = "Posted SzWr DW (1-16 dwords) Block-oriented DMA writes, often cache-line sized; also processor Write Combining buffer flushes", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "READ_BYTE_4_BYTES", | 
|  | .udesc  = "SzRd Byte (4 bytes) Legacy or mapped IO", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "READ_DWORD_1_16_DWORDS", | 
|  | .udesc  = "SzRd DW (1-16 dwords) Block-oriented DMA reads, typically cache-line size", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_probe[]={ | 
|  | { .uname  = "MISS", | 
|  | .udesc  = "Probe miss", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "HIT_CLEAN", | 
|  | .udesc  = "Probe hit clean", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "HIT_DIRTY_NO_MEMORY_CANCEL", | 
|  | .udesc  = "Probe hit dirty without memory cancel (probed by Sized Write or Change2Dirty)", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "HIT_DIRTY_WITH_MEMORY_CANCEL", | 
|  | .udesc  = "Probe hit dirty with memory cancel (probed by DMA read or cache refill request)", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "UPSTREAM_DISPLAY_REFRESH_READS", | 
|  | .udesc  = "Upstream display refresh/ISOC reads", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "UPSTREAM_NON_DISPLAY_REFRESH_READS", | 
|  | .udesc  = "Upstream non-display refresh reads", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "UPSTREAM_WRITES", | 
|  | .udesc  = "Upstream ISOC writes", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "UPSTREAM_NON_ISOC_WRITES", | 
|  | .udesc  = "Upstream non-ISOC writes", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xff, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_gart[]={ | 
|  | { .uname  = "APERTURE_HIT_FROM_CPU", | 
|  | .udesc  = "GART aperture hit on access from CPU", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "APERTURE_HIT_FROM_IO", | 
|  | .udesc  = "GART aperture hit on access from IO", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "MISS", | 
|  | .udesc  = "GART miss", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "REQUEST_HIT_TABLE_WALK", | 
|  | .udesc  = "GART/DEV Request hit table walk in progress", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "DEV_HIT", | 
|  | .udesc  = "DEV hit", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "DEV_MISS", | 
|  | .udesc  = "DEV miss", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "DEV_ERROR", | 
|  | .udesc  = "DEV error", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "MULTIPLE_TABLE_WALK", | 
|  | .udesc  = "GART/DEV multiple table walk in progress", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xff, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_memory_controller_requests[]={ | 
|  | { .uname  = "WRITE_REQUESTS", | 
|  | .udesc  = "Write requests sent to the DCT", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "READ_REQUESTS", | 
|  | .udesc  = "Read requests (including prefetch requests) sent to the DCT", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "PREFETCH_REQUESTS", | 
|  | .udesc  = "Prefetch requests sent to the DCT", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "32_BYTES_WRITES", | 
|  | .udesc  = "32 Bytes Sized Writes", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "64_BYTES_WRITES", | 
|  | .udesc  = "64 Bytes Sized Writes", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "32_BYTES_READS", | 
|  | .udesc  = "32 Bytes Sized Reads", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "64_BYTES_READS", | 
|  | .udesc  = "64 Byte Sized Reads", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "READ_REQUESTS_WHILE_WRITES_REQUESTS", | 
|  | .udesc  = "Read requests sent to the DCT while writes requests are pending in the DCT", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xff, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_cpu_to_dram_requests_to_target_node[]={ | 
|  | { .uname  = "LOCAL_TO_0", | 
|  | .udesc  = "From Local node to Node 0", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_1", | 
|  | .udesc  = "From Local node to Node 1", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_2", | 
|  | .udesc  = "From Local node to Node 2", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_3", | 
|  | .udesc  = "From Local node to Node 3", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_4", | 
|  | .udesc  = "From Local node to Node 4", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_5", | 
|  | .udesc  = "From Local node to Node 5", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_6", | 
|  | .udesc  = "From Local node to Node 6", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_7", | 
|  | .udesc  = "From Local node to Node 7", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xff, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_cpu_read_command_latency_to_target_node_0_3[]={ | 
|  | { .uname  = "READ_BLOCK", | 
|  | .udesc  = "Read block", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_SHARED", | 
|  | .udesc  = "Read block shared", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_MODIFIED", | 
|  | .udesc  = "Read block modified", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "CHANGE_TO_DIRTY", | 
|  | .udesc  = "Change-to-Dirty", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_0", | 
|  | .udesc  = "From Local node to Node 0", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_1", | 
|  | .udesc  = "From Local node to Node 1", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_2", | 
|  | .udesc  = "From Local node to Node 2", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_3", | 
|  | .udesc  = "From Local node to Node 3", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xff, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_cpu_read_command_latency_to_target_node_4_7[]={ | 
|  | { .uname  = "READ_BLOCK", | 
|  | .udesc  = "Read block", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_SHARED", | 
|  | .udesc  = "Read block shared", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_MODIFIED", | 
|  | .udesc  = "Read block modified", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "CHANGE_TO_DIRTY", | 
|  | .udesc  = "Change-to-Dirty", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_4", | 
|  | .udesc  = "From Local node to Node 4", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_5", | 
|  | .udesc  = "From Local node to Node 5", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_6", | 
|  | .udesc  = "From Local node to Node 6", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_7", | 
|  | .udesc  = "From Local node to Node 7", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xff, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_cpu_command_latency_to_target_node_0_3_4_7[]={ | 
|  | { .uname  = "READ_SIZED", | 
|  | .udesc  = "Read Sized", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "WRITE_SIZED", | 
|  | .udesc  = "Write Sized", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "VICTIM_BLOCK", | 
|  | .udesc  = "Victim Block", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "NODE_GROUP_SELECT", | 
|  | .udesc  = "Node Group Select. 0=Nodes 0-3. 1= Nodes 4-7.", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_0_4", | 
|  | .udesc  = "From Local node to Node 0/4", | 
|  | .ucode = 0x10, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_1_5", | 
|  | .udesc  = "From Local node to Node 1/5", | 
|  | .ucode = 0x20, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_2_6", | 
|  | .udesc  = "From Local node to Node 2/6", | 
|  | .ucode = 0x40, | 
|  | }, | 
|  | { .uname  = "LOCAL_TO_3_7", | 
|  | .udesc  = "From Local node to Node 3/7", | 
|  | .ucode = 0x80, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xff, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_hypertransport_link0[]={ | 
|  | { .uname  = "COMMAND_DWORD_SENT", | 
|  | .udesc  = "Command DWORD sent", | 
|  | .ucode = 0x1, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "DATA_DWORD_SENT", | 
|  | .udesc  = "Data DWORD sent", | 
|  | .ucode = 0x2, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "BUFFER_RELEASE_DWORD_SENT", | 
|  | .udesc  = "Buffer release DWORD sent", | 
|  | .ucode = 0x4, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "NOP_DWORD_SENT", | 
|  | .udesc  = "Nop DW sent (idle)", | 
|  | .ucode = 0x8, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ADDRESS_EXT_DWORD_SENT", | 
|  | .udesc  = "Address extension DWORD sent", | 
|  | .ucode = 0x10, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "PER_PACKET_CRC_SENT", | 
|  | .udesc  = "Per packet CRC sent", | 
|  | .ucode = 0x20, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "SUBLINK_MASK", | 
|  | .udesc  = "SubLink Mask", | 
|  | .ucode = 0x80, | 
|  | .uflags= AMD64_FL_OMIT, | 
|  | .grpid = 1, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_hypertransport_link3[]={ | 
|  | { .uname  = "COMMAND_DWORD_SENT", | 
|  | .udesc  = "Command DWORD sent", | 
|  | .ucode = 0x1, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "DATA_DWORD_SENT", | 
|  | .udesc  = "Data DWORD sent", | 
|  | .ucode = 0x2, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "BUFFER_RELEASE_DWORD_SENT", | 
|  | .udesc  = "Buffer release DWORD sent", | 
|  | .ucode = 0x4, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "NOP_DWORD_SENT", | 
|  | .udesc  = "Nop DW sent (idle)", | 
|  | .ucode = 0x8, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ADDRESS_EXT_DWORD_SENT", | 
|  | .udesc  = "Address DWORD sent", | 
|  | .ucode = 0x10, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "PER_PACKET_CRC_SENT", | 
|  | .udesc  = "Per packet CRC sent", | 
|  | .ucode = 0x20, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x3f, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "SUBLINK_MASK", | 
|  | .udesc  = "SubLink Mask", | 
|  | .ucode = 0x80, | 
|  | .uflags= AMD64_FL_OMIT, | 
|  | .grpid = 1, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_read_request_to_l3_cache[]={ | 
|  | { .uname  = "READ_BLOCK_EXCLUSIVE", | 
|  | .udesc  = "Read Block Exclusive (Data cache read)", | 
|  | .ucode = 0x1, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_SHARED", | 
|  | .udesc  = "Read Block Shared (Instruction cache read)", | 
|  | .ucode = 0x2, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_MODIFY", | 
|  | .udesc  = "Read Block Modify", | 
|  | .ucode = 0x4, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ANY_READ", | 
|  | .udesc  = "Any read modes (exclusive, shared, modify)", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ALL_CORES", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf0, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | .grpid = 1, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l3_cache_misses[]={ | 
|  | { .uname  = "READ_BLOCK_EXCLUSIVE", | 
|  | .udesc  = "Read Block Exclusive (Data cache read)", | 
|  | .ucode = 0x1, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_SHARED", | 
|  | .udesc  = "Read Block Shared (Instruction cache read)", | 
|  | .ucode = 0x2, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "READ_BLOCK_MODIFY", | 
|  | .udesc  = "Read Block Modify", | 
|  | .ucode = 0x4, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ANY_READ", | 
|  | .udesc  = "Any read modes (exclusive, shared, modify)", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ALL_CORES", | 
|  | .udesc  = "All cores", | 
|  | .ucode = 0xf0, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | .grpid = 1, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l3_fills_caused_by_l2_evictions[]={ | 
|  | { .uname  = "SHARED", | 
|  | .udesc  = "Shared", | 
|  | .ucode = 0x1, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "EXCLUSIVE", | 
|  | .udesc  = "Exclusive", | 
|  | .ucode = 0x2, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "OWNED", | 
|  | .udesc  = "Owned", | 
|  | .ucode = 0x4, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "MODIFIED", | 
|  | .udesc  = "Modified", | 
|  | .ucode = 0x8, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ANY_STATE", | 
|  | .udesc  = "Any line state (shared, owned, exclusive, modified)", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | .grpid = 0, | 
|  | }, | 
|  | { .uname  = "ALL_CORES", | 
|  | .udesc  = "All cores", | 
|  | .ucode = 0xf0, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | .grpid = 1, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_l3_evictions[]={ | 
|  | { .uname  = "SHARED", | 
|  | .udesc  = "Shared", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "EXCLUSIVE", | 
|  | .udesc  = "Exclusive", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "OWNED", | 
|  | .udesc  = "Owned", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "MODIFIED", | 
|  | .udesc  = "Modified", | 
|  | .ucode = 0x8, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0xf, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_page_size_mismatches[]={ | 
|  | { .uname  = "GUEST_LARGER", | 
|  | .udesc  = "Guest page size is larger than the host page size.", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "MTRR_MISMATCH", | 
|  | .udesc  = "MTRR mismatch.", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "HOST_LARGER", | 
|  | .udesc  = "Host page size is larger than the guest page size.", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_umask_t amd64_fam10h_retired_x87_ops[]={ | 
|  | { .uname  = "ADD_SUB_OPS", | 
|  | .udesc  = "Add/subtract ops", | 
|  | .ucode = 0x1, | 
|  | }, | 
|  | { .uname  = "MUL_OPS", | 
|  | .udesc  = "Multiply ops", | 
|  | .ucode = 0x2, | 
|  | }, | 
|  | { .uname  = "DIV_OPS", | 
|  | .udesc  = "Divide ops", | 
|  | .ucode = 0x4, | 
|  | }, | 
|  | { .uname  = "ALL", | 
|  | .udesc  = "All sub-events selected", | 
|  | .ucode = 0x7, | 
|  | .uflags= AMD64_FL_NCOMBO | AMD64_FL_DFL, | 
|  | }, | 
|  | }; | 
|  |  | 
|  | static const amd64_entry_t amd64_fam10h_pe[]={ | 
|  | { .name    = "DISPATCHED_FPU", | 
|  | .desc    = "Dispatched FPU Operations", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x0, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_dispatched_fpu), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_dispatched_fpu, | 
|  | }, | 
|  | { .name    = "CYCLES_NO_FPU_OPS_RETIRED", | 
|  | .desc    = "Cycles in which the FPU is Empty", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1, | 
|  | }, | 
|  | { .name    = "DISPATCHED_FPU_OPS_FAST_FLAG", | 
|  | .desc    = "Dispatched Fast Flag FPU Operations", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x2, | 
|  | }, | 
|  | { .name    = "RETIRED_SSE_OPERATIONS", | 
|  | .desc    = "Retired SSE Operations", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x3, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_retired_sse_operations), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_retired_sse_operations, | 
|  | }, | 
|  | { .name    = "RETIRED_MOVE_OPS", | 
|  | .desc    = "Retired Move Ops", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_retired_move_ops), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_retired_move_ops, | 
|  | }, | 
|  | { .name    = "RETIRED_SERIALIZING_OPS", | 
|  | .desc    = "Retired Serializing Ops", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x5, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_retired_serializing_ops), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_retired_serializing_ops, | 
|  | }, | 
|  | { .name    = "FP_SCHEDULER_CYCLES", | 
|  | .desc    = "Number of Cycles that a Serializing uop is in the FP Scheduler", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x6, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_fp_scheduler_cycles), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_fp_scheduler_cycles, | 
|  | }, | 
|  | { .name    = "SEGMENT_REGISTER_LOADS", | 
|  | .desc    = "Segment Register Loads", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x20, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_segment_register_loads), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_segment_register_loads, | 
|  | }, | 
|  | { .name    = "PIPELINE_RESTART_DUE_TO_SELF_MODIFYING_CODE", | 
|  | .desc    = "Pipeline Restart Due to Self-Modifying Code", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x21, | 
|  | }, | 
|  | { .name    = "PIPELINE_RESTART_DUE_TO_PROBE_HIT", | 
|  | .desc    = "Pipeline Restart Due to Probe Hit", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x22, | 
|  | }, | 
|  | { .name    = "LS_BUFFER_2_FULL_CYCLES", | 
|  | .desc    = "LS Buffer 2 Full", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x23, | 
|  | }, | 
|  | { .name    = "LOCKED_OPS", | 
|  | .desc    = "Locked Operations", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x24, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_locked_ops), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_locked_ops, | 
|  | }, | 
|  | { .name    = "RETIRED_CLFLUSH_INSTRUCTIONS", | 
|  | .desc    = "Retired CLFLUSH Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x26, | 
|  | }, | 
|  | { .name    = "RETIRED_CPUID_INSTRUCTIONS", | 
|  | .desc    = "Retired CPUID Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x27, | 
|  | }, | 
|  | { .name    = "CANCELLED_STORE_TO_LOAD_FORWARD_OPERATIONS", | 
|  | .desc    = "Cancelled Store to Load Forward Operations", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x2a, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cancelled_store_to_load_forward_operations), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cancelled_store_to_load_forward_operations, | 
|  | }, | 
|  | { .name    = "SMIS_RECEIVED", | 
|  | .desc    = "SMIs Received", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x2b, | 
|  | }, | 
|  | { .name    = "DATA_CACHE_ACCESSES", | 
|  | .desc    = "Data Cache Accesses", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x40, | 
|  | }, | 
|  | { .name    = "DATA_CACHE_MISSES", | 
|  | .desc    = "Data Cache Misses", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x41, | 
|  | }, | 
|  | { .name    = "DATA_CACHE_REFILLS", | 
|  | .desc    = "Data Cache Refills from L2 or Northbridge", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x42, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_data_cache_refills), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_data_cache_refills, | 
|  | }, | 
|  | { .name    = "DATA_CACHE_REFILLS_FROM_SYSTEM", | 
|  | .desc    = "Data Cache Refills from the Northbridge", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x43, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_data_cache_refills_from_system), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_data_cache_refills_from_system, | 
|  | }, | 
|  | { .name    = "DATA_CACHE_LINES_EVICTED", | 
|  | .desc    = "Data Cache Lines Evicted", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x44, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_data_cache_lines_evicted), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_data_cache_lines_evicted, | 
|  | }, | 
|  | { .name    = "L1_DTLB_MISS_AND_L2_DTLB_HIT", | 
|  | .desc    = "L1 DTLB Miss and L2 DTLB Hit", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x45, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l1_dtlb_miss_and_l2_dtlb_hit), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_l1_dtlb_miss_and_l2_dtlb_hit, | 
|  | }, | 
|  | { .name    = "L1_DTLB_AND_L2_DTLB_MISS", | 
|  | .desc    = "L1 DTLB and L2 DTLB Miss", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x46, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l1_dtlb_and_l2_dtlb_miss), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_l1_dtlb_and_l2_dtlb_miss, | 
|  | }, | 
|  | { .name    = "MISALIGNED_ACCESSES", | 
|  | .desc    = "Misaligned Accesses", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x47, | 
|  | }, | 
|  | { .name    = "MICROARCHITECTURAL_LATE_CANCEL_OF_AN_ACCESS", | 
|  | .desc    = "Microarchitectural Late Cancel of an Access", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x48, | 
|  | }, | 
|  | { .name    = "MICROARCHITECTURAL_EARLY_CANCEL_OF_AN_ACCESS", | 
|  | .desc    = "Microarchitectural Early Cancel of an Access", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x49, | 
|  | }, | 
|  | { .name    = "SCRUBBER_SINGLE_BIT_ECC_ERRORS", | 
|  | .desc    = "Single-bit ECC Errors Recorded by Scrubber", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4a, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_scrubber_single_bit_ecc_errors), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_scrubber_single_bit_ecc_errors, | 
|  | }, | 
|  | { .name    = "PREFETCH_INSTRUCTIONS_DISPATCHED", | 
|  | .desc    = "Prefetch Instructions Dispatched", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4b, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_prefetch_instructions_dispatched), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_prefetch_instructions_dispatched, | 
|  | }, | 
|  | { .name    = "DCACHE_MISSES_BY_LOCKED_INSTRUCTIONS", | 
|  | .desc    = "DCACHE Misses by Locked Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4c, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_dcache_misses_by_locked_instructions), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_dcache_misses_by_locked_instructions, | 
|  | }, | 
|  | { .name    = "L1_DTLB_HIT", | 
|  | .desc    = "L1 DTLB Hit", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4d, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l1_dtlb_hit), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_l1_dtlb_hit, | 
|  | }, | 
|  | { .name    = "INEFFECTIVE_SW_PREFETCHES", | 
|  | .desc    = "Ineffective Software Prefetches", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x52, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_ineffective_sw_prefetches), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_ineffective_sw_prefetches, | 
|  | }, | 
|  | { .name    = "GLOBAL_TLB_FLUSHES", | 
|  | .desc    = "Global TLB Flushes", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x54, | 
|  | }, | 
|  | { .name    = "MEMORY_REQUESTS", | 
|  | .desc    = "Memory Requests by Type", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x65, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_memory_requests), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_memory_requests, | 
|  | }, | 
|  | { .name    = "DATA_PREFETCHES", | 
|  | .desc    = "Data Prefetcher", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x67, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_data_prefetches), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_data_prefetches, | 
|  | }, | 
|  | { .name    = "MAB_REQUESTS", | 
|  | .desc    = "Average L1 refill latency for Icache and Dcache misses (request count for cache refills)", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x68, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_mab_requests), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_mab_requests, | 
|  | }, | 
|  | { .name    = "MAB_WAIT_CYCLES", | 
|  | .desc    = "Average L1 refill latency for Icache and Dcache misses (cycles that requests spent waiting for the refills)", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x69, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_mab_requests), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_mab_requests, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "SYSTEM_READ_RESPONSES", | 
|  | .desc    = "Northbridge Read Responses by Coherency State", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x6c, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_system_read_responses), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_system_read_responses, | 
|  | }, | 
|  | { .name    = "QUADWORDS_WRITTEN_TO_SYSTEM", | 
|  | .desc    = "Octwords Written to System", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x6d, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_quadwords_written_to_system), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_quadwords_written_to_system, | 
|  | }, | 
|  | { .name    = "CPU_CLK_UNHALTED", | 
|  | .desc    = "CPU Clocks not Halted", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x76, | 
|  | }, | 
|  | { .name    = "REQUESTS_TO_L2", | 
|  | .desc    = "Requests to L2 Cache", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x7d, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_requests_to_l2), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_requests_to_l2, | 
|  | }, | 
|  | { .name    = "L2_CACHE_MISS", | 
|  | .desc    = "L2 Cache Misses", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x7e, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l2_cache_miss), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_l2_cache_miss, | 
|  | }, | 
|  | { .name    = "L2_FILL_WRITEBACK", | 
|  | .desc    = "L2 Fill/Writeback", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x7f, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l2_fill_writeback), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_l2_fill_writeback, | 
|  | }, | 
|  | { .name    = "INSTRUCTION_CACHE_FETCHES", | 
|  | .desc    = "Instruction Cache Fetches", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x80, | 
|  | }, | 
|  | { .name    = "INSTRUCTION_CACHE_MISSES", | 
|  | .desc    = "Instruction Cache Misses", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x81, | 
|  | }, | 
|  | { .name    = "INSTRUCTION_CACHE_REFILLS_FROM_L2", | 
|  | .desc    = "Instruction Cache Refills from L2", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x82, | 
|  | }, | 
|  | { .name    = "INSTRUCTION_CACHE_REFILLS_FROM_SYSTEM", | 
|  | .desc    = "Instruction Cache Refills from System", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x83, | 
|  | }, | 
|  | { .name    = "L1_ITLB_MISS_AND_L2_ITLB_HIT", | 
|  | .desc    = "L1 ITLB Miss and L2 ITLB Hit", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x84, | 
|  | }, | 
|  | { .name    = "L1_ITLB_MISS_AND_L2_ITLB_MISS", | 
|  | .desc    = "L1 ITLB Miss and L2 ITLB Miss", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x85, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l1_itlb_miss_and_l2_itlb_miss), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_l1_itlb_miss_and_l2_itlb_miss, | 
|  | }, | 
|  | { .name    = "PIPELINE_RESTART_DUE_TO_INSTRUCTION_STREAM_PROBE", | 
|  | .desc    = "Pipeline Restart Due to Instruction Stream Probe", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x86, | 
|  | }, | 
|  | { .name    = "INSTRUCTION_FETCH_STALL", | 
|  | .desc    = "Instruction Fetch Stall", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x87, | 
|  | }, | 
|  | { .name    = "RETURN_STACK_HITS", | 
|  | .desc    = "Return Stack Hits", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x88, | 
|  | }, | 
|  | { .name    = "RETURN_STACK_OVERFLOWS", | 
|  | .desc    = "Return Stack Overflows", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x89, | 
|  | }, | 
|  | { .name    = "INSTRUCTION_CACHE_VICTIMS", | 
|  | .desc    = "Instruction Cache Victims", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x8b, | 
|  | }, | 
|  | { .name    = "INSTRUCTION_CACHE_LINES_INVALIDATED", | 
|  | .desc    = "Instruction Cache Lines Invalidated", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x8c, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_instruction_cache_lines_invalidated), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_instruction_cache_lines_invalidated, | 
|  | }, | 
|  | { .name    = "ITLB_RELOADS", | 
|  | .desc    = "ITLB Reloads", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x99, | 
|  | }, | 
|  | { .name    = "ITLB_RELOADS_ABORTED", | 
|  | .desc    = "ITLB Reloads Aborted", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x9a, | 
|  | }, | 
|  | { .name    = "RETIRED_INSTRUCTIONS", | 
|  | .desc    = "Retired Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc0, | 
|  | }, | 
|  | { .name    = "RETIRED_UOPS", | 
|  | .desc    = "Retired uops", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc1, | 
|  | }, | 
|  | { .name    = "RETIRED_BRANCH_INSTRUCTIONS", | 
|  | .desc    = "Retired Branch Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc2, | 
|  | }, | 
|  | { .name    = "RETIRED_MISPREDICTED_BRANCH_INSTRUCTIONS", | 
|  | .desc    = "Retired Mispredicted Branch Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc3, | 
|  | }, | 
|  | { .name    = "RETIRED_TAKEN_BRANCH_INSTRUCTIONS", | 
|  | .desc    = "Retired Taken Branch Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc4, | 
|  | }, | 
|  | { .name    = "RETIRED_TAKEN_BRANCH_INSTRUCTIONS_MISPREDICTED", | 
|  | .desc    = "Retired Taken Branch Instructions Mispredicted", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc5, | 
|  | }, | 
|  | { .name    = "RETIRED_FAR_CONTROL_TRANSFERS", | 
|  | .desc    = "Retired Far Control Transfers", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc6, | 
|  | }, | 
|  | { .name    = "RETIRED_BRANCH_RESYNCS", | 
|  | .desc    = "Retired Branch Resyncs", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc7, | 
|  | }, | 
|  | { .name    = "RETIRED_NEAR_RETURNS", | 
|  | .desc    = "Retired Near Returns", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc8, | 
|  | }, | 
|  | { .name    = "RETIRED_NEAR_RETURNS_MISPREDICTED", | 
|  | .desc    = "Retired Near Returns Mispredicted", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xc9, | 
|  | }, | 
|  | { .name    = "RETIRED_INDIRECT_BRANCHES_MISPREDICTED", | 
|  | .desc    = "Retired Indirect Branches Mispredicted", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xca, | 
|  | }, | 
|  | { .name    = "RETIRED_MMX_AND_FP_INSTRUCTIONS", | 
|  | .desc    = "Retired MMX/FP Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xcb, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_retired_mmx_and_fp_instructions), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_retired_mmx_and_fp_instructions, | 
|  | }, | 
|  | { .name    = "RETIRED_FASTPATH_DOUBLE_OP_INSTRUCTIONS", | 
|  | .desc    = "Retired Fastpath Double Op Instructions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xcc, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_retired_fastpath_double_op_instructions), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_retired_fastpath_double_op_instructions, | 
|  | }, | 
|  | { .name    = "INTERRUPTS_MASKED_CYCLES", | 
|  | .desc    = "Interrupts-Masked Cycles", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xcd, | 
|  | }, | 
|  | { .name    = "INTERRUPTS_MASKED_CYCLES_WITH_INTERRUPT_PENDING", | 
|  | .desc    = "Interrupts-Masked Cycles with Interrupt Pending", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xce, | 
|  | }, | 
|  | { .name    = "INTERRUPTS_TAKEN", | 
|  | .desc    = "Interrupts Taken", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xcf, | 
|  | }, | 
|  | { .name    = "DECODER_EMPTY", | 
|  | .desc    = "Decoder Empty", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd0, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALLS", | 
|  | .desc    = "Dispatch Stalls", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd1, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_FOR_BRANCH_ABORT", | 
|  | .desc    = "Dispatch Stall for Branch Abort to Retire", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd2, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_FOR_SERIALIZATION", | 
|  | .desc    = "Dispatch Stall for Serialization", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd3, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_FOR_SEGMENT_LOAD", | 
|  | .desc    = "Dispatch Stall for Segment Load", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd4, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_FOR_REORDER_BUFFER_FULL", | 
|  | .desc    = "Dispatch Stall for Reorder Buffer Full", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd5, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_FOR_RESERVATION_STATION_FULL", | 
|  | .desc    = "Dispatch Stall for Reservation Station Full", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd6, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_FOR_FPU_FULL", | 
|  | .desc    = "Dispatch Stall for FPU Full", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd7, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_FOR_LS_FULL", | 
|  | .desc    = "Dispatch Stall for LS Full", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd8, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_WAITING_FOR_ALL_QUIET", | 
|  | .desc    = "Dispatch Stall Waiting for All Quiet", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xd9, | 
|  | }, | 
|  | { .name    = "DISPATCH_STALL_FOR_FAR_TRANSFER_OR_RSYNC", | 
|  | .desc    = "Dispatch Stall for Far Transfer or Resync to Retire", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xda, | 
|  | }, | 
|  | { .name    = "FPU_EXCEPTIONS", | 
|  | .desc    = "FPU Exceptions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xdb, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_fpu_exceptions), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_fpu_exceptions, | 
|  | }, | 
|  | { .name    = "DR0_BREAKPOINT_MATCHES", | 
|  | .desc    = "DR0 Breakpoint Matches", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xdc, | 
|  | }, | 
|  | { .name    = "DR1_BREAKPOINT_MATCHES", | 
|  | .desc    = "DR1 Breakpoint Matches", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xdd, | 
|  | }, | 
|  | { .name    = "DR2_BREAKPOINT_MATCHES", | 
|  | .desc    = "DR2 Breakpoint Matches", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xde, | 
|  | }, | 
|  | { .name    = "DR3_BREAKPOINT_MATCHES", | 
|  | .desc    = "DR3 Breakpoint Matches", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xdf, | 
|  | }, | 
|  | { .name    = "DRAM_ACCESSES_PAGE", | 
|  | .desc    = "DRAM Accesses", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xe0, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_dram_accesses_page), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_dram_accesses_page, | 
|  | }, | 
|  | { .name    = "MEMORY_CONTROLLER_PAGE_TABLE_OVERFLOWS", | 
|  | .desc    = "DRAM Controller Page Table Overflows", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xe1, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_memory_controller_page_table_overflows), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_memory_controller_page_table_overflows, | 
|  | }, | 
|  | { .name    = "MEMORY_CONTROLLER_SLOT_MISSES", | 
|  | .desc    = "Memory Controller DRAM Command Slots Missed", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xe2, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_memory_controller_slot_misses), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_memory_controller_slot_misses, | 
|  | }, | 
|  | { .name    = "MEMORY_CONTROLLER_TURNAROUNDS", | 
|  | .desc    = "Memory Controller Turnarounds", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xe3, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_memory_controller_turnarounds), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_memory_controller_turnarounds, | 
|  | }, | 
|  | { .name    = "MEMORY_CONTROLLER_BYPASS", | 
|  | .desc    = "Memory Controller Bypass Counter Saturation", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xe4, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_memory_controller_bypass), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_memory_controller_bypass, | 
|  | }, | 
|  | { .name    = "THERMAL_STATUS_AND_ECC_ERRORS", | 
|  | .desc    = "Thermal Status", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xe8, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_thermal_status_and_ecc_errors), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_thermal_status_and_ecc_errors, | 
|  | }, | 
|  | { .name    = "CPU_IO_REQUESTS_TO_MEMORY_IO", | 
|  | .desc    = "CPU/IO Requests to Memory/IO", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xe9, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_io_requests_to_memory_io), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_io_requests_to_memory_io, | 
|  | }, | 
|  | { .name    = "CACHE_BLOCK", | 
|  | .desc    = "Cache Block Commands", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xea, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cache_block), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cache_block, | 
|  | }, | 
|  | { .name    = "SIZED_COMMANDS", | 
|  | .desc    = "Sized Commands", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xeb, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_sized_commands), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_sized_commands, | 
|  | }, | 
|  | { .name    = "PROBE", | 
|  | .desc    = "Probe Responses and Upstream Requests", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xec, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_probe), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_probe, | 
|  | }, | 
|  | { .name    = "GART", | 
|  | .desc    = "GART Events", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xee, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_gart), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_gart, | 
|  | }, | 
|  | { .name    = "MEMORY_CONTROLLER_REQUESTS", | 
|  | .desc    = "Memory Controller Requests", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1f0, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_memory_controller_requests), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_memory_controller_requests, | 
|  | }, | 
|  | { .name    = "CPU_TO_DRAM_REQUESTS_TO_TARGET_NODE", | 
|  | .desc    = "CPU to DRAM Requests to Target Node", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1e0, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_to_dram_requests_to_target_node), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_to_dram_requests_to_target_node, | 
|  | }, | 
|  | { .name    = "IO_TO_DRAM_REQUESTS_TO_TARGET_NODE", | 
|  | .desc    = "IO to DRAM Requests to Target Node", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1e1, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_to_dram_requests_to_target_node), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_to_dram_requests_to_target_node, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "CPU_READ_COMMAND_LATENCY_TO_TARGET_NODE_0_3", | 
|  | .desc    = "CPU Read Command Latency to Target Node 0-3", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1e2, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_read_command_latency_to_target_node_0_3), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_read_command_latency_to_target_node_0_3, | 
|  | }, | 
|  | { .name    = "CPU_READ_COMMAND_REQUESTS_TO_TARGET_NODE_0_3", | 
|  | .desc    = "CPU Read Command Requests to Target Node 0-3", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1e3, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_read_command_latency_to_target_node_0_3), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_read_command_latency_to_target_node_0_3, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "CPU_READ_COMMAND_LATENCY_TO_TARGET_NODE_4_7", | 
|  | .desc    = "CPU Read Command Latency to Target Node 4-7", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1e4, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_read_command_latency_to_target_node_4_7), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_read_command_latency_to_target_node_4_7, | 
|  | }, | 
|  | { .name    = "CPU_READ_COMMAND_REQUESTS_TO_TARGET_NODE_4_7", | 
|  | .desc    = "CPU Read Command Requests to Target Node 4-7", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1e5, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_read_command_latency_to_target_node_4_7), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_read_command_latency_to_target_node_4_7, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "CPU_COMMAND_LATENCY_TO_TARGET_NODE_0_3_4_7", | 
|  | .desc    = "CPU Command Latency to Target Node 0-3/4-7", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1e6, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_command_latency_to_target_node_0_3_4_7), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_command_latency_to_target_node_0_3_4_7, | 
|  | }, | 
|  | { .name    = "CPU_REQUESTS_TO_TARGET_NODE_0_3_4_7", | 
|  | .desc    = "CPU Requests to Target Node 0-3/4-7", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1e7, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_cpu_command_latency_to_target_node_0_3_4_7), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_cpu_command_latency_to_target_node_0_3_4_7, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "HYPERTRANSPORT_LINK0", | 
|  | .desc    = "HyperTransport Link 0 Transmit Bandwidth", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xf6, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_hypertransport_link0), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_hypertransport_link0, | 
|  | }, | 
|  | { .name    = "HYPERTRANSPORT_LINK1", | 
|  | .desc    = "HyperTransport Link 1 Transmit Bandwidth", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xf7, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_hypertransport_link0), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_hypertransport_link0, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "HYPERTRANSPORT_LINK2", | 
|  | .desc    = "HyperTransport Link 2 Transmit Bandwidth", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0xf8, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_hypertransport_link0), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_hypertransport_link0, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "HYPERTRANSPORT_LINK3", | 
|  | .desc    = "HyperTransport Link 3 Transmit Bandwidth", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1f9, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_hypertransport_link3), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_hypertransport_link3, | 
|  | }, | 
|  | { .name    = "READ_REQUEST_TO_L3_CACHE", | 
|  | .desc    = "Read Request to L3 Cache", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4e0, | 
|  | .flags   = AMD64_FL_TILL_FAM10H_REV_C, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_read_request_to_l3_cache), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_read_request_to_l3_cache, | 
|  | }, | 
|  | { .name    = "L3_CACHE_MISSES", | 
|  | .desc    = "L3 Cache Misses", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4e1, | 
|  | .flags   = AMD64_FL_TILL_FAM10H_REV_C, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l3_cache_misses), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_l3_cache_misses, | 
|  | }, | 
|  | { .name    = "L3_FILLS_CAUSED_BY_L2_EVICTIONS", | 
|  | .desc    = "L3 Fills caused by L2 Evictions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4e2, | 
|  | .flags   = AMD64_FL_TILL_FAM10H_REV_C, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l3_fills_caused_by_l2_evictions), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_l3_fills_caused_by_l2_evictions, | 
|  | }, | 
|  | { .name    = "L3_EVICTIONS", | 
|  | .desc    = "L3 Evictions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4e3, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l3_evictions), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_l3_evictions, | 
|  | }, | 
|  | { .name    = "PAGE_SIZE_MISMATCHES", | 
|  | .desc    = "Page Size Mismatches", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x165, | 
|  | .flags   = AMD64_FL_FAM10H_REV_C, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_page_size_mismatches), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_page_size_mismatches, | 
|  | }, | 
|  | { .name    = "RETIRED_X87_OPS", | 
|  | .desc    = "Retired x87 Floating Point Operations", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1c0, | 
|  | .flags   = AMD64_FL_FAM10H_REV_C, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_retired_x87_ops), | 
|  | .ngrp    = 1, | 
|  | .umasks  = amd64_fam10h_retired_x87_ops, | 
|  | }, | 
|  | { .name    = "IBS_OPS_TAGGED", | 
|  | .desc    = "IBS Ops Tagged", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1cf, | 
|  | .flags   = AMD64_FL_FAM10H_REV_C, | 
|  | }, | 
|  | { .name    = "LFENCE_INST_RETIRED", | 
|  | .desc    = "LFENCE Instructions Retired", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1d3, | 
|  | .flags   = AMD64_FL_FAM10H_REV_C, | 
|  | }, | 
|  | { .name    = "SFENCE_INST_RETIRED", | 
|  | .desc    = "SFENCE Instructions Retired", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1d4, | 
|  | .flags   = AMD64_FL_FAM10H_REV_C, | 
|  | }, | 
|  | { .name    = "MFENCE_INST_RETIRED", | 
|  | .desc    = "MFENCE Instructions Retired", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x1d5, | 
|  | .flags   = AMD64_FL_FAM10H_REV_C, | 
|  | }, | 
|  | { .name    = "READ_REQUEST_TO_L3_CACHE", | 
|  | .desc    = "Read Request to L3 Cache", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4e0, | 
|  | .flags   = AMD64_FL_FAM10H_REV_D, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l3_cache_misses), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_l3_cache_misses, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "L3_CACHE_MISSES", | 
|  | .desc    = "L3 Cache Misses", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4e1, | 
|  | .flags   = AMD64_FL_FAM10H_REV_D, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l3_cache_misses), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_l3_cache_misses, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "L3_FILLS_CAUSED_BY_L2_EVICTIONS", | 
|  | .desc    = "L3 Fills caused by L2 Evictions", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4e2, | 
|  | .flags   = AMD64_FL_FAM10H_REV_D, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l3_fills_caused_by_l2_evictions), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_l3_fills_caused_by_l2_evictions, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | { .name    = "NON_CANCELLED_L3_READ_REQUESTS", | 
|  | .desc    = "Non-cancelled L3 Read Requests", | 
|  | .modmsk  = AMD64_FAM10H_ATTRS, | 
|  | .code    = 0x4ed, | 
|  | .flags   = AMD64_FL_FAM10H_REV_D, | 
|  | .numasks = LIBPFM_ARRAY_SIZE(amd64_fam10h_l3_cache_misses), | 
|  | .ngrp    = 2, | 
|  | .umasks  = amd64_fam10h_l3_cache_misses, /* identical to actual umasks list for this event */ | 
|  | }, | 
|  | }; |