#include <perfmon/perfmon_intel.h> static perfmon_intel_pmc_cpu_model_t cpu_model_table[] = { {0x2A, 0x00, 0}, }; static perfmon_intel_pmc_event_t event_table[] = { { .event_code = {0x00}, .umask = 0x03, .event_name = "cpu_clk_unhalted.ref_tsc", }, { .event_code = {0x00}, .umask = 0x01, .event_name = "inst_retired.any", }, { .event_code = {0x00}, .umask = 0x02, .event_name = "cpu_clk_unhalted.thread", }, { .event_code = {0x00}, .umask = 0x02, .event_name = "cpu_clk_unhalted.thread_any", }, { .event_code = {0x03}, .umask = 0x01, .event_name = "ld_blocks.data_unknown", }, { .event_code = {0x03}, .umask = 0x02, .event_name = "ld_blocks.store_forward", }, { .event_code = {0x03}, .umask = 0x08, .event_name = "ld_blocks.no_sr", }, { .event_code = {0x03}, .umask = 0x10, .event_name = "ld_blocks.all_block", }, { .event_code = {0x05}, .umask = 0x01, .event_name = "misalign_mem_ref.loads", }, { .event_code = {0x05}, .umask = 0x02, .event_name = "misalign_mem_ref.stores", }, { .event_code = {0x07}, .umask = 0x01, .event_name = "ld_blocks_partial.address_alias", }, { .event_code = {0x07}, .umask = 0x08, .event_name = "ld_blocks_partial.all_sta_block", }, { .event_code = {0x08}, .umask = 0x01, .event_name = "dtlb_load_misses.miss_causes_a_walk", }, { .event_code = {0x08}, .umask = 0x02, .event_name = "dtlb_load_misses.walk_completed", }, { .event_code = {0x08}, .umask = 0x04, .event_name = "dtlb_load_misses.walk_duration", }, { .event_code = {0x08}, .umask = 0x10, .event_name = "dtlb_load_misses.stlb_hit", }, { .event_code = {0x0D}, .umask = 0x03, .event_name = "int_misc.recovery_cycles", }, { .event_code = {0x0D}, .umask = 0x03, .event_name = "int_misc.recovery_stalls_count", }, { .event_code = {0x0D}, .umask = 0x03, .event_name = "int_misc.recovery_cycles_any", }, { .event_code = {0x0D}, .umask = 0x40, .event_name = "int_misc.rat_stall_cycles", }, { .event_code = {0x0E}, .umask = 0x01, .event_name = "uops_issued.any", }, { .event_code = {0x0E}, .umask = 0x01, .event_name = "uops_issued.stall_cycles", }, { .event_code = {0x0E}, .umask = 0x01, .event_name = "uops_issued.core_stall_cycles", }, { .event_code = {0x10}, .umask = 0x01, .event_name = "fp_comp_ops_exe.x87", }, { .event_code = {0x10}, .umask = 0x10, .event_name = "fp_comp_ops_exe.sse_packed_double", }, { .event_code = {0x10}, .umask = 0x20, .event_name = "fp_comp_ops_exe.sse_scalar_single", }, { .event_code = {0x10}, .umask = 0x40, .event_name = "fp_comp_ops_exe.sse_packed_single", }, { .event_code = {0x10}, .umask = 0x80, .event_name = "fp_comp_ops_exe.sse_scalar_double", }, { .event_code = {0x11}, .umask = 0x01, .event_name = "simd_fp_256.packed_single", }, { .event_code = {0x11}, .umask = 0x02, .event_name = "simd_fp_256.packed_double", }, { .event_code = {0x14}, .umask = 0x01, .event_name = "arith.fpu_div_active", }, { .event_code = {0x14}, .umask = 0x01, .event_name = "arith.fpu_div", }, { .event_code = {0x17}, .umask = 0x01, .event_name = "insts_written_to_iq.insts", }, { .event_code = {0x24}, .umask = 0x01, .event_name = "l2_rqsts.demand_data_rd_hit", }, { .event_code = {0x24}, .umask = 0x03, .event_name = "l2_rqsts.all_demand_data_rd", }, { .event_code = {0x24}, .umask = 0x04, .event_name = "l2_rqsts.rfo_hit", }, { .event_code = {0x24}, .umask = 0x08, .event_name = "l2_rqsts.rfo_miss", }, { .event_code = {0x24}, .umask = 0x0C, .event_name = "l2_rqsts.all_rfo", }, { .event_code = {0x24}, .umask = 0x10, .event_name = "l2_rqsts.code_rd_hit", }, { .event_code = {0x24}, .umask = 0x20, .event_name = "l2_rqsts.code_rd_miss", }, { .event_code = {0x24}, .umask = 0x30, .event_name = "l2_rqsts.all_code_rd", }, { .event_code = {0x24}, .umask = 0x40, .event_name = "l2_rqsts.pf_hit", }, { .event_code = {0x24}, .umask = 0x80, .event_name = "l2_rqsts.pf_miss", }, { .event_code = {0x24}, .umask = 0xC0, .event_name = "l2_rqsts.all_pf", }, { .event_code = {0x27}, .umask = 0x01, .event_name = "l2_store_lock_rqsts.miss", }, { .event_code = {0x27}, .umask = 0x04, .event_name = "l2_store_lock_rqsts.hit_e", }, { .event_code = {0x27}, .umask = 0x08, .event_name = "l2_store_lock_rqsts.hit_m", }, { .event_code = {0x27}, .umask = 0x0F, .event_name = "l2_store_lock_rqsts.all", }, { .event_code = {0x28}, .umask = 0x01, .event_name = "l2_l1d_wb_rqsts.miss", }, { .event_code = {0x28}, .umask = 0x02, .event_name = "l2_l1d_wb_rqsts.hit_s", }, { .event_code = {0x28}, .umask = 0x04, .event_name = "l2_l1d_wb_rqsts.hit_e", }, { .event_code = {0x28}, .umask = 0x08, .event_name = "l2_l1d_wb_rqsts.hit_m", }, { .event_code = {0x28}, .umask = 0x0F, .event_name = "l2_l1d_wb_rqsts.all", }, { .event_code = {0x2E}, .umask = 0x41, .event_name = "longest_lat_cache.miss", }, { .event_code = {0x2E}, .umask = 0x4F, .event_name = "longest_lat_cache.reference", }, { .event_code = {0x3C}, .umask = 0x00, .event_name = "cpu_clk_unhalted.thread_p", }, { .event_code = {0x3C}, .umask = 0x00, .event_name = "cpu_clk_unhalted.thread_p_any", }, { .event_code = {0x3C}, .umask = 0x01, .event_name = "cpu_clk_thread_unhalted.ref_xclk", }, { .event_code = {0x3C}, .umask = 0x02, .event_name = "cpu_clk_thread_unhalted.one_thread_active", }, { .event_code = {0x48}, .umask = 0x01, .event_name = "l1d_pend_miss.pending", }, { .event_code = {0x48}, .umask = 0x01, .event_name = "l1d_pend_miss.pending_cycles", }, { .event_code = {0x49}, .umask = 0x01, .event_name = "dtlb_store_misses.miss_causes_a_walk", }, { .event_code = {0x49}, .umask = 0x02, .event_name = "dtlb_store_misses.walk_completed", }, { .event_code = {0x49}, .umask = 0x04, .event_name = "dtlb_store_misses.walk_duration", }, { .event_code = {0x49}, .umask = 0x10, .event_name = "dtlb_store_misses.stlb_hit", }, { .event_code = {0x4C}, .umask = 0x01, .event_name = "load_hit_pre.sw_pf", }, { .event_code = {0x4C}, .umask = 0x02, .event_name = "load_hit_pre.hw_pf", }, { .event_code = {0x4E}, .umask = 0x02, .event_name = "hw_pre_req.dl1_miss", }, { .event_code = {0x4F}, .umask = 0x10, .event_name = "ept.walk_cycles", }, { .event_code = {0x51}, .umask = 0x01, .event_name = "l1d.replacement", }, { .event_code = {0x51}, .umask = 0x02, .event_name = "l1d.allocated_in_m", }, { .event_code = {0x51}, .umask = 0x04, .event_name = "l1d.eviction", }, { .event_code = {0x51}, .umask = 0x08, .event_name = "l1d.all_m_replacement", }, { .event_code = {0x59}, .umask = 0x20, .event_name = "partial_rat_stalls.flags_merge_uop", }, { .event_code = {0x59}, .umask = 0x20, .event_name = "partial_rat_stalls.flags_merge_uop_cycles", }, { .event_code = {0x59}, .umask = 0x40, .event_name = "partial_rat_stalls.slow_lea_window", }, { .event_code = {0x59}, .umask = 0x80, .event_name = "partial_rat_stalls.mul_single_uop", }, { .event_code = {0x5B}, .umask = 0x0C, .event_name = "resource_stalls2.all_fl_empty", }, { .event_code = {0x5B}, .umask = 0x0F, .event_name = "resource_stalls2.all_prf_control", }, { .event_code = {0x5B}, .umask = 0x40, .event_name = "resource_stalls2.bob_full", }, { .event_code = {0x5B}, .umask = 0x4F, .event_name = "resource_stalls2.ooo_rsrc", }, { .event_code = {0x5C}, .umask = 0x01, .event_name = "cpl_cycles.ring0", }, { .event_code = {0x5C}, .umask = 0x01, .event_name = "cpl_cycles.ring0_trans", }, { .event_code = {0x5C}, .umask = 0x02, .event_name = "cpl_cycles.ring123", }, { .event_code = {0x5E}, .umask = 0x01, .event_name = "rs_events.empty_cycles", }, { .event_code = {0x5E}, .umask = 0x01, .event_name = "rs_events.empty_end", }, { .event_code = {0x60}, .umask = 0x01, .event_name = "offcore_requests_outstanding.demand_data_rd", }, { .event_code = {0x60}, .umask = 0x01, .event_name = "offcore_requests_outstanding.cycles_with_demand_data_rd", }, { .event_code = {0x60}, .umask = 0x04, .event_name = "offcore_requests_outstanding.demand_rfo", }, { .event_code = {0x60}, .umask = 0x04, .event_name = "offcore_requests_outstanding.cycles_with_demand_rfo", }, { .event_code = {0x60}, .umask = 0x08, .event_name = "offcore_requests_outstanding.all_data_rd", }, { .event_code = {0x60}, .umask = 0x08, .event_name = "offcore_requests_outstanding.cycles_with_data_rd", }, { .event_code = {0x63}, .umask = 0x01, .event_name = "lock_cycles.split_lock_uc_lock_duration", }, { .event_code = {0x63}, .umask = 0x02, .event_name = "lock_cycles.cache_lock_duration", }, { .event_code = {0x79}, .umask = 0x02, .event_name = "idq.empty", }, { .event_code = {0x79}, .umask = 0x04, .event_name = "idq.mite_uops", }, { .event_code = {0x79}, .umask = 0x04, .event_name = "idq.mite_cycles", }, { .event_code = {0x79}, .umask = 0x08, .event_name = "idq.dsb_uops", }, { .event_code = {0x79}, .umask = 0x08, .event_name = "idq.dsb_cycles", }, { .event_code = {0x79}, .umask = 0x10, .event_name = "idq.ms_dsb_uops", }, { .event_code = {0x79}, .umask = 0x10, .event_name = "idq.ms_dsb_cycles", }, { .event_code = {0x79}, .umask = 0x10, .event_name = "idq.ms_dsb_occur", }, { .event_code = {0x79}, .umask = 0x18, .event_name = "idq.all_dsb_cycles_4_uops", }, { .event_code = {0x79}, .umask = 0x18, .event_name = "idq.all_dsb_cycles_any_uops", }, { .event_code = {0x79}, .umask = 0x20, .event_name = "idq.ms_mite_uops", }, { .event_code = {0x79}, .umask = 0x24, .event_name = "idq.all_mite_cycles_4_uops", }, { .event_code = {0x79}, .umask = 0x24, .event_name = "idq.all_mite_cycles_any_uops", }, { .event_code = {0x79}, .umask = 0x30, .event_name = "idq.ms_uops", }, { .event_code = {0x79}, .umask = 0x30, .event_name = "idq.ms_cycles", }, { .event_code = {0x79}, .umask = 0x30, .event_name = "idq.ms_switches", }, { .event_code = {0x79}, .umask = 0x3c, .event_name = "idq.mite_all_uops", }, { .event_code = {0x80}, .umask = 0x01, .event_name = "icache.hit", }, { .event_code = {0x80}, .umask = 0x02, .event_name = "icache.misses", }, { .event_code = {0x85}, .umask = 0x01, .event_name = "itlb_misses.miss_causes_a_walk", }, { .event_code = {0x85}, .umask = 0x02, .event_name = "itlb_misses.walk_completed", }, { .event_code = {0x85}, .umask = 0x04, .event_name = "itlb_misses.walk_duration", }, { .event_code = {0x85}, .umask = 0x10, .event_name = "itlb_misses.stlb_hit", }, { .event_code = {0x87}, .umask = 0x01, .event_name = "ild_stall.lcp", }, { .event_code = {0x87}, .umask = 0x04, .event_name = "ild_stall.iq_full", }, { .event_code = {0x88}, .umask = 0x41, .event_name = "br_inst_exec.nontaken_conditional", }, { .event_code = {0x88}, .umask = 0x81, .event_name = "br_inst_exec.taken_conditional", }, { .event_code = {0x88}, .umask = 0x82, .event_name = "br_inst_exec.taken_direct_jump", }, { .event_code = {0x88}, .umask = 0x84, .event_name = "br_inst_exec.taken_indirect_jump_non_call_ret", }, { .event_code = {0x88}, .umask = 0x88, .event_name = "br_inst_exec.taken_indirect_near_return", }, { .event_code = {0x88}, .umask = 0x90, .event_name = "br_inst_exec.taken_direct_near_call", }, { .event_code = {0x88}, .umask = 0xA0, .event_name = "br_inst_exec.taken_indirect_near_call", }, { .event_code = {0x88}, .umask = 0xC1, .event_name = "br_inst_exec.all_conditional", }, { .event_code = {0x88}, .umask = 0xC2, .event_name = "br_inst_exec.all_direct_jmp", }, { .event_code = {0x88}, .umask = 0xC4, .event_name = "br_inst_exec.all_indirect_jump_non_call_ret", }, { .event_code = {0x88}, .umask = 0xC8, .event_name = "br_inst_exec.all_indirect_near_return", }, { .event_code = {0x88}, .umask = 0xD0, .event_name = "br_inst_exec.all_direct_near_call", }, { .event_code = {0x88}, .umask = 0xFF, .event_name = "br_inst_exec.all_branches", }, { .event_code = {0x89}, .umask = 0x41, .event_name = "br_misp_exec.nontaken_conditional", }, { .event_code = {0x89}, .umask = 0x81, .event_name = "br_misp_exec.taken_conditional", }, { .event_code = {0x89}, .umask = 0x84, .event_name = "br_misp_exec.taken_indirect_jump_non_call_ret", }, { .event_code = {0x89}, .umask = 0x88, .event_name = "br_misp_exec.taken_return_near", }, { .event_code = {0x89}, .umask = 0x90, .event_name = "br_misp_exec.taken_direct_near_call", }, { .event_code = {0x89}, .umask = 0xA0, .event_name = "br_misp_exec.taken_indirect_near_call", }, { .event_code = {0x89}, .umask = 0xC1, .event_name = "br_misp_exec.all_conditional", }, { .event_code = {0x89}, .umask = 0xC4, .event_name = "br_misp_exec.all_indirect_jump_non_call_ret", }, { .event_code = {0x89}, .umask = 0xD0, .event_name = "br_misp_exec.all_direct_near_call", }, { .event_code = {0x89}, .umask = 0xFF, .event_name = "br_misp_exec.all_branches", }, { .event_code = {0x9C}, .umask = 0x01, .event_name = "idq_uops_not_delivered.core", }, { .event_code = {0x9C}, .umask = 0x01, .event_name = "idq_uops_not_delivered.cycles_0_uops_deliv.core", }, { .event_code = {0x9C}, .umask = 0x01, .event_name = "idq_uops_not_delivered.cycles_le_1_uop_deliv.core", }, { .event_code = {0x9C}, .umask = 0x01, .event_name = "idq_uops_not_delivered.cycles_le_2_uop_deliv.core", }, { .event_code = {0x9C}, .umask = 0x01, .event_name = "idq_uops_not_delivered.cycles_le_3_uop_deliv.core", }, { .event_code = {0x9C}, .umask = 0x01, .event_name = "idq_uops_not_delivered.cycles_ge_1_uop_deliv.core", }, { .event_code = {0x9C}, .umask = 0x01, .event_name = "idq_uops_not_delivered.cycles_fe_was_ok", }, { .event_code = {0xA1}, .umask = 0x01, .event_name = "uops_dispatched_port.port_0", }, { .event_code = {0xA1}, .umask = 0x01, .event_name = "uops_dispatched_port.port_0_core", }, { .event_code = {0xA1}, .umask = 0x02, .event_name = "uops_dispatched_port.port_1", }, { .event_code = {0xA1}, .umask = 0x02, .event_name = "uops_dispatched_port.port_1_core", }, { .event_code = {0xA1}, .umask = 0x0C, .event_name = "uops_dispatched_port.port_2", }, { .event_code = {0xA1}, .umask = 0x0C, .event_name = "uops_dispatched_port.port_2_core", }, { .event_code = {0xA1}, .umask = 0x30, .event_name = "uops_dispatched_port.port_3", }, { .event_code = {0xA1}, .umask = 0x30, .event_name = "uops_dispatched_port.port_3_core", }, { .event_code = {0xA1}, .umask = 0x40, .event_name = "uops_dispatched_port.port_4", }, { .event_code = {0xA1}, .umask = 0x40, .event_name = "uops_dispatched_port.port_4_core", }, { .event_code = {0xA1}, .umask = 0x80, .event_name = "uops_dispatched_port.port_5", }, { .event_code = {0xA1}, .umask = 0x80, .event_name = "uops_dispatched_port.port_5_core", }, { .event_code = {0xA2}, .umask = 0x01, .event_name = "resource_stalls.any", }, { .event_code = {0xA2}, .umask = 0x02, .event_name = "resource_stalls.lb", }, { .event_code = {0xA2}, .umask = 0x04, .event_name = "resource_stalls.rs", }, { .event_code = {0xA2}, .umask = 0x08, .event_name = "resource_stalls.sb", }, { .event_code = {0xA2}, .umask = 0x0A, .event_name = "resource_stalls.lb_sb", }, { .event_code = {0xA2}, .umask = 0x0E, .event_name = "resource_stalls.mem_rs", }, { .event_code = {0xA2}, .umask = 0x10, .event_name = "resource_stalls.rob", }, { .event_code = {0xA2}, .umask = 0xF0, .event_name = "resource_stalls.ooo_rsrc", }, { .event_code = {0xA3}, .umask = 0x01, .event_name = "cycle_activity.cycles_l2_pending", }, { .event_code = {0xA3}, .umask = 0x02, .event_name = "cycle_activity.cycles_l1d_pending", }, { .event_code = {0xA3}, .umask = 0x04, .event_name = "cycle_activity.cycles_no_dispatch", }, { .event_code = {0xA3}, .umask = 0x05, .event_name = "cycle_activity.stalls_l2_pending", }, { .event_code = {0xA3}, .umask = 0x06, .event_name = "cycle_activity.stalls_l1d_pending", }, { .event_code = {0xA8}, .umask = 0x01, .event_name = "lsd.uops", }, { .event_code = {0xA8}, .umask = 0x01, .event_name = "lsd.cycles_active", }, { .event_code = {0xA8}, .umask = 0x01, .event_name = "lsd.cycles_4_uops", }, { .event_code = {0xAB}, .umask = 0x01, .event_name = "dsb2mite_switches.count", }, { .event_code = {0xAB}, .umask = 0x02, .event_name = "dsb2mite_switches.penalty_cycles", }, { .event_code = {0xAC}, .umask = 0x02, .event_name = "dsb_fill.other_cancel", }, { .event_code = {0xAC}, .umask = 0x08, .event_name = "dsb_fill.exceed_dsb_lines", }, { .event_code = {0xAC}, .umask = 0x0A, .event_name = "dsb_fill.all_cancel", }, { .event_code = {0xAE}, .umask = 0x01, .event_name = "itlb.itlb_flush", }, { .event_code = {0xB0}, .umask = 0x01, .event_name = "offcore_requests.demand_data_rd", }, { .event_code = {0xB0}, .umask = 0x02, .event_name = "offcore_requests.demand_code_rd", }, { .event_code = {0xB0}, .umask = 0x04, .event_name = "offcore_requests.demand_rfo", }, { .event_code = {0xB0}, .umask = 0x08, .event_name = "offcore_requests.all_data_rd", }, { .event_code = {0xB1}, .umask = 0x01, .event_name = "uops_dispatched.thread", }, { .event_code = {0xB1}, .umask = 0x02, .event_name = "uops_dispatched.core", }, { .event_code = {0xB2}, .umask = 0x01, .event_name = "offcore_requests_buffer.sq_full", }, { .event_code = {0xB6}, .umask = 0x01, .event_name = "agu_bypass_cancel.count", }, { .event_code = {0xBD}, .umask = 0x01, .event_name = "tlb_flush.dtlb_thread", }, { .event_code = {0xBD}, .umask = 0x20, .event_name = "tlb_flush.stlb_any", }, { .event_code = {0xBE}, .umask = 0x01, .event_name = "page_walks.llc_miss", }, { .event_code = {0xBF}, .umask = 0x05, .event_name = "l1d_blocks.bank_conflict_cycles", }, { .event_code = {0xC0}, .umask = 0x00, .event_name = "inst_retired.any_p", }, { .event_code = {0xC0}, .umask = 0x01, .event_name = "inst_retired.prec_dist", }, { .event_code = {0xC1}, .umask = 0x02, .event_name = "other_assists.itlb_miss_retired", }, { .event_code = {0xC1}, .umask = 0x08, .event_name = "other_assists.avx_store", }, { .event_code = {0xC1}, .umask = 0x10, .event_name = "other_assists.avx_to_sse", }, { .event_code = {0xC1}, .umask = 0x20, .event_name = "other_assists.sse_to_avx", }, { .event_code = {0xC2}, .umask = 0x01, .event_name = "uops_retired.all", }, { .event_code = {0xC2}, .umask = 0x01, .event_name = "uops_retired.stall_cycles", }, { .event_code = {0xC2}, .umask = 0x01, .event_name = "uops_retired.total_cycles", }, { .event_code = {0xC2}, .umask = 0x01, .event_name = "uops_retired.core_stall_cycles", }, { .event_code = {0xC2}, .umask = 0x02, .event_name = "uops_retired.retire_slots", }, { .event_code = {0xc3}, .umask = 0x01, .event_name = "machine_clears.count", }, { .event_code = {0xC3}, .umask = 0x02, .event_name = "machine_clears.memory_ordering", }, { .event_code = {0xC3}, .umask = 0x04, .event_name = "machine_clears.smc", }, { .event_code = {0xC3}, .umask = 0x20, .event_name = "machine_clears.maskmov", }, { .event_code = {0xC4}, .umask = 0x00, .event_name = "br_inst_retired.all_branches", }, { .event_code = {0xC4}, .umask = 0x01, .event_name = "br_inst_retired.conditional", }, { .event_code = {0xC4}, .umask = 0x02, .event_name = "br_inst_retired.near_call", }, { .event_code = {0xC4}, .umask = 0x02, .event_name = "br_inst_retired.near_call_r3", }, { .event_code = {0xC4}, .umask = 0x04, .event_name = "br_inst_retired.all_branches_pebs", }, { .event_code = {0xC4}, .umask = 0x08, .event_name = "br_inst_retired.near_return", }, { .event_code = {0xC4}, .umask = 0x10, .event_name = "br_inst_retired.not_taken", }, { .event_code = {0xC4}, .umask = 0x20, .event_name = "br_inst_retired.near_taken", }, { .event_code = {0xC4}, .umask = 0x40, .event_name = "br_inst_retired.far_branch", }, { .event_code = {0xC5}, .umask = 0x00, .event_name = "br_misp_retired.all_branches", }, { .event_code = {0xC5}, .umask = 0x01, .event_name = "br_misp_retired.conditional", }, { .event_code = {0xC5}, .umask = 0x02, .event_name = "br_misp_retired.near_call", }, { .event_code = {0xC5}, .umask = 0x04, .event_name = "br_misp_retired.all_branches_pebs", }, { .event_code = {0xC5}, .umask = 0x10, .event_name = "br_misp_retired.not_taken", }, { .event_code = {0xC5}, .umask = 0x20, .event_name = "br_misp_retired.taken", }, { .event_code = {0xCA}, .umask = 0x02, .event_name = "fp_assist.x87_output", }, { .event_code = {0xCA}, .umask = 0x04, .event_name = "fp_assist.x87_input", }, { .event_code = {0xCA}, .umask = 0x08, .event_name = "fp_assist.simd_output", }, { .event_code = {0xCA}, .umask = 0x10, .event_name = "fp_assist.simd_input", }, { .event_code = {0xCA}, .umask = 0x1E, .event_name = "fp_assist.any", }, { .event_code = {0xCC}, .umask = 0x20, .event_name = "rob_misc_events.lbr_inserts", }, { .event_code = {0xCD}, .umask = 0x02, .event_name = "mem_trans_retired.precise_store", }, { .event_code = {0xD0}, .umask = 0x11, .event_name = "mem_uops_retired.stlb_miss_loads", }, { .event_code = {0xD0}, .umask = 0x12, .event_name = "mem_uops_retired.stlb_miss_stores", }, { .event_code = {0xD0}, .umask = 0x21, .event_name = "mem_uops_retired.lock_loads", }, { .event_code = {0xD0}, .umask = 0x41, .event_name = "mem_uops_retired.split_loads", }, { .event_code = {0xD0}, .umask = 0x42, .event_name = "mem_uops_retired.split_stores", }, { .event_code = {0xD0}, .umask = 0x81, .event_name = "mem_uops_retired.all_loads", }, { .event_code = {0xD0}, .umask = 0x82, .event_name = "mem_uops_retired.all_stores", }, { .event_code = {0xD1}, .umask = 0x01, .event_name = "mem_load_uops_retired.l1_hit", }, { .event_code = {0xD1}, .umask = 0x02, .event_name = "mem_load_uops_retired.l2_hit", }, { .event_code = {0xD1}, .umask = 0x04, .event_name = "mem_load_uops_retired.llc_hit", }, { .event_code = {0xD1}, .umask = 0x40, .event_name = "mem_load_uops_retired.hit_lfb", }, { .event_code = {0xD2}, .umask = 0x01, .event_name = "mem_load_uops_llc_hit_retired.xsnp_miss", }, { .event_code = {0xD2}, .umask = 0x02, .event_name = "mem_load_uops_llc_hit_retired.xsnp_hit", }, { .event_code = {0xD2}, .umask = 0x04, .event_name = "mem_load_uops_llc_hit_retired.xsnp_hitm", }, { .event_code = {0xD2}, .umask = 0x08, .event_name = "mem_load_uops_llc_hit_retired.xsnp_none", }, { .event_code = {0xD4}, .umask = 0x02, .event_name = "mem_load_uops_misc_retired.llc_miss", }, { .event_code = {0xE6}, .umask = 0x1F, .event_name = "baclears.any", }, { .event_code = {0xF0}, .umask = 0x01, .event_name = "l2_trans.demand_data_rd", }, { .event_code = {0xF0}, .umask = 0x02, .event_name = "l2_trans.rfo", }, { .event_code = {0xF0}, .umask = 0x04, .event_name = "l2_trans.code_rd", }, { .event_code = {0xF0}, .umask = 0x08, .event_name = "l2_trans.all_pf", }, { .event_code = {0xF0}, .umask = 0x10, .event_name = "l2_trans.l1d_wb", }, { .event_code = {0xF0}, .umask = 0x20, .event_name = "l2_trans.l2_fill", }, { .event_code = {0xF0}, .umask = 0x40, .event_name = "l2_trans.l2_wb", }, { .event_code = {0xF0}, .umask = 0x80, .event_name = "l2_trans.all_requests", }, { .event_code = {0xF1}, .umask = 0x01, .event_name = "l2_lines_in.i", }, { .event_code = {0xF1}, .umask = 0x02, .event_name = "l2_lines_in.s", }, { .event_code = {0xF1}, .umask = 0x04, .event_name = "l2_lines_in.e", }, { .event_code = {0xF1}, .umask = 0x07, .event_name = "l2_lines_in.all", }, { .event_code = {0xF2}, .umask = 0x01, .event_name = "l2_lines_out.demand_clean", }, { .event_code = {0xF2}, .umask = 0x02, .event_name = "l2_lines_out.demand_dirty", }, { .event_code = {0xF2}, .umask = 0x04, .event_name = "l2_lines_out.pf_clean", }, { .event_code = {0xF2}, .umask = 0x08, .event_name = "l2_lines_out.pf_dirty", }, { .event_code = {0xF2}, .umask = 0x0A, .event_name = "l2_lines_out.dirty_all", }, { .event_code = {0xF4}, .umask = 0x10, .event_name = "sq_misc.split_lock", }, { .event_name = 0, }, }; PERFMON_REGISTER_INTEL_PMC (cpu_model_table, event_table);