diff options
| -rw-r--r-- | drivers/clocksource/bcm_kona_timer.c | 54 |
1 files changed, 28 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); |
