Hi Peter, On Wed, 2015-08-26 at 15:07 +-0200, Peter Zijlstra wrote: +AD4- On Mon, Aug 24, 2015 at 05:20:20PM +-0300, Alexey Brodkin wrote: +AD4- +AD4- +AEAAQA- -139,9 +-141,11 +AEAAQA- static int arc+AF8-pmu+AF8-event+AF8-init(struct perf+AF8-event +ACo-event) +AD4- +AD4- struct hw+AF8-perf+AF8-event +ACo-hwc +AD0- +ACY-event-+AD4-hw+ADs- +AD4- +AD4- int ret+ADs- +AD4- +AD4- +AD4- +AD4- - hwc-+AD4-sample+AF8-period +AD0- arc+AF8-pmu-+AD4-max+AF8-period+ADs- +AD4- +AD4- - hwc-+AD4-last+AF8-period +AD0- hwc-+AD4-sample+AF8-period+ADs- +AD4- +AD4- - local64+AF8-set(+ACY-hwc-+AD4-period+AF8-left, hwc-+AD4-sample+AF8-period)+ADs- +AD4- +AD4- +- if (+ACE-is+AF8-sampling+AF8-event(event)) +AHs- +AD4- +AD4- +- hwc-+AD4-sample+AF8-period +AD0- arc+AF8-pmu-+AD4-max+AF8-period+ADs- +AD4- +AD4- +- hwc-+AD4-last+AF8-period +AD0- hwc-+AD4-sample+AF8-period+ADs- +AD4- +AD4- +- local64+AF8-set(+ACY-hwc-+AD4-period+AF8-left, hwc-+AD4-sample+AF8-period)+ADs- +AD4- +AD4- +- +AH0- +AD4- +AD4- So here we set a max+AF8-period sample period for +ACE-sampling events such that +AD4- we can properly deal with (short) counter overflow and accumulate into a +AD4- 64bit value. +AD4- +AD4- +AD4- switch (event-+AD4-attr.type) +AHs- +AD4- +AD4- case PERF+AF8-TYPE+AF8-HARDWARE: +AD4- +AD4- +AEAAQA- -243,6 +-247,11 +AEAAQA- static void arc+AF8-pmu+AF8-start(struct perf+AF8-event +ACo-event, int flags) +AD4- +AD4- +AD4- +AD4- arc+AF8-pmu+AF8-event+AF8-set+AF8-period(event)+ADs- +AD4- +AD4- +AD4- +AD4- +- /+ACo- Enable interrupt for this counter +ACo-/ +AD4- +AD4- +- if (is+AF8-sampling+AF8-event(event)) +AD4- +AD4- +- write+AF8-aux+AF8-reg(ARC+AF8-REG+AF8-PCT+AF8-INT+AF8-CTRL, +AD4- +AD4- +- read+AF8-aux+AF8-reg(ARC+AF8-REG+AF8-PCT+AF8-INT+AF8-CTRL) +AHw- (1 +ADwAPA- idx))+ADs- +AD4- +AD4- +- +AD4- +AD4- Yet here you fail to actually enable the interrupt for the non sampling +AD4- events, which makes the above not work. Indeed we intentionally leave interrupts disabled for non-sampling events. +AFs-1+AF0- We have quite large counters so we don't expect to overflow normally +AFs-2+AF0- We may re-use the same code for hardware that lacks support of IRQs in PCT. See we check if IRQs are available and if not set PERF+AF8-PMU+AF8-CAP+AF8-NO+AF8-INTERRUPT that will guarantee we won't get sampling event and for non-sampling events we won't use IRQs. -Alexey-- To unsubscribe from this list: send the line "unsubscribe linux-arch" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html