aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/clocksource
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/clocksource')
-rw-r--r--drivers/clocksource/mmio.c2
-rw-r--r--drivers/clocksource/vt8500_timer.c6
2 files changed, 5 insertions, 3 deletions
diff --git a/drivers/clocksource/mmio.c b/drivers/clocksource/mmio.c
index 1593ade2a815..c4f7d7a9b689 100644
--- a/drivers/clocksource/mmio.c
+++ b/drivers/clocksource/mmio.c
@@ -55,7 +55,7 @@ int __init clocksource_mmio_init(void __iomem *base, const char *name,
55{ 55{
56 struct clocksource_mmio *cs; 56 struct clocksource_mmio *cs;
57 57
58 if (bits > 32 || bits < 16) 58 if (bits > 64 || bits < 16)
59 return -EINVAL; 59 return -EINVAL;
60 60
61 cs = kzalloc(sizeof(struct clocksource_mmio), GFP_KERNEL); 61 cs = kzalloc(sizeof(struct clocksource_mmio), GFP_KERNEL);
diff --git a/drivers/clocksource/vt8500_timer.c b/drivers/clocksource/vt8500_timer.c
index de49805fbb09..ddb409274f45 100644
--- a/drivers/clocksource/vt8500_timer.c
+++ b/drivers/clocksource/vt8500_timer.c
@@ -49,6 +49,8 @@
49 49
50#define msecs_to_loops(t) (loops_per_jiffy / 1000 * HZ * t) 50#define msecs_to_loops(t) (loops_per_jiffy / 1000 * HZ * t)
51 51
52#define MIN_OSCR_DELTA 16
53
52static void __iomem *regbase; 54static void __iomem *regbase;
53 55
54static cycle_t vt8500_timer_read(struct clocksource *cs) 56static cycle_t vt8500_timer_read(struct clocksource *cs)
@@ -79,7 +81,7 @@ static int vt8500_timer_set_next_event(unsigned long cycles,
79 cpu_relax(); 81 cpu_relax();
80 writel((unsigned long)alarm, regbase + TIMER_MATCH_VAL); 82 writel((unsigned long)alarm, regbase + TIMER_MATCH_VAL);
81 83
82 if ((signed)(alarm - clocksource.read(&clocksource)) <= 16) 84 if ((signed)(alarm - clocksource.read(&clocksource)) <= MIN_OSCR_DELTA)
83 return -ETIME; 85 return -ETIME;
84 86
85 writel(1, regbase + TIMER_IER_VAL); 87 writel(1, regbase + TIMER_IER_VAL);
@@ -150,7 +152,7 @@ static void __init vt8500_timer_init(struct device_node *np)
150 pr_err("%s: setup_irq failed for %s\n", __func__, 152 pr_err("%s: setup_irq failed for %s\n", __func__,
151 clockevent.name); 153 clockevent.name);
152 clockevents_config_and_register(&clockevent, VT8500_TIMER_HZ, 154 clockevents_config_and_register(&clockevent, VT8500_TIMER_HZ,
153 4, 0xf0000000); 155 MIN_OSCR_DELTA * 2, 0xf0000000);
154} 156}
155 157
156CLOCKSOURCE_OF_DECLARE(vt8500, "via,vt8500-timer", vt8500_timer_init); 158CLOCKSOURCE_OF_DECLARE(vt8500, "via,vt8500-timer", vt8500_timer_init);