Commit ba919d1c authored by Thomas Gleixner's avatar Thomas Gleixner

clocksource: Let timekeeping_notify return success/error

timekeeping_notify() can fail due cs->enable() failure. Though the
caller does not notice and happily keeps the wrong clocksource as the
current one.

Let the caller know about failure, so the current clocksource will be
shown correctly in sysfs.
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Acked-by: default avatarJohn Stultz <john.stultz@linaro.org>
Cc: Magnus Damm <magnus.damm@gmail.com>
Link: http://lkml.kernel.org/r/20130425143435.696321912@linutronix.deSigned-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
parent 5d33b883
...@@ -321,7 +321,7 @@ static inline void __clocksource_updatefreq_khz(struct clocksource *cs, u32 khz) ...@@ -321,7 +321,7 @@ static inline void __clocksource_updatefreq_khz(struct clocksource *cs, u32 khz)
} }
extern void timekeeping_notify(struct clocksource *clock); extern int timekeeping_notify(struct clocksource *clock);
extern cycle_t clocksource_mmio_readl_up(struct clocksource *); extern cycle_t clocksource_mmio_readl_up(struct clocksource *);
extern cycle_t clocksource_mmio_readl_down(struct clocksource *); extern cycle_t clocksource_mmio_readl_down(struct clocksource *);
......
...@@ -611,10 +611,10 @@ static void clocksource_select(void) ...@@ -611,10 +611,10 @@ static void clocksource_select(void)
best = cs; best = cs;
break; break;
} }
if (curr_clocksource != best) {
printk(KERN_INFO "Switching to clocksource %s\n", best->name); if (curr_clocksource != best && !timekeeping_notify(best)) {
pr_info("Switched to clocksource %s\n", best->name);
curr_clocksource = best; curr_clocksource = best;
timekeeping_notify(curr_clocksource);
} }
} }
......
...@@ -648,14 +648,15 @@ static int change_clocksource(void *data) ...@@ -648,14 +648,15 @@ static int change_clocksource(void *data)
* This function is called from clocksource.c after a new, better clock * This function is called from clocksource.c after a new, better clock
* source has been registered. The caller holds the clocksource_mutex. * source has been registered. The caller holds the clocksource_mutex.
*/ */
void timekeeping_notify(struct clocksource *clock) int timekeeping_notify(struct clocksource *clock)
{ {
struct timekeeper *tk = &timekeeper; struct timekeeper *tk = &timekeeper;
if (tk->clock == clock) if (tk->clock == clock)
return; return 0;
stop_machine(change_clocksource, clock, NULL); stop_machine(change_clocksource, clock, NULL);
tick_clock_notify(); tick_clock_notify();
return tk->clock == clock ? 0 : -1;
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment