aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJan Beulich <jbeulich@novell.com>2008-01-30 07:31:24 -0500
committerIngo Molnar <mingo@elte.hu>2008-01-30 07:31:24 -0500
commite94271017f0933b29362a3c9dea5a6b9d04d98e1 (patch)
treee3711fd58a2a6f12a6b09087832468776e3c19e3
parentcae4595764cb3b08f6517e99bac1e3862854b1a1 (diff)
x86: adjust enable_NMI_through_LVT0()
Its previous use in a call to on_each_cpu() was pointless, as at the time that code gets executed only one CPU is online. Further, the function can be __cpuinit, and for this to work without CONFIG_HOTPLUG_CPU setup_nmi() must also get an attribute (this one can even be __init; on 64-bits check_timer() also was lacking that attribute). Signed-off-by: Jan Beulich <jbeulich@novell.com> Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r--arch/x86/kernel/apic_32.c2
-rw-r--r--arch/x86/kernel/apic_64.c2
-rw-r--r--arch/x86/kernel/io_apic_32.c4
-rw-r--r--arch/x86/kernel/io_apic_64.c6
-rw-r--r--arch/x86/kernel/smpboot_32.c2
-rw-r--r--arch/x86/kernel/smpboot_64.c2
-rw-r--r--include/asm-x86/apic.h2
7 files changed, 10 insertions, 10 deletions
diff --git a/arch/x86/kernel/apic_32.c b/arch/x86/kernel/apic_32.c
index 69a13d127da3..4c014fca2057 100644
--- a/arch/x86/kernel/apic_32.c
+++ b/arch/x86/kernel/apic_32.c
@@ -152,7 +152,7 @@ u32 safe_apic_wait_icr_idle(void)
152/** 152/**
153 * enable_NMI_through_LVT0 - enable NMI through local vector table 0 153 * enable_NMI_through_LVT0 - enable NMI through local vector table 0
154 */ 154 */
155void enable_NMI_through_LVT0 (void * dummy) 155void __cpuinit enable_NMI_through_LVT0(void)
156{ 156{
157 unsigned int v = APIC_DM_NMI; 157 unsigned int v = APIC_DM_NMI;
158 158
diff --git a/arch/x86/kernel/apic_64.c b/arch/x86/kernel/apic_64.c
index ab4ae50399fd..47b8ef51dde0 100644
--- a/arch/x86/kernel/apic_64.c
+++ b/arch/x86/kernel/apic_64.c
@@ -130,7 +130,7 @@ u32 safe_apic_wait_icr_idle(void)
130/** 130/**
131 * enable_NMI_through_LVT0 - enable NMI through local vector table 0 131 * enable_NMI_through_LVT0 - enable NMI through local vector table 0
132 */ 132 */
133void enable_NMI_through_LVT0(void *dummy) 133void __cpuinit enable_NMI_through_LVT0(void)
134{ 134{
135 unsigned int v; 135 unsigned int v;
136 136
diff --git a/arch/x86/kernel/io_apic_32.c b/arch/x86/kernel/io_apic_32.c
index 76f11c3e3906..0d204237489e 100644
--- a/arch/x86/kernel/io_apic_32.c
+++ b/arch/x86/kernel/io_apic_32.c
@@ -2078,7 +2078,7 @@ static struct irq_chip lapic_chip __read_mostly = {
2078 .eoi = ack_apic, 2078 .eoi = ack_apic,
2079}; 2079};
2080 2080
2081static void setup_nmi (void) 2081static void __init setup_nmi(void)
2082{ 2082{
2083 /* 2083 /*
2084 * Dirty trick to enable the NMI watchdog ... 2084 * Dirty trick to enable the NMI watchdog ...
@@ -2091,7 +2091,7 @@ static void setup_nmi (void)
2091 */ 2091 */
2092 apic_printk(APIC_VERBOSE, KERN_INFO "activating NMI Watchdog ..."); 2092 apic_printk(APIC_VERBOSE, KERN_INFO "activating NMI Watchdog ...");
2093 2093
2094 on_each_cpu(enable_NMI_through_LVT0, NULL, 1, 1); 2094 enable_NMI_through_LVT0();
2095 2095
2096 apic_printk(APIC_VERBOSE, " done.\n"); 2096 apic_printk(APIC_VERBOSE, " done.\n");
2097} 2097}
diff --git a/arch/x86/kernel/io_apic_64.c b/arch/x86/kernel/io_apic_64.c
index fa70005be5e8..f914d84a21da 100644
--- a/arch/x86/kernel/io_apic_64.c
+++ b/arch/x86/kernel/io_apic_64.c
@@ -1566,7 +1566,7 @@ static struct hw_interrupt_type lapic_irq_type __read_mostly = {
1566 .end = end_lapic_irq, 1566 .end = end_lapic_irq,
1567}; 1567};
1568 1568
1569static void setup_nmi (void) 1569static void __init setup_nmi(void)
1570{ 1570{
1571 /* 1571 /*
1572 * Dirty trick to enable the NMI watchdog ... 1572 * Dirty trick to enable the NMI watchdog ...
@@ -1579,7 +1579,7 @@ static void setup_nmi (void)
1579 */ 1579 */
1580 printk(KERN_INFO "activating NMI Watchdog ..."); 1580 printk(KERN_INFO "activating NMI Watchdog ...");
1581 1581
1582 enable_NMI_through_LVT0(NULL); 1582 enable_NMI_through_LVT0();
1583 1583
1584 printk(" done.\n"); 1584 printk(" done.\n");
1585} 1585}
@@ -1655,7 +1655,7 @@ static inline void unlock_ExtINT_logic(void)
1655 * 1655 *
1656 * FIXME: really need to revamp this for modern platforms only. 1656 * FIXME: really need to revamp this for modern platforms only.
1657 */ 1657 */
1658static inline void check_timer(void) 1658static inline void __init check_timer(void)
1659{ 1659{
1660 struct irq_cfg *cfg = irq_cfg + 0; 1660 struct irq_cfg *cfg = irq_cfg + 0;
1661 int apic1, pin1, apic2, pin2; 1661 int apic1, pin1, apic2, pin2;
diff --git a/arch/x86/kernel/smpboot_32.c b/arch/x86/kernel/smpboot_32.c
index 0f294d6e22cf..2034332ad080 100644
--- a/arch/x86/kernel/smpboot_32.c
+++ b/arch/x86/kernel/smpboot_32.c
@@ -404,7 +404,7 @@ static void __cpuinit start_secondary(void *unused)
404 setup_secondary_clock(); 404 setup_secondary_clock();
405 if (nmi_watchdog == NMI_IO_APIC) { 405 if (nmi_watchdog == NMI_IO_APIC) {
406 disable_8259A_irq(0); 406 disable_8259A_irq(0);
407 enable_NMI_through_LVT0(NULL); 407 enable_NMI_through_LVT0();
408 enable_8259A_irq(0); 408 enable_8259A_irq(0);
409 } 409 }
410 /* 410 /*
diff --git a/arch/x86/kernel/smpboot_64.c b/arch/x86/kernel/smpboot_64.c
index cb73c4da87fc..4c03ddccd681 100644
--- a/arch/x86/kernel/smpboot_64.c
+++ b/arch/x86/kernel/smpboot_64.c
@@ -337,7 +337,7 @@ void __cpuinit start_secondary(void)
337 337
338 if (nmi_watchdog == NMI_IO_APIC) { 338 if (nmi_watchdog == NMI_IO_APIC) {
339 disable_8259A_irq(0); 339 disable_8259A_irq(0);
340 enable_NMI_through_LVT0(NULL); 340 enable_NMI_through_LVT0();
341 enable_8259A_irq(0); 341 enable_8259A_irq(0);
342 } 342 }
343 343
diff --git a/include/asm-x86/apic.h b/include/asm-x86/apic.h
index 72bf09cf13ab..bcfc07fd3661 100644
--- a/include/asm-x86/apic.h
+++ b/include/asm-x86/apic.h
@@ -117,7 +117,7 @@ extern void init_apic_mappings(void);
117extern void setup_boot_APIC_clock(void); 117extern void setup_boot_APIC_clock(void);
118extern void setup_secondary_APIC_clock(void); 118extern void setup_secondary_APIC_clock(void);
119extern int APIC_init_uniprocessor(void); 119extern int APIC_init_uniprocessor(void);
120extern void enable_NMI_through_LVT0(void *dummy); 120extern void enable_NMI_through_LVT0(void);
121 121
122/* 122/*
123 * On 32bit this is mach-xxx local 123 * On 32bit this is mach-xxx local