diff options
Diffstat (limited to 'arch/mips')
-rw-r--r-- | arch/mips/alchemy/common/time.c | 15 | ||||
-rw-r--r-- | arch/mips/kernel/cpu-probe.c | 13 |
2 files changed, 14 insertions, 14 deletions
diff --git a/arch/mips/alchemy/common/time.c b/arch/mips/alchemy/common/time.c index 33fbae79af5e..f34ff8601942 100644 --- a/arch/mips/alchemy/common/time.c +++ b/arch/mips/alchemy/common/time.c | |||
@@ -36,14 +36,13 @@ | |||
36 | #include <linux/interrupt.h> | 36 | #include <linux/interrupt.h> |
37 | #include <linux/spinlock.h> | 37 | #include <linux/spinlock.h> |
38 | 38 | ||
39 | #include <asm/processor.h> | ||
39 | #include <asm/time.h> | 40 | #include <asm/time.h> |
40 | #include <asm/mach-au1x00/au1000.h> | 41 | #include <asm/mach-au1x00/au1000.h> |
41 | 42 | ||
42 | /* 32kHz clock enabled and detected */ | 43 | /* 32kHz clock enabled and detected */ |
43 | #define CNTR_OK (SYS_CNTRL_E0 | SYS_CNTRL_32S) | 44 | #define CNTR_OK (SYS_CNTRL_E0 | SYS_CNTRL_32S) |
44 | 45 | ||
45 | extern int allow_au1k_wait; /* default off for CP0 Counter */ | ||
46 | |||
47 | static cycle_t au1x_counter1_read(struct clocksource *cs) | 46 | static cycle_t au1x_counter1_read(struct clocksource *cs) |
48 | { | 47 | { |
49 | return au_readl(SYS_RTCREAD); | 48 | return au_readl(SYS_RTCREAD); |
@@ -153,13 +152,17 @@ void __init plat_time_init(void) | |||
153 | 152 | ||
154 | printk(KERN_INFO "Alchemy clocksource installed\n"); | 153 | printk(KERN_INFO "Alchemy clocksource installed\n"); |
155 | 154 | ||
156 | /* can now use 'wait' */ | ||
157 | allow_au1k_wait = 1; | ||
158 | return; | 155 | return; |
159 | 156 | ||
160 | cntr_err: | 157 | cntr_err: |
161 | /* counters unusable, use C0 counter */ | 158 | /* |
159 | * MIPS kernel assigns 'au1k_wait' to 'cpu_wait' before this | ||
160 | * function is called. Because the Alchemy counters are unusable | ||
161 | * the C0 timekeeping code is installed and use of the 'wait' | ||
162 | * instruction must be prohibited, which is done most easily by | ||
163 | * assigning NULL to cpu_wait. | ||
164 | */ | ||
165 | cpu_wait = NULL; | ||
162 | r4k_clockevent_init(); | 166 | r4k_clockevent_init(); |
163 | init_r4k_clocksource(); | 167 | init_r4k_clocksource(); |
164 | allow_au1k_wait = 0; | ||
165 | } | 168 | } |
diff --git a/arch/mips/kernel/cpu-probe.c b/arch/mips/kernel/cpu-probe.c index 1abe9905c9c1..6e4807a19c00 100644 --- a/arch/mips/kernel/cpu-probe.c +++ b/arch/mips/kernel/cpu-probe.c | |||
@@ -91,16 +91,13 @@ static void rm7k_wait_irqoff(void) | |||
91 | local_irq_enable(); | 91 | local_irq_enable(); |
92 | } | 92 | } |
93 | 93 | ||
94 | /* The Au1xxx wait is available only if using 32khz counter or | 94 | /* |
95 | * external timer source, but specifically not CP0 Counter. */ | 95 | * The Au1xxx wait is available only if using 32khz counter or |
96 | int allow_au1k_wait; | 96 | * external timer source, but specifically not CP0 Counter. |
97 | 97 | * alchemy/common/time.c may override cpu_wait! | |
98 | */ | ||
98 | static void au1k_wait(void) | 99 | static void au1k_wait(void) |
99 | { | 100 | { |
100 | if (!allow_au1k_wait) | ||
101 | return; | ||
102 | |||
103 | /* using the wait instruction makes CP0 counter unusable */ | ||
104 | __asm__(" .set mips3 \n" | 101 | __asm__(" .set mips3 \n" |
105 | " cache 0x14, 0(%0) \n" | 102 | " cache 0x14, 0(%0) \n" |
106 | " cache 0x14, 32(%0) \n" | 103 | " cache 0x14, 32(%0) \n" |