summaryrefslogtreecommitdiffstats
path: root/drivers/clocksource
diff options
context:
space:
mode:
authorLadislav Michl <ladis@linux-mips.org>2018-02-23 05:15:01 -0500
committerTony Lindgren <tony@atomide.com>2018-02-28 16:41:30 -0500
commit58a54f03e73d67432216931854363e4ba15839b9 (patch)
tree2eff25bbed5762ec7ac87a2ad57b1fcac8567bab /drivers/clocksource
parentad6e4b6fdc99ebbd520d2faf3c6d48198c74a99b (diff)
clocksource: timer-ti-dm: Check prescaler value
Invalid value silently disables use of the prescaler. Use -1 explicitely for that purpose and error out on invalid value. Signed-off-by: Ladislav Michl <ladis@linux-mips.org> Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'drivers/clocksource')
-rw-r--r--drivers/clocksource/timer-ti-dm.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/clocksource/timer-ti-dm.c b/drivers/clocksource/timer-ti-dm.c
index 6abe5ab553ce..4cce6b224b87 100644
--- a/drivers/clocksource/timer-ti-dm.c
+++ b/drivers/clocksource/timer-ti-dm.c
@@ -663,13 +663,13 @@ static int omap_dm_timer_set_prescaler(struct omap_dm_timer *timer,
663{ 663{
664 u32 l; 664 u32 l;
665 665
666 if (unlikely(!timer)) 666 if (unlikely(!timer) || prescaler < -1 || prescaler > 7)
667 return -EINVAL; 667 return -EINVAL;
668 668
669 omap_dm_timer_enable(timer); 669 omap_dm_timer_enable(timer);
670 l = omap_dm_timer_read_reg(timer, OMAP_TIMER_CTRL_REG); 670 l = omap_dm_timer_read_reg(timer, OMAP_TIMER_CTRL_REG);
671 l &= ~(OMAP_TIMER_CTRL_PRE | (0x07 << 2)); 671 l &= ~(OMAP_TIMER_CTRL_PRE | (0x07 << 2));
672 if (prescaler >= 0x00 && prescaler <= 0x07) { 672 if (prescaler >= 0) {
673 l |= OMAP_TIMER_CTRL_PRE; 673 l |= OMAP_TIMER_CTRL_PRE;
674 l |= prescaler << 2; 674 l |= prescaler << 2;
675 } 675 }