summaryrefslogtreecommitdiff
path: root/arch/ia64/kernel/perfmon.c
diff options
context:
space:
mode:
authorJeff Garzik <jeff@garzik.org>2006-03-22 06:09:31 -0500
committerJeff Garzik <jeff@garzik.org>2006-03-22 06:09:31 -0500
commit949ec2c8e6b7b89179b85baf6309c009e1a1b951 (patch)
tree2d9c3dde17ba8608aa07e96e6fffcc23f1cab39c /arch/ia64/kernel/perfmon.c
parent55cca65e1995ad604ee87e22c76c17d5cbceb9d0 (diff)
parente952f31bce6e9f64db01f607abc46529ba57ac9e (diff)
Merge branch 'master'
Diffstat (limited to 'arch/ia64/kernel/perfmon.c')
-rw-r--r--arch/ia64/kernel/perfmon.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/arch/ia64/kernel/perfmon.c b/arch/ia64/kernel/perfmon.c
index 9c5194b385da..077f21216b65 100644
--- a/arch/ia64/kernel/perfmon.c
+++ b/arch/ia64/kernel/perfmon.c
@@ -6722,6 +6722,7 @@ __initcall(pfm_init);
void
pfm_init_percpu (void)
{
+ static int first_time=1;
/*
* make sure no measurement is active
* (may inherit programmed PMCs from EFI).
@@ -6734,8 +6735,10 @@ pfm_init_percpu (void)
*/
pfm_unfreeze_pmu();
- if (smp_processor_id() == 0)
+ if (first_time) {
register_percpu_irq(IA64_PERFMON_VECTOR, &perfmon_irqaction);
+ first_time=0;
+ }
ia64_setreg(_IA64_REG_CR_PMV, IA64_PERFMON_VECTOR);
ia64_srlz_d();