diff options
| -rw-r--r-- | drivers/clocksource/bcm_kona_timer.c | 54 | ||||
| -rw-r--r-- | kernel/time/jiffies.c | 6 | ||||
| -rw-r--r-- | kernel/time/tick-broadcast.c | 1 |
3 files changed, 35 insertions, 26 deletions
diff --git a/drivers/clocksource/bcm_kona_timer.c b/drivers/clocksource/bcm_kona_timer.c index 974b2db2fe10..0595dc6c453e 100644 --- a/drivers/clocksource/bcm_kona_timer.c +++ b/drivers/clocksource/bcm_kona_timer.c | |||
| @@ -99,31 +99,6 @@ kona_timer_get_counter(void *timer_base, uint32_t *msw, uint32_t *lsw) | |||
| 99 | return; | 99 | return; |
| 100 | } | 100 | } |
| 101 | 101 | ||
| 102 | static void __init kona_timers_init(struct device_node *node) | ||
| 103 | { | ||
| 104 | u32 freq; | ||
| 105 | struct clk *external_clk; | ||
| 106 | |||
| 107 | external_clk = of_clk_get_by_name(node, NULL); | ||
| 108 | |||
| 109 | if (!IS_ERR(external_clk)) { | ||
| 110 | arch_timer_rate = clk_get_rate(external_clk); | ||
| 111 | clk_prepare_enable(external_clk); | ||
| 112 | } else if (!of_property_read_u32(node, "clock-frequency", &freq)) { | ||
| 113 | arch_timer_rate = freq; | ||
| 114 | } else { | ||
| 115 | panic("unable to determine clock-frequency"); | ||
| 116 | } | ||
| 117 | |||
| 118 | /* Setup IRQ numbers */ | ||
| 119 | timers.tmr_irq = irq_of_parse_and_map(node, 0); | ||
| 120 | |||
| 121 | /* Setup IO addresses */ | ||
| 122 | timers.tmr_regs = of_iomap(node, 0); | ||
| 123 | |||
| 124 | kona_timer_disable_and_clear(timers.tmr_regs); | ||
| 125 | } | ||
| 126 | |||
| 127 | static int kona_timer_set_next_event(unsigned long clc, | 102 | static int kona_timer_set_next_event(unsigned long clc, |
| 128 | struct clock_event_device *unused) | 103 | struct clock_event_device *unused) |
| 129 | { | 104 | { |
| @@ -198,7 +173,34 @@ static struct irqaction kona_timer_irq = { | |||
| 198 | 173 | ||
| 199 | static void __init kona_timer_init(struct device_node *node) | 174 | static void __init kona_timer_init(struct device_node *node) |
| 200 | { | 175 | { |
| 201 | kona_timers_init(node); | 176 | u32 freq; |
| 177 | struct clk *external_clk; | ||
| 178 | |||
| 179 | if (!of_device_is_available(node)) { | ||
| 180 | pr_info("Kona Timer v1 marked as disabled in device tree\n"); | ||
| 181 | return; | ||
| 182 | } | ||
| 183 | |||
| 184 | external_clk = of_clk_get_by_name(node, NULL); | ||
| 185 | |||
| 186 | if (!IS_ERR(external_clk)) { | ||
| 187 | arch_timer_rate = clk_get_rate(external_clk); | ||
| 188 | clk_prepare_enable(external_clk); | ||
| 189 | } else if (!of_property_read_u32(node, "clock-frequency", &freq)) { | ||
| 190 | arch_timer_rate = freq; | ||
| 191 | } else { | ||
| 192 | pr_err("Kona Timer v1 unable to determine clock-frequency"); | ||
| 193 | return; | ||
| 194 | } | ||
| 195 | |||
| 196 | /* Setup IRQ numbers */ | ||
| 197 | timers.tmr_irq = irq_of_parse_and_map(node, 0); | ||
| 198 | |||
| 199 | /* Setup IO addresses */ | ||
| 200 | timers.tmr_regs = of_iomap(node, 0); | ||
| 201 | |||
| 202 | kona_timer_disable_and_clear(timers.tmr_regs); | ||
| 203 | |||
| 202 | kona_timer_clockevents_init(); | 204 | kona_timer_clockevents_init(); |
| 203 | setup_irq(timers.tmr_irq, &kona_timer_irq); | 205 | setup_irq(timers.tmr_irq, &kona_timer_irq); |
| 204 | kona_timer_set_next_event((arch_timer_rate / HZ), NULL); | 206 | kona_timer_set_next_event((arch_timer_rate / HZ), NULL); |
diff --git a/kernel/time/jiffies.c b/kernel/time/jiffies.c index 7a925ba456fb..a6a5bf53e86d 100644 --- a/kernel/time/jiffies.c +++ b/kernel/time/jiffies.c | |||
| @@ -51,7 +51,13 @@ | |||
| 51 | * HZ shrinks, so values greater than 8 overflow 32bits when | 51 | * HZ shrinks, so values greater than 8 overflow 32bits when |
| 52 | * HZ=100. | 52 | * HZ=100. |
| 53 | */ | 53 | */ |
| 54 | #if HZ < 34 | ||
| 55 | #define JIFFIES_SHIFT 6 | ||
| 56 | #elif HZ < 67 | ||
| 57 | #define JIFFIES_SHIFT 7 | ||
| 58 | #else | ||
| 54 | #define JIFFIES_SHIFT 8 | 59 | #define JIFFIES_SHIFT 8 |
| 60 | #endif | ||
| 55 | 61 | ||
| 56 | static cycle_t jiffies_read(struct clocksource *cs) | 62 | static cycle_t jiffies_read(struct clocksource *cs) |
| 57 | { | 63 | { |
diff --git a/kernel/time/tick-broadcast.c b/kernel/time/tick-broadcast.c index 43780ab5e279..98977a57ac72 100644 --- a/kernel/time/tick-broadcast.c +++ b/kernel/time/tick-broadcast.c | |||
| @@ -756,6 +756,7 @@ out: | |||
| 756 | static void tick_broadcast_clear_oneshot(int cpu) | 756 | static void tick_broadcast_clear_oneshot(int cpu) |
| 757 | { | 757 | { |
| 758 | cpumask_clear_cpu(cpu, tick_broadcast_oneshot_mask); | 758 | cpumask_clear_cpu(cpu, tick_broadcast_oneshot_mask); |
| 759 | cpumask_clear_cpu(cpu, tick_broadcast_pending_mask); | ||
| 759 | } | 760 | } |
| 760 | 761 | ||
| 761 | static void tick_broadcast_init_next_event(struct cpumask *mask, | 762 | static void tick_broadcast_init_next_event(struct cpumask *mask, |
