diff options
author | Ingo Molnar <mingo@elte.hu> | 2008-07-10 09:48:48 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-10 12:55:41 -0400 |
commit | 078c0bba55b3dc751881d40cf170c002eafc048d (patch) | |
tree | e6df988d90bcd22239910a9401ae219df1deeb53 /arch/x86/mach-default/setup.c | |
parent | 8bfaba873f0cc81c1747d6787f2721926192a3dc (diff) |
x86, VisWS: turn into generic arch, add early quirks to default architectures
add early quirk support to the generic architecture code.
this allows VISWS to be supported by the generic code and allows us
to remove the VISWS subarch.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/mach-default/setup.c')
-rw-r--r-- | arch/x86/mach-default/setup.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/arch/x86/mach-default/setup.c b/arch/x86/mach-default/setup.c index 2f5e277686b8..b8054c3ffce3 100644 --- a/arch/x86/mach-default/setup.c +++ b/arch/x86/mach-default/setup.c | |||
@@ -10,6 +10,14 @@ | |||
10 | #include <asm/e820.h> | 10 | #include <asm/e820.h> |
11 | #include <asm/setup.h> | 11 | #include <asm/setup.h> |
12 | 12 | ||
13 | /* | ||
14 | * Any quirks to be performed to initialize timers/irqs/etc? | ||
15 | */ | ||
16 | int (*arch_time_init_quirk)(void); | ||
17 | int (*arch_pre_intr_init_quirk)(void); | ||
18 | int (*arch_intr_init_quirk)(void); | ||
19 | int (*arch_trap_init_quirk)(void); | ||
20 | |||
13 | #ifdef CONFIG_HOTPLUG_CPU | 21 | #ifdef CONFIG_HOTPLUG_CPU |
14 | #define DEFAULT_SEND_IPI (1) | 22 | #define DEFAULT_SEND_IPI (1) |
15 | #else | 23 | #else |
@@ -29,6 +37,10 @@ int no_broadcast=DEFAULT_SEND_IPI; | |||
29 | **/ | 37 | **/ |
30 | void __init pre_intr_init_hook(void) | 38 | void __init pre_intr_init_hook(void) |
31 | { | 39 | { |
40 | if (arch_pre_intr_init_quirk) { | ||
41 | if (arch_pre_intr_init_quirk()) | ||
42 | return; | ||
43 | } | ||
32 | init_ISA_irqs(); | 44 | init_ISA_irqs(); |
33 | } | 45 | } |
34 | 46 | ||
@@ -52,6 +64,10 @@ static struct irqaction irq2 = { | |||
52 | **/ | 64 | **/ |
53 | void __init intr_init_hook(void) | 65 | void __init intr_init_hook(void) |
54 | { | 66 | { |
67 | if (arch_intr_init_quirk) { | ||
68 | if (arch_intr_init_quirk()) | ||
69 | return; | ||
70 | } | ||
55 | #ifdef CONFIG_X86_LOCAL_APIC | 71 | #ifdef CONFIG_X86_LOCAL_APIC |
56 | apic_intr_init(); | 72 | apic_intr_init(); |
57 | #endif | 73 | #endif |
@@ -81,6 +97,10 @@ void __init pre_setup_arch_hook(void) | |||
81 | **/ | 97 | **/ |
82 | void __init trap_init_hook(void) | 98 | void __init trap_init_hook(void) |
83 | { | 99 | { |
100 | if (arch_trap_init_quirk) { | ||
101 | if (arch_trap_init_quirk()) | ||
102 | return; | ||
103 | } | ||
84 | } | 104 | } |
85 | 105 | ||
86 | static struct irqaction irq0 = { | 106 | static struct irqaction irq0 = { |
@@ -99,6 +119,16 @@ static struct irqaction irq0 = { | |||
99 | **/ | 119 | **/ |
100 | void __init time_init_hook(void) | 120 | void __init time_init_hook(void) |
101 | { | 121 | { |
122 | if (arch_time_init_quirk) { | ||
123 | /* | ||
124 | * A nonzero return code does not mean failure, it means | ||
125 | * that the architecture quirk does not want any | ||
126 | * generic (timer) setup to be performed after this: | ||
127 | */ | ||
128 | if (arch_time_init_quirk()) | ||
129 | return; | ||
130 | } | ||
131 | |||
102 | irq0.mask = cpumask_of_cpu(0); | 132 | irq0.mask = cpumask_of_cpu(0); |
103 | setup_irq(0, &irq0); | 133 | setup_irq(0, &irq0); |
104 | } | 134 | } |