Lines Matching refs:event

11 PMU_FORMAT_ATTR(event,		"config:0-49");
45 static inline bool event_is_fab_match(u64 event)
48 event &= 0xff0fe;
51 return (event == 0x30056 || event == 0x4f052);
54 static bool is_event_valid(u64 event)
63 return !(event & ~valid_mask);
66 static inline bool is_event_marked(u64 event)
68 if (event & EVENT_IS_MARKED)
74 static unsigned long sdar_mod_val(u64 event)
77 return p10_SDAR_MODE(event);
79 return p9_SDAR_MODE(event);
82 static void mmcra_sdar_mode(u64 event, unsigned long *mmcra)
93 * Marked event: MMCRA[SDAR_MODE] will be set to 0b00 ('No Updates'),
96 * MMCRA[SDAR_MODE] will be set from event code.
97 * If sdar_mode from event is zero, default to 0b01. Hardware
101 if (is_event_marked(event) || (*mmcra & MMCRA_SAMPLE_ENABLE))
103 else if (sdar_mod_val(event))
104 *mmcra |= sdar_mod_val(event) << MMCRA_SDAR_MODE_SHIFT;
119 static unsigned long combine_from_event(u64 event)
122 return p9_EVENT_COMBINE(event);
124 return EVENT_COMBINE(event);
135 static inline bool event_is_threshold(u64 event)
137 return (event >> EVENT_THR_SEL_SHIFT) & EVENT_THR_SEL_MASK;
140 static bool is_thresh_cmp_valid(u64 event)
147 * Power10: thresh_cmp is replaced by l2_l3 event select.
152 cmp = (event >> EVENT_THR_CMP_SHIFT) & EVENT_THR_CMP_MASK;
161 static unsigned int dc_ic_rld_quad_l1_sel(u64 event)
165 cache = (event >> EVENT_CACHE_SEL_SHIFT) & MMCR1_DC_IC_QUAL_MASK;
259 int isa207_get_constraint(u64 event, unsigned long *maskp, unsigned long *valp)
266 if (!is_event_valid(event))
269 pmc = (event >> EVENT_PMC_SHIFT) & EVENT_PMC_MASK;
270 unit = (event >> EVENT_UNIT_SHIFT) & EVENT_UNIT_MASK;
272 cache = (event >> EVENT_CACHE_SEL_SHIFT) &
275 cache = (event >> EVENT_CACHE_SEL_SHIFT) &
277 ebb = (event >> EVENT_EBB_SHIFT) & EVENT_EBB_MASK;
285 /* Ignore Linux defined bits when checking event below */
286 base_event = event & ~EVENT_LINUX_MASK;
309 * Don't count events on PMC 5 & 6, there is only one valid event
320 value |= CNST_L2L3_GROUP_VAL(event >> p10_L2L3_EVENT_SHIFT);
324 value |= CNST_CACHE_GROUP_VAL(event & 0xff);
342 } else if (cpu_has_feature(CPU_FTR_ARCH_300) || (event & EVENT_IS_L1)) {
349 value |= CNST_RADIX_SCOPE_GROUP_VAL(event >> p10_EVENT_RADIX_SCOPE_QUAL_SHIFT);
352 if (is_event_marked(event)) {
354 value |= CNST_SAMPLE_VAL(event >> EVENT_SAMPLE_SHIFT);
358 if (event_is_threshold(event)) {
360 value |= CNST_THRESH_CTL_SEL_VAL(event >> EVENT_THRESH_SHIFT);
363 if (event_is_threshold(event) && is_thresh_cmp_valid(event)) {
365 value |= CNST_THRESH_VAL(event >> EVENT_THRESH_SHIFT);
366 } else if (event_is_threshold(event))
373 if (event_is_fab_match(event)) {
375 value |= CNST_FAB_MATCH_VAL(event >> EVENT_THR_CTL_SHIFT);
377 if (!is_thresh_cmp_valid(event))
381 value |= CNST_THRESH_VAL(event >> EVENT_THRESH_SHIFT);
390 if (event & EVENT_WANTS_BHRB) {
396 value |= CNST_IFM_VAL(event >> EVENT_IFM_SHIFT);
413 int isa207_compute_mmcr(u64 event[], int n_ev,
426 pmc = (event[i] >> EVENT_PMC_SHIFT) & EVENT_PMC_MASK;
442 pmc = (event[i] >> EVENT_PMC_SHIFT) & EVENT_PMC_MASK;
443 unit = (event[i] >> EVENT_UNIT_SHIFT) & EVENT_UNIT_MASK;
444 combine = combine_from_event(event[i]);
445 psel = event[i] & EVENT_PSEL_MASK;
463 mmcra_sdar_mode(event[i], &mmcra);
466 cache = dc_ic_rld_quad_l1_sel(event[i]);
469 if (event[i] & EVENT_IS_L1) {
470 cache = dc_ic_rld_quad_l1_sel(event[i]);
477 val = (event[i] >> p10_EVENT_RADIX_SCOPE_QUAL_SHIFT) &
482 if (is_event_marked(event[i])) {
485 val = (event[i] >> EVENT_SAMPLE_SHIFT) & EVENT_SAMPLE_MASK;
496 if (!cpu_has_feature(CPU_FTR_ARCH_300) && event_is_fab_match(event[i])) {
497 mmcr1 |= ((event[i] >> EVENT_THR_CTL_SHIFT) &
500 val = (event[i] >> EVENT_THR_CTL_SHIFT) & EVENT_THR_CTL_MASK;
502 val = (event[i] >> EVENT_THR_SEL_SHIFT) & EVENT_THR_SEL_MASK;
505 val = (event[i] >> EVENT_THR_CMP_SHIFT) &
512 val = (event[i] >> p10_L2L3_EVENT_SHIFT) &
517 if (event[i] & EVENT_WANTS_BHRB) {
518 val = (event[i] >> EVENT_IFM_SHIFT) & EVENT_IFM_MASK;
524 (has_branch_stack(pevents[i]) || (event[i] & EVENT_WANTS_BHRB)))
542 val = (event[i] >> p10_EVENT_MMCR3_SHIFT) &
587 static int find_alternative(u64 event, const unsigned int ev_alt[][MAX_ALT], int size)
592 if (event < ev_alt[i][0])
596 if (event == ev_alt[i][j])
603 int isa207_get_alternatives(u64 event, u64 alt[], int size, unsigned int flags,
609 alt[num_alt++] = event;
610 i = find_alternative(event, ev_alt, size);
612 /* Filter out the original event, it's already in alt[0] */
615 if (alt_event && alt_event != event)