2007-02-16 01:28:02 -08:00
/*
* tick internal variable and functions used by low / high res code
*/
2011-01-27 16:00:32 +01:00
# include <linux/hrtimer.h>
# include <linux/tick.h>
2008-09-22 18:46:37 +02:00
2011-02-01 09:34:58 +01:00
# ifdef CONFIG_GENERIC_CLOCKEVENTS_BUILD
2008-09-22 18:46:37 +02:00
# define TICK_DO_TIMER_NONE -1
# define TICK_DO_TIMER_BOOT -2
2007-02-16 01:28:02 -08:00
DECLARE_PER_CPU ( struct tick_device , tick_cpu_device ) ;
extern ktime_t tick_next_period ;
extern ktime_t tick_period ;
2007-05-08 00:30:03 -07:00
extern int tick_do_timer_cpu __read_mostly ;
2007-02-16 01:28:02 -08:00
extern void tick_setup_periodic ( struct clock_event_device * dev , int broadcast ) ;
extern void tick_handle_periodic ( struct clock_event_device * dev ) ;
2008-09-16 11:32:50 -07:00
extern void clockevents_shutdown ( struct clock_event_device * dev ) ;
2007-02-16 01:28:03 -08:00
/*
* NO_HZ / high resolution timer shared code
*/
# ifdef CONFIG_TICK_ONESHOT
extern void tick_setup_oneshot ( struct clock_event_device * newdev ,
void ( * handler ) ( struct clock_event_device * ) ,
ktime_t nextevt ) ;
2008-09-03 21:37:14 +00:00
extern int tick_dev_program_event ( struct clock_event_device * dev ,
ktime_t expires , int force ) ;
2007-02-16 01:28:03 -08:00
extern int tick_program_event ( ktime_t expires , int force ) ;
extern void tick_oneshot_notify ( void ) ;
extern int tick_switch_to_oneshot ( void ( * handler ) ( struct clock_event_device * ) ) ;
2007-03-17 00:25:52 +01:00
extern void tick_resume_oneshot ( void ) ;
2007-02-16 01:28:03 -08:00
# ifdef CONFIG_GENERIC_CLOCKEVENTS_BROADCAST
extern void tick_broadcast_setup_oneshot ( struct clock_event_device * bc ) ;
extern void tick_broadcast_oneshot_control ( unsigned long reason ) ;
extern void tick_broadcast_switch_to_oneshot ( void ) ;
extern void tick_shutdown_broadcast_oneshot ( unsigned int * cpup ) ;
2007-03-17 00:25:52 +01:00
extern int tick_resume_broadcast_oneshot ( struct clock_event_device * bc ) ;
2008-09-22 19:04:02 +02:00
extern int tick_broadcast_oneshot_active ( void ) ;
2008-10-17 10:01:23 +02:00
extern void tick_check_oneshot_broadcast ( int cpu ) ;
2007-02-16 01:28:03 -08:00
# else /* BROADCAST */
static inline void tick_broadcast_setup_oneshot ( struct clock_event_device * bc )
{
BUG ( ) ;
}
static inline void tick_broadcast_oneshot_control ( unsigned long reason ) { }
static inline void tick_broadcast_switch_to_oneshot ( void ) { }
static inline void tick_shutdown_broadcast_oneshot ( unsigned int * cpup ) { }
2008-09-22 19:04:02 +02:00
static inline int tick_broadcast_oneshot_active ( void ) { return 0 ; }
2008-10-17 10:01:23 +02:00
static inline void tick_check_oneshot_broadcast ( int cpu ) { }
2007-02-16 01:28:03 -08:00
# endif /* !BROADCAST */
# else /* !ONESHOT */
static inline
void tick_setup_oneshot ( struct clock_event_device * newdev ,
void ( * handler ) ( struct clock_event_device * ) ,
ktime_t nextevt )
{
BUG ( ) ;
}
2007-03-17 00:25:52 +01:00
static inline void tick_resume_oneshot ( void )
{
BUG ( ) ;
}
2007-02-16 01:28:03 -08:00
static inline int tick_program_event ( ktime_t expires , int force )
{
return 0 ;
}
static inline void tick_oneshot_notify ( void ) { }
static inline void tick_broadcast_setup_oneshot ( struct clock_event_device * bc )
{
BUG ( ) ;
}
static inline void tick_broadcast_oneshot_control ( unsigned long reason ) { }
static inline void tick_shutdown_broadcast_oneshot ( unsigned int * cpup ) { }
2007-03-17 00:25:52 +01:00
static inline int tick_resume_broadcast_oneshot ( struct clock_event_device * bc )
{
return 0 ;
}
2008-09-23 13:00:57 +02:00
static inline int tick_broadcast_oneshot_active ( void ) { return 0 ; }
2007-02-16 01:28:03 -08:00
# endif /* !TICK_ONESHOT */
2007-02-16 01:28:02 -08:00
/*
* Broadcasting support
*/
# ifdef CONFIG_GENERIC_CLOCKEVENTS_BROADCAST
extern int tick_device_uses_broadcast ( struct clock_event_device * dev , int cpu ) ;
extern int tick_check_broadcast_device ( struct clock_event_device * dev ) ;
extern int tick_is_broadcast_device ( struct clock_event_device * dev ) ;
extern void tick_broadcast_on_off ( unsigned long reason , int * oncpu ) ;
extern void tick_shutdown_broadcast ( unsigned int * cpup ) ;
2007-03-06 08:25:42 +01:00
extern void tick_suspend_broadcast ( void ) ;
extern int tick_resume_broadcast ( void ) ;
2007-02-16 01:28:02 -08:00
extern void
tick_set_periodic_handler ( struct clock_event_device * dev , int broadcast ) ;
# else /* !BROADCAST */
static inline int tick_check_broadcast_device ( struct clock_event_device * dev )
{
return 0 ;
}
static inline int tick_is_broadcast_device ( struct clock_event_device * dev )
{
return 0 ;
}
static inline int tick_device_uses_broadcast ( struct clock_event_device * dev ,
int cpu )
{
return 0 ;
}
static inline void tick_do_periodic_broadcast ( struct clock_event_device * d ) { }
static inline void tick_broadcast_on_off ( unsigned long reason , int * oncpu ) { }
static inline void tick_shutdown_broadcast ( unsigned int * cpup ) { }
2007-03-06 08:25:42 +01:00
static inline void tick_suspend_broadcast ( void ) { }
static inline int tick_resume_broadcast ( void ) { return 0 ; }
2007-02-16 01:28:02 -08:00
/*
* Set the periodic handler in non broadcast mode
*/
static inline void tick_set_periodic_handler ( struct clock_event_device * dev ,
int broadcast )
{
dev - > event_handler = tick_handle_periodic ;
}
# endif /* !BROADCAST */
/*
* Check , if the device is functional or a dummy for broadcast
*/
static inline int tick_device_is_functional ( struct clock_event_device * dev )
{
return ! ( dev - > features & CLOCK_EVT_FEAT_DUMMY ) ;
}
2011-01-27 16:00:32 +01:00
2011-02-01 09:34:58 +01:00
# endif
2011-01-27 16:00:32 +01:00
extern void do_timer ( unsigned long ticks ) ;
extern seqlock_t xtime_lock ;