1 /* local apic based NMI watchdog for various CPUs.
2 This file also handles reservation of performance counters for coordination
3 with other users (like oprofile).
5 Note that these events normally don't tick when the CPU idles. This means
6 the frequency varies with CPU load.
8 Original code for K7/P6 written by Keith Owens */
10 #include <linux/percpu.h>
11 #include <linux/module.h>
12 #include <linux/kernel.h>
13 #include <linux/bitops.h>
14 #include <linux/smp.h>
15 #include <linux/nmi.h>
17 #include <asm/intel_arch_perfmon.h>
19 struct nmi_watchdog_ctlblk {
20 unsigned int cccr_msr;
21 unsigned int perfctr_msr; /* the MSR to reset in NMI handler */
22 unsigned int evntsel_msr; /* the MSR to select the events to handle */
25 /* Interface defining a CPU specific perfctr watchdog */
28 void (*unreserve)(void);
29 int (*setup)(unsigned nmi_hz);
30 void (*rearm)(struct nmi_watchdog_ctlblk *wd, unsigned nmi_hz);
37 static const struct wd_ops *wd_ops;
39 /* this number is calculated from Intel's MSR_P4_CRU_ESCR5 register and it's
40 * offset from MSR_P4_BSU_ESCR0. It will be the max for all platforms (for now)
42 #define NMI_MAX_COUNTER_BITS 66
44 /* perfctr_nmi_owner tracks the ownership of the perfctr registers:
45 * evtsel_nmi_owner tracks the ownership of the event selection
46 * - different performance counters/ event selection may be reserved for
47 * different subsystems this reservation system just tries to coordinate
50 static DECLARE_BITMAP(perfctr_nmi_owner, NMI_MAX_COUNTER_BITS);
51 static DECLARE_BITMAP(evntsel_nmi_owner, NMI_MAX_COUNTER_BITS);
53 static DEFINE_PER_CPU(struct nmi_watchdog_ctlblk, nmi_watchdog_ctlblk);
55 /* converts an msr to an appropriate reservation bit */
56 static inline unsigned int nmi_perfctr_msr_to_bit(unsigned int msr)
58 /* returns the bit offset of the performance counter register */
59 switch (boot_cpu_data.x86_vendor) {
61 return (msr - MSR_K7_PERFCTR0);
62 case X86_VENDOR_INTEL:
63 if (cpu_has(&boot_cpu_data, X86_FEATURE_ARCH_PERFMON))
64 return (msr - MSR_ARCH_PERFMON_PERFCTR0);
66 switch (boot_cpu_data.x86) {
68 return (msr - MSR_P6_PERFCTR0);
70 return (msr - MSR_P4_BPU_PERFCTR0);
76 /* converts an msr to an appropriate reservation bit */
77 /* returns the bit offset of the event selection register */
78 static inline unsigned int nmi_evntsel_msr_to_bit(unsigned int msr)
80 /* returns the bit offset of the event selection register */
81 switch (boot_cpu_data.x86_vendor) {
83 return (msr - MSR_K7_EVNTSEL0);
84 case X86_VENDOR_INTEL:
85 if (cpu_has(&boot_cpu_data, X86_FEATURE_ARCH_PERFMON))
86 return (msr - MSR_ARCH_PERFMON_EVENTSEL0);
88 switch (boot_cpu_data.x86) {
90 return (msr - MSR_P6_EVNTSEL0);
92 return (msr - MSR_P4_BSU_ESCR0);
99 /* checks for a bit availability (hack for oprofile) */
100 int avail_to_resrv_perfctr_nmi_bit(unsigned int counter)
102 BUG_ON(counter > NMI_MAX_COUNTER_BITS);
104 return (!test_bit(counter, perfctr_nmi_owner));
107 /* checks the an msr for availability */
108 int avail_to_resrv_perfctr_nmi(unsigned int msr)
110 unsigned int counter;
112 counter = nmi_perfctr_msr_to_bit(msr);
113 BUG_ON(counter > NMI_MAX_COUNTER_BITS);
115 return (!test_bit(counter, perfctr_nmi_owner));
118 int reserve_perfctr_nmi(unsigned int msr)
120 unsigned int counter;
122 counter = nmi_perfctr_msr_to_bit(msr);
123 /* register not managed by the allocator? */
124 if (counter > NMI_MAX_COUNTER_BITS)
127 if (!test_and_set_bit(counter, perfctr_nmi_owner))
132 void release_perfctr_nmi(unsigned int msr)
134 unsigned int counter;
136 counter = nmi_perfctr_msr_to_bit(msr);
137 /* register not managed by the allocator? */
138 if (counter > NMI_MAX_COUNTER_BITS)
141 clear_bit(counter, perfctr_nmi_owner);
144 int reserve_evntsel_nmi(unsigned int msr)
146 unsigned int counter;
148 counter = nmi_evntsel_msr_to_bit(msr);
149 /* register not managed by the allocator? */
150 if (counter > NMI_MAX_COUNTER_BITS)
153 if (!test_and_set_bit(counter, evntsel_nmi_owner))
158 void release_evntsel_nmi(unsigned int msr)
160 unsigned int counter;
162 counter = nmi_evntsel_msr_to_bit(msr);
163 /* register not managed by the allocator? */
164 if (counter > NMI_MAX_COUNTER_BITS)
167 clear_bit(counter, evntsel_nmi_owner);
170 EXPORT_SYMBOL(avail_to_resrv_perfctr_nmi);
171 EXPORT_SYMBOL(avail_to_resrv_perfctr_nmi_bit);
172 EXPORT_SYMBOL(reserve_perfctr_nmi);
173 EXPORT_SYMBOL(release_perfctr_nmi);
174 EXPORT_SYMBOL(reserve_evntsel_nmi);
175 EXPORT_SYMBOL(release_evntsel_nmi);
177 void disable_lapic_nmi_watchdog(void)
179 BUG_ON(nmi_watchdog != NMI_LOCAL_APIC);
181 if (atomic_read(&nmi_active) <= 0)
184 on_each_cpu(stop_apic_nmi_watchdog, NULL, 0, 1);
187 BUG_ON(atomic_read(&nmi_active) != 0);
190 void enable_lapic_nmi_watchdog(void)
192 BUG_ON(nmi_watchdog != NMI_LOCAL_APIC);
194 /* are we already enabled */
195 if (atomic_read(&nmi_active) != 0)
198 /* are we lapic aware */
201 if (!wd_ops->reserve()) {
202 printk(KERN_ERR "NMI watchdog: cannot reserve perfctrs\n");
206 on_each_cpu(setup_apic_nmi_watchdog, NULL, 0, 1);
207 touch_nmi_watchdog();
211 * Activate the NMI watchdog via the local APIC.
214 static unsigned int adjust_for_32bit_ctr(unsigned int hz)
217 unsigned int retval = hz;
220 * On Intel CPUs with P6/ARCH_PERFMON only 32 bits in the counter
221 * are writable, with higher bits sign extending from bit 31.
222 * So, we can only program the counter with 31 bit values and
223 * 32nd bit should be 1, for 33.. to be 1.
224 * Find the appropriate nmi_hz
226 counter_val = (u64)cpu_khz * 1000;
227 do_div(counter_val, retval);
228 if (counter_val > 0x7fffffffULL) {
229 u64 count = (u64)cpu_khz * 1000;
230 do_div(count, 0x7fffffffUL);
237 write_watchdog_counter(unsigned int perfctr_msr, const char *descr, unsigned nmi_hz)
239 u64 count = (u64)cpu_khz * 1000;
241 do_div(count, nmi_hz);
243 Dprintk("setting %s to -0x%08Lx\n", descr, count);
244 wrmsrl(perfctr_msr, 0 - count);
247 static void write_watchdog_counter32(unsigned int perfctr_msr,
248 const char *descr, unsigned nmi_hz)
250 u64 count = (u64)cpu_khz * 1000;
252 do_div(count, nmi_hz);
254 Dprintk("setting %s to -0x%08Lx\n", descr, count);
255 wrmsr(perfctr_msr, (u32)(-count), 0);
258 /* AMD K7/K8/Family10h/Family11h support. AMD keeps this interface
259 nicely stable so there is not much variety */
261 #define K7_EVNTSEL_ENABLE (1 << 22)
262 #define K7_EVNTSEL_INT (1 << 20)
263 #define K7_EVNTSEL_OS (1 << 17)
264 #define K7_EVNTSEL_USR (1 << 16)
265 #define K7_EVENT_CYCLES_PROCESSOR_IS_RUNNING 0x76
266 #define K7_NMI_EVENT K7_EVENT_CYCLES_PROCESSOR_IS_RUNNING
268 static int setup_k7_watchdog(unsigned nmi_hz)
270 unsigned int perfctr_msr, evntsel_msr;
271 unsigned int evntsel;
272 struct nmi_watchdog_ctlblk *wd = &__get_cpu_var(nmi_watchdog_ctlblk);
274 perfctr_msr = wd_ops->perfctr;
275 evntsel_msr = wd_ops->evntsel;
277 wrmsrl(perfctr_msr, 0UL);
279 evntsel = K7_EVNTSEL_INT
284 /* setup the timer */
285 wrmsr(evntsel_msr, evntsel, 0);
286 write_watchdog_counter(perfctr_msr, "K7_PERFCTR0",nmi_hz);
287 apic_write(APIC_LVTPC, APIC_DM_NMI);
288 evntsel |= K7_EVNTSEL_ENABLE;
289 wrmsr(evntsel_msr, evntsel, 0);
291 wd->perfctr_msr = perfctr_msr;
292 wd->evntsel_msr = evntsel_msr;
293 wd->cccr_msr = 0; //unused
297 static void single_msr_stop_watchdog(void)
299 struct nmi_watchdog_ctlblk *wd = &__get_cpu_var(nmi_watchdog_ctlblk);
301 wrmsr(wd->evntsel_msr, 0, 0);
304 static int single_msr_reserve(void)
306 if (!reserve_perfctr_nmi(wd_ops->perfctr))
309 if (!reserve_evntsel_nmi(wd_ops->evntsel)) {
310 release_perfctr_nmi(wd_ops->perfctr);
316 static void single_msr_unreserve(void)
318 release_evntsel_nmi(wd_ops->evntsel);
319 release_perfctr_nmi(wd_ops->perfctr);
322 static void single_msr_rearm(struct nmi_watchdog_ctlblk *wd, unsigned nmi_hz)
324 /* start the cycle over again */
325 write_watchdog_counter(wd->perfctr_msr, NULL, nmi_hz);
328 static const struct wd_ops k7_wd_ops = {
329 .reserve = single_msr_reserve,
330 .unreserve = single_msr_unreserve,
331 .setup = setup_k7_watchdog,
332 .rearm = single_msr_rearm,
333 .stop = single_msr_stop_watchdog,
334 .perfctr = MSR_K7_PERFCTR0,
335 .evntsel = MSR_K7_EVNTSEL0,
336 .checkbit = 1ULL<<47,
339 /* Intel Model 6 (PPro+,P2,P3,P-M,Core1) */
341 #define P6_EVNTSEL0_ENABLE (1 << 22)
342 #define P6_EVNTSEL_INT (1 << 20)
343 #define P6_EVNTSEL_OS (1 << 17)
344 #define P6_EVNTSEL_USR (1 << 16)
345 #define P6_EVENT_CPU_CLOCKS_NOT_HALTED 0x79
346 #define P6_NMI_EVENT P6_EVENT_CPU_CLOCKS_NOT_HALTED
348 static int setup_p6_watchdog(unsigned nmi_hz)
350 unsigned int perfctr_msr, evntsel_msr;
351 unsigned int evntsel;
352 struct nmi_watchdog_ctlblk *wd = &__get_cpu_var(nmi_watchdog_ctlblk);
354 perfctr_msr = wd_ops->perfctr;
355 evntsel_msr = wd_ops->evntsel;
357 /* KVM doesn't implement this MSR */
358 if (wrmsr_safe(perfctr_msr, 0, 0) < 0)
361 evntsel = P6_EVNTSEL_INT
366 /* setup the timer */
367 wrmsr(evntsel_msr, evntsel, 0);
368 nmi_hz = adjust_for_32bit_ctr(nmi_hz);
369 write_watchdog_counter32(perfctr_msr, "P6_PERFCTR0",nmi_hz);
370 apic_write(APIC_LVTPC, APIC_DM_NMI);
371 evntsel |= P6_EVNTSEL0_ENABLE;
372 wrmsr(evntsel_msr, evntsel, 0);
374 wd->perfctr_msr = perfctr_msr;
375 wd->evntsel_msr = evntsel_msr;
376 wd->cccr_msr = 0; //unused
380 static void p6_rearm(struct nmi_watchdog_ctlblk *wd, unsigned nmi_hz)
382 /* P6 based Pentium M need to re-unmask
383 * the apic vector but it doesn't hurt
385 * ArchPerfom/Core Duo also needs this */
386 apic_write(APIC_LVTPC, APIC_DM_NMI);
387 /* P6/ARCH_PERFMON has 32 bit counter write */
388 write_watchdog_counter32(wd->perfctr_msr, NULL,nmi_hz);
391 static const struct wd_ops p6_wd_ops = {
392 .reserve = single_msr_reserve,
393 .unreserve = single_msr_unreserve,
394 .setup = setup_p6_watchdog,
396 .stop = single_msr_stop_watchdog,
397 .perfctr = MSR_P6_PERFCTR0,
398 .evntsel = MSR_P6_EVNTSEL0,
399 .checkbit = 1ULL<<39,
402 /* Intel P4 performance counters. By far the most complicated of all. */
404 #define MSR_P4_MISC_ENABLE_PERF_AVAIL (1<<7)
405 #define P4_ESCR_EVENT_SELECT(N) ((N)<<25)
406 #define P4_ESCR_OS (1<<3)
407 #define P4_ESCR_USR (1<<2)
408 #define P4_CCCR_OVF_PMI0 (1<<26)
409 #define P4_CCCR_OVF_PMI1 (1<<27)
410 #define P4_CCCR_THRESHOLD(N) ((N)<<20)
411 #define P4_CCCR_COMPLEMENT (1<<19)
412 #define P4_CCCR_COMPARE (1<<18)
413 #define P4_CCCR_REQUIRED (3<<16)
414 #define P4_CCCR_ESCR_SELECT(N) ((N)<<13)
415 #define P4_CCCR_ENABLE (1<<12)
416 #define P4_CCCR_OVF (1<<31)
418 /* Set up IQ_COUNTER0 to behave like a clock, by having IQ_CCCR0 filter
419 CRU_ESCR0 (with any non-null event selector) through a complemented
420 max threshold. [IA32-Vol3, Section 14.9.9] */
422 static int setup_p4_watchdog(unsigned nmi_hz)
424 unsigned int perfctr_msr, evntsel_msr, cccr_msr;
425 unsigned int evntsel, cccr_val;
426 unsigned int misc_enable, dummy;
428 struct nmi_watchdog_ctlblk *wd = &__get_cpu_var(nmi_watchdog_ctlblk);
430 rdmsr(MSR_IA32_MISC_ENABLE, misc_enable, dummy);
431 if (!(misc_enable & MSR_P4_MISC_ENABLE_PERF_AVAIL))
435 /* detect which hyperthread we are on */
436 if (smp_num_siblings == 2) {
437 unsigned int ebx, apicid;
440 apicid = (ebx >> 24) & 0xff;
446 /* performance counters are shared resources
447 * assign each hyperthread its own set
448 * (re-use the ESCR0 register, seems safe
449 * and keeps the cccr_val the same)
453 perfctr_msr = MSR_P4_IQ_PERFCTR0;
454 evntsel_msr = MSR_P4_CRU_ESCR0;
455 cccr_msr = MSR_P4_IQ_CCCR0;
456 cccr_val = P4_CCCR_OVF_PMI0 | P4_CCCR_ESCR_SELECT(4);
459 perfctr_msr = MSR_P4_IQ_PERFCTR1;
460 evntsel_msr = MSR_P4_CRU_ESCR0;
461 cccr_msr = MSR_P4_IQ_CCCR1;
462 cccr_val = P4_CCCR_OVF_PMI1 | P4_CCCR_ESCR_SELECT(4);
465 evntsel = P4_ESCR_EVENT_SELECT(0x3F)
469 cccr_val |= P4_CCCR_THRESHOLD(15)
474 wrmsr(evntsel_msr, evntsel, 0);
475 wrmsr(cccr_msr, cccr_val, 0);
476 write_watchdog_counter(perfctr_msr, "P4_IQ_COUNTER0", nmi_hz);
477 apic_write(APIC_LVTPC, APIC_DM_NMI);
478 cccr_val |= P4_CCCR_ENABLE;
479 wrmsr(cccr_msr, cccr_val, 0);
480 wd->perfctr_msr = perfctr_msr;
481 wd->evntsel_msr = evntsel_msr;
482 wd->cccr_msr = cccr_msr;
486 static void stop_p4_watchdog(void)
488 struct nmi_watchdog_ctlblk *wd = &__get_cpu_var(nmi_watchdog_ctlblk);
489 wrmsr(wd->cccr_msr, 0, 0);
490 wrmsr(wd->evntsel_msr, 0, 0);
493 static int p4_reserve(void)
495 if (!reserve_perfctr_nmi(MSR_P4_IQ_PERFCTR0))
498 if (smp_num_siblings > 1 && !reserve_perfctr_nmi(MSR_P4_IQ_PERFCTR1))
501 if (!reserve_evntsel_nmi(MSR_P4_CRU_ESCR0))
503 /* RED-PEN why is ESCR1 not reserved here? */
507 if (smp_num_siblings > 1)
508 release_perfctr_nmi(MSR_P4_IQ_PERFCTR1);
511 release_perfctr_nmi(MSR_P4_IQ_PERFCTR0);
515 static void p4_unreserve(void)
518 if (smp_num_siblings > 1)
519 release_perfctr_nmi(MSR_P4_IQ_PERFCTR1);
521 release_evntsel_nmi(MSR_P4_CRU_ESCR0);
522 release_perfctr_nmi(MSR_P4_IQ_PERFCTR0);
525 static void p4_rearm(struct nmi_watchdog_ctlblk *wd, unsigned nmi_hz)
530 * - An overflown perfctr will assert its interrupt
531 * until the OVF flag in its CCCR is cleared.
532 * - LVTPC is masked on interrupt and must be
533 * unmasked by the LVTPC handler.
535 rdmsrl(wd->cccr_msr, dummy);
536 dummy &= ~P4_CCCR_OVF;
537 wrmsrl(wd->cccr_msr, dummy);
538 apic_write(APIC_LVTPC, APIC_DM_NMI);
539 /* start the cycle over again */
540 write_watchdog_counter(wd->perfctr_msr, NULL, nmi_hz);
543 static const struct wd_ops p4_wd_ops = {
544 .reserve = p4_reserve,
545 .unreserve = p4_unreserve,
546 .setup = setup_p4_watchdog,
548 .stop = stop_p4_watchdog,
549 /* RED-PEN this is wrong for the other sibling */
550 .perfctr = MSR_P4_BPU_PERFCTR0,
551 .evntsel = MSR_P4_BSU_ESCR0,
552 .checkbit = 1ULL<<39,
555 /* Watchdog using the Intel architected PerfMon. Used for Core2 and hopefully
556 all future Intel CPUs. */
558 #define ARCH_PERFMON_NMI_EVENT_SEL ARCH_PERFMON_UNHALTED_CORE_CYCLES_SEL
559 #define ARCH_PERFMON_NMI_EVENT_UMASK ARCH_PERFMON_UNHALTED_CORE_CYCLES_UMASK
561 static struct wd_ops intel_arch_wd_ops;
563 static int setup_intel_arch_watchdog(unsigned nmi_hz)
566 union cpuid10_eax eax;
568 unsigned int perfctr_msr, evntsel_msr;
569 unsigned int evntsel;
570 struct nmi_watchdog_ctlblk *wd = &__get_cpu_var(nmi_watchdog_ctlblk);
573 * Check whether the Architectural PerfMon supports
574 * Unhalted Core Cycles Event or not.
575 * NOTE: Corresponding bit = 0 in ebx indicates event present.
577 cpuid(10, &(eax.full), &ebx, &unused, &unused);
578 if ((eax.split.mask_length < (ARCH_PERFMON_UNHALTED_CORE_CYCLES_INDEX+1)) ||
579 (ebx & ARCH_PERFMON_UNHALTED_CORE_CYCLES_PRESENT))
582 perfctr_msr = wd_ops->perfctr;
583 evntsel_msr = wd_ops->evntsel;
585 wrmsrl(perfctr_msr, 0UL);
587 evntsel = ARCH_PERFMON_EVENTSEL_INT
588 | ARCH_PERFMON_EVENTSEL_OS
589 | ARCH_PERFMON_EVENTSEL_USR
590 | ARCH_PERFMON_NMI_EVENT_SEL
591 | ARCH_PERFMON_NMI_EVENT_UMASK;
593 /* setup the timer */
594 wrmsr(evntsel_msr, evntsel, 0);
595 nmi_hz = adjust_for_32bit_ctr(nmi_hz);
596 write_watchdog_counter32(perfctr_msr, "INTEL_ARCH_PERFCTR0", nmi_hz);
597 apic_write(APIC_LVTPC, APIC_DM_NMI);
598 evntsel |= ARCH_PERFMON_EVENTSEL0_ENABLE;
599 wrmsr(evntsel_msr, evntsel, 0);
601 wd->perfctr_msr = perfctr_msr;
602 wd->evntsel_msr = evntsel_msr;
603 wd->cccr_msr = 0; //unused
604 intel_arch_wd_ops.checkbit = 1ULL << (eax.split.bit_width - 1);
608 static struct wd_ops intel_arch_wd_ops __read_mostly = {
609 .reserve = single_msr_reserve,
610 .unreserve = single_msr_unreserve,
611 .setup = setup_intel_arch_watchdog,
613 .stop = single_msr_stop_watchdog,
614 .perfctr = MSR_ARCH_PERFMON_PERFCTR1,
615 .evntsel = MSR_ARCH_PERFMON_EVENTSEL1,
618 static struct wd_ops coreduo_wd_ops = {
619 .reserve = single_msr_reserve,
620 .unreserve = single_msr_unreserve,
621 .setup = setup_intel_arch_watchdog,
623 .stop = single_msr_stop_watchdog,
624 .perfctr = MSR_ARCH_PERFMON_PERFCTR0,
625 .evntsel = MSR_ARCH_PERFMON_EVENTSEL0,
628 static void probe_nmi_watchdog(void)
630 switch (boot_cpu_data.x86_vendor) {
632 if (boot_cpu_data.x86 != 6 && boot_cpu_data.x86 != 15 &&
633 boot_cpu_data.x86 != 16)
637 case X86_VENDOR_INTEL:
638 /* Work around Core Duo (Yonah) errata AE49 where perfctr1
639 doesn't have a working enable bit. */
640 if (boot_cpu_data.x86 == 6 && boot_cpu_data.x86_model == 14) {
641 wd_ops = &coreduo_wd_ops;
644 if (cpu_has(&boot_cpu_data, X86_FEATURE_ARCH_PERFMON)) {
645 wd_ops = &intel_arch_wd_ops;
648 switch (boot_cpu_data.x86) {
650 if (boot_cpu_data.x86_model > 0xd)
656 if (boot_cpu_data.x86_model > 0x4)
668 /* Interface to nmi.c */
670 int lapic_watchdog_init(unsigned nmi_hz)
673 probe_nmi_watchdog();
677 if (!wd_ops->reserve()) {
679 "NMI watchdog: cannot reserve perfctrs\n");
684 if (!(wd_ops->setup(nmi_hz))) {
685 printk(KERN_ERR "Cannot setup NMI watchdog on CPU %d\n",
686 raw_smp_processor_id());
693 void lapic_watchdog_stop(void)
699 unsigned lapic_adjust_nmi_hz(unsigned hz)
701 struct nmi_watchdog_ctlblk *wd = &__get_cpu_var(nmi_watchdog_ctlblk);
702 if (wd->perfctr_msr == MSR_P6_PERFCTR0 ||
703 wd->perfctr_msr == MSR_ARCH_PERFMON_PERFCTR1)
704 hz = adjust_for_32bit_ctr(hz);
708 int lapic_wd_event(unsigned nmi_hz)
710 struct nmi_watchdog_ctlblk *wd = &__get_cpu_var(nmi_watchdog_ctlblk);
712 rdmsrl(wd->perfctr_msr, ctr);
713 if (ctr & wd_ops->checkbit) { /* perfctr still running? */
716 wd_ops->rearm(wd, nmi_hz);
720 int lapic_watchdog_ok(void)
722 return wd_ops != NULL;