On Fri, Dec 21, 2012 at 10:02:18AM +0000, Santosh Shilimkar wrote: > On Tuesday 18 December 2012 05:36 PM, Mark Rutland wrote: > > Currently the broadcast mechanism used for timers is abstracted by a > > function pointer on struct clock_event_device. As the fundamental > > mechanism for broadcast is architecture-specific, this ties each > > clock_event_device driver to a single architecture, even where the > > driver is otherwise generic. > > > > This patch adds a standard path for the receipt of timer broadcasts, so > > drivers and/or architecture backends need not manage redundant lists of > > timers for the purpose of routing broadcast timer ticks. > > > > Signed-off-by: Mark Rutland <mark.rutl...@arm.com> > > --- > > include/linux/clockchips.h | 4 ++++ > > kernel/time/tick-broadcast.c | 15 +++++++++++++++ > > 2 files changed, 19 insertions(+), 0 deletions(-) > > > > diff --git a/include/linux/clockchips.h b/include/linux/clockchips.h > > index 8a7096f..e1089aa 100644 > > --- a/include/linux/clockchips.h > > +++ b/include/linux/clockchips.h > > @@ -161,6 +161,10 @@ clockevents_calc_mult_shift(struct clock_event_device > > *ce, u32 freq, u32 minsec) > > extern void clockevents_suspend(void); > > extern void clockevents_resume(void); > > > > +#ifdef CONFIG_GENERIC_CLOCKEVENTS_BROADCAST > > +extern int tick_receive_broadcast(void); > > +#endif > > + > As mentioned in earlier patch, CONFIG_GENERIC_CLOCKEVENTS_BROADCAST > isn't must for SMP kernel and hence when build with > !GENERIC_CLOCKEVENTS_BROADCAST, $subject patch will break the build.
I'd assumed that the broadcast receive path would be ifdef'd on CONFIG_GENERIC_CLOCKEVENTS_BROADCAST, and thus this wouldn't be a problem. Though I guess it probably makes arch/platform code a bit nicer if it doesn't have to ifdef everything. > Below is the fix for the same. Feel free to fold it if you agree. Will do. > diff --git a/include/linux/clockchips.h b/include/linux/clockchips.h > index 6634652..921568b 100644 > --- a/include/linux/clockchips.h > +++ b/include/linux/clockchips.h > @@ -168,6 +168,11 @@ extern void tick_broadcast(const struct cpumask *mask); > #define tick_broadcast NULL > #endif > extern int tick_receive_broadcast(void); > +#else > +static inline int tick_receive_broadcast(void) > +{ > + return 0; > +} > #endif > > #ifdef CONFIG_GENERIC_CLOCKEVENTS > Thanks, Mark. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/