Lines Matching +full:0 +full:x1b00
17 #define MSR_ARCH_PERFMON_PERFCTR0 0xc1
18 #define MSR_ARCH_PERFMON_PERFCTR1 0xc2
20 #define MSR_ARCH_PERFMON_EVENTSEL0 0x186
21 #define MSR_ARCH_PERFMON_EVENTSEL1 0x187
23 #define ARCH_PERFMON_EVENTSEL_EVENT 0x000000FFULL
24 #define ARCH_PERFMON_EVENTSEL_UMASK 0x0000FF00ULL
33 #define ARCH_PERFMON_EVENTSEL_CMASK 0xFF000000ULL
36 #define ARCH_PERFMON_EVENTSEL_UMASK2 (0xFFULL << 40)
38 #define INTEL_FIXED_BITS_MASK 0xFULL
40 #define INTEL_FIXED_0_KERNEL (1ULL << 0)
59 (0xFULL << AMD64_EVENTSEL_INT_CORE_SEL_SHIFT)
62 (ARCH_PERFMON_EVENTSEL_EVENT | (0x0FULL << 32))
68 (0xFULL << AMD64_L3_SLICE_SHIFT)
70 (0x7ULL << AMD64_L3_SLICE_SHIFT)
74 (0xFFULL << AMD64_L3_THREAD_SHIFT)
76 (0x3ULL << AMD64_L3_THREAD_SHIFT)
83 (0x7ULL << AMD64_L3_COREID_SHIFT)
119 #define AMD64_PERFMON_V2_EVENTSEL_EVENT_UMC GENMASK_ULL(7, 0)
129 #define ARCH_PERFMON_UNHALTED_CORE_CYCLES_SEL 0x3c
130 #define ARCH_PERFMON_UNHALTED_CORE_CYCLES_UMASK (0x00 << 8)
131 #define ARCH_PERFMON_UNHALTED_CORE_CYCLES_INDEX 0
138 #define PEBS_DATACFG_MEMINFO BIT_ULL(0)
189 #define ARCH_PERFMON_EXT_LEAF 0x00000023
190 #define ARCH_PERFMON_EXT_UMASK2 0x1
191 #define ARCH_PERFMON_EXT_EQ 0x2
192 #define ARCH_PERFMON_NUM_COUNTER_LEAF_BIT 0x1
193 #define ARCH_PERFMON_NUM_COUNTER_LEAF 0x1
278 #define MSR_ARCH_PERFMON_FIXED_CTR_CTRL 0x38d
289 * The pseudo event-code for a fixed-mode PMC must be 0x00.
290 * The pseudo umask-code is 0xX. The X equals the index of the fixed
291 * counter + 1, e.g., the fixed counter 2 has the pseudo-encoding 0x0300.
297 #define MSR_ARCH_PERFMON_FIXED_CTR0 0x309
298 #define INTEL_PMC_IDX_FIXED_INSTRUCTIONS (INTEL_PMC_IDX_FIXED + 0)
301 #define MSR_ARCH_PERFMON_FIXED_CTR1 0x30a
304 /* CPU_CLK_Unhalted.Ref: event=0x00,umask=0x3 (pseudo-encoding) */
305 #define MSR_ARCH_PERFMON_FIXED_CTR2 0x30b
309 /* TOPDOWN.SLOTS: event=0x00,umask=0x4 (pseudo-encoding) */
310 #define MSR_ARCH_PERFMON_FIXED_CTR3 0x30c
320 return !(code & 0xff); in use_fixed_pseudo_encoding()
339 #define INTEL_PMC_IDX_TD_RETIRING (INTEL_PMC_IDX_METRIC_BASE + 0)
348 #define INTEL_PMC_MSK_TOPDOWN ((0xffull << INTEL_PMC_IDX_METRIC_BASE) | \
356 * For the metric events, the pseudo event-code is 0x00.
358 * space, 0x80.
360 #define INTEL_TD_SLOTS 0x0400 /* TOPDOWN.SLOTS */
362 #define INTEL_TD_METRIC_RETIRING 0x8000 /* Retiring metric */
363 #define INTEL_TD_METRIC_BAD_SPEC 0x8100 /* Bad speculation metric */
364 #define INTEL_TD_METRIC_FE_BOUND 0x8200 /* FE bound metric */
365 #define INTEL_TD_METRIC_BE_BOUND 0x8300 /* BE bound metric */
367 #define INTEL_TD_METRIC_HEAVY_OPS 0x8400 /* Heavy Operations metric */
368 #define INTEL_TD_METRIC_BR_MISPREDICT 0x8500 /* Branch Mispredict metric */
369 #define INTEL_TD_METRIC_FETCH_LAT 0x8600 /* Fetch Latency metric */
370 #define INTEL_TD_METRIC_MEM_BOUND 0x8700 /* Memory bound metric */
386 (~(0x1ull << bit) & INTEL_PMC_MSK_TOPDOWN)
415 * Pseudo-encoding the guest LBR event as event=0x00,umask=0x1b,
418 #define INTEL_FIXED_VLBR_EVENT 0x1b00
450 #define EXT_PERFMON_DEBUG_FEATURES 0x80000022
456 #define IBS_CPUID_FEATURES 0x8000001b
460 * bit 0 is used to indicate the existence of IBS.
462 #define IBS_CAPS_AVAIL (1U<<0)
482 #define IBSCTL 0x1cc
484 #define IBSCTL_LVT_OFFSET_MASK 0x0F
491 #define IBS_FETCH_CNT 0xFFFF0000ULL
492 #define IBS_FETCH_MAX_CNT 0x0000FFFFULL
499 #define IBS_OP_CUR_CNT (0xFFF80ULL<<32)
500 #define IBS_OP_CUR_CNT_RAND (0x0007FULL<<32)
505 #define IBS_OP_MAX_CNT 0x0000FFFFULL
506 #define IBS_OP_MAX_CNT_EXT 0x007FFFFFULL /* not a register bit mask */
507 #define IBS_OP_MAX_CNT_EXT_MASK (0x7FULL<<20) /* separate upper 7 bits */
514 static inline u32 get_ibs_caps(void) { return 0; } in get_ibs_caps()
523 * unused and ABI specified to be 0, so nobody should care what we do with
551 (regs)->sp = (unsigned long)__builtin_frame_address(0); \
553 regs->flags = 0; \
577 memset(cap, 0, sizeof(*cap)); in perf_get_x86_pmu_capability()
582 return 0; in perf_get_hw_event_config()
596 memset(lbr, 0, sizeof(*lbr)); in x86_perf_get_lbr()