diff options
author | David S. Miller <davem@sunset.davemloft.net> | 2006-02-17 15:33:13 -0500 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2006-03-20 04:13:29 -0500 |
commit | 3763be32d591cacf808c36390a8af3f2784cde5f (patch) | |
tree | 124ae01bf91905a6d3af931caf28acf82900699b | |
parent | 3f19a84e39619053f117bd5bb9183c5bfea7db45 (diff) |
[SPARC64]: Define ARCH_HAS_READ_CURRENT_TIMER.
This gives more consistent bogomips and delay() semantics,
especially on sun4v. It gives weird looking values though...
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | arch/sparc64/kernel/time.c | 8 | ||||
-rw-r--r-- | arch/sparc64/lib/delay.c | 19 | ||||
-rw-r--r-- | include/asm-sparc64/timex.h | 6 |
3 files changed, 15 insertions, 18 deletions
diff --git a/arch/sparc64/kernel/time.c b/arch/sparc64/kernel/time.c index 7041146f86f0..f6275adbc811 100644 --- a/arch/sparc64/kernel/time.c +++ b/arch/sparc64/kernel/time.c | |||
@@ -1029,11 +1029,10 @@ static void sparc64_start_timers(irqreturn_t (*cfunc)(int, void *, struct pt_reg | |||
1029 | } | 1029 | } |
1030 | 1030 | ||
1031 | struct freq_table { | 1031 | struct freq_table { |
1032 | unsigned long udelay_val_ref; | ||
1033 | unsigned long clock_tick_ref; | 1032 | unsigned long clock_tick_ref; |
1034 | unsigned int ref_freq; | 1033 | unsigned int ref_freq; |
1035 | }; | 1034 | }; |
1036 | static DEFINE_PER_CPU(struct freq_table, sparc64_freq_table) = { 0, 0, 0 }; | 1035 | static DEFINE_PER_CPU(struct freq_table, sparc64_freq_table) = { 0, 0 }; |
1037 | 1036 | ||
1038 | unsigned long sparc64_get_clock_tick(unsigned int cpu) | 1037 | unsigned long sparc64_get_clock_tick(unsigned int cpu) |
1039 | { | 1038 | { |
@@ -1055,16 +1054,11 @@ static int sparc64_cpufreq_notifier(struct notifier_block *nb, unsigned long val | |||
1055 | 1054 | ||
1056 | if (!ft->ref_freq) { | 1055 | if (!ft->ref_freq) { |
1057 | ft->ref_freq = freq->old; | 1056 | ft->ref_freq = freq->old; |
1058 | ft->udelay_val_ref = cpu_data(cpu).udelay_val; | ||
1059 | ft->clock_tick_ref = cpu_data(cpu).clock_tick; | 1057 | ft->clock_tick_ref = cpu_data(cpu).clock_tick; |
1060 | } | 1058 | } |
1061 | if ((val == CPUFREQ_PRECHANGE && freq->old < freq->new) || | 1059 | if ((val == CPUFREQ_PRECHANGE && freq->old < freq->new) || |
1062 | (val == CPUFREQ_POSTCHANGE && freq->old > freq->new) || | 1060 | (val == CPUFREQ_POSTCHANGE && freq->old > freq->new) || |
1063 | (val == CPUFREQ_RESUMECHANGE)) { | 1061 | (val == CPUFREQ_RESUMECHANGE)) { |
1064 | cpu_data(cpu).udelay_val = | ||
1065 | cpufreq_scale(ft->udelay_val_ref, | ||
1066 | ft->ref_freq, | ||
1067 | freq->new); | ||
1068 | cpu_data(cpu).clock_tick = | 1062 | cpu_data(cpu).clock_tick = |
1069 | cpufreq_scale(ft->clock_tick_ref, | 1063 | cpufreq_scale(ft->clock_tick_ref, |
1070 | ft->ref_freq, | 1064 | ft->ref_freq, |
diff --git a/arch/sparc64/lib/delay.c b/arch/sparc64/lib/delay.c index e8808727617a..fb27e54a03ee 100644 --- a/arch/sparc64/lib/delay.c +++ b/arch/sparc64/lib/delay.c | |||
@@ -1,6 +1,6 @@ | |||
1 | /* delay.c: Delay loops for sparc64 | 1 | /* delay.c: Delay loops for sparc64 |
2 | * | 2 | * |
3 | * Copyright (C) 2004 David S. Miller <davem@redhat.com> | 3 | * Copyright (C) 2004, 2006 David S. Miller <davem@davemloft.net> |
4 | * | 4 | * |
5 | * Based heavily upon x86 variant which is: | 5 | * Based heavily upon x86 variant which is: |
6 | * Copyright (C) 1993 Linus Torvalds | 6 | * Copyright (C) 1993 Linus Torvalds |
@@ -8,19 +8,16 @@ | |||
8 | */ | 8 | */ |
9 | 9 | ||
10 | #include <linux/delay.h> | 10 | #include <linux/delay.h> |
11 | #include <asm/timer.h> | ||
11 | 12 | ||
12 | void __delay(unsigned long loops) | 13 | void __delay(unsigned long loops) |
13 | { | 14 | { |
14 | __asm__ __volatile__( | 15 | unsigned long bclock, now; |
15 | " b,pt %%xcc, 1f\n" | 16 | |
16 | " cmp %0, 0\n" | 17 | bclock = tick_ops->get_tick(); |
17 | " .align 32\n" | 18 | do { |
18 | "1:\n" | 19 | now = tick_ops->get_tick(); |
19 | " bne,pt %%xcc, 1b\n" | 20 | } while ((now-bclock) < loops); |
20 | " subcc %0, 1, %0\n" | ||
21 | : "=&r" (loops) | ||
22 | : "0" (loops) | ||
23 | : "cc"); | ||
24 | } | 21 | } |
25 | 22 | ||
26 | /* We used to multiply by HZ after shifting down by 32 bits | 23 | /* We used to multiply by HZ after shifting down by 32 bits |
diff --git a/include/asm-sparc64/timex.h b/include/asm-sparc64/timex.h index 9e8d4175bcb2..2a5e4ebaad80 100644 --- a/include/asm-sparc64/timex.h +++ b/include/asm-sparc64/timex.h | |||
@@ -14,4 +14,10 @@ | |||
14 | typedef unsigned long cycles_t; | 14 | typedef unsigned long cycles_t; |
15 | #define get_cycles() tick_ops->get_tick() | 15 | #define get_cycles() tick_ops->get_tick() |
16 | 16 | ||
17 | #define ARCH_HAS_READ_CURRENT_TIMER 1 | ||
18 | #define read_current_timer(timer_val_p) \ | ||
19 | ({ *timer_val_p = tick_ops->get_tick(); \ | ||
20 | 0; \ | ||
21 | }) | ||
22 | |||
17 | #endif | 23 | #endif |