diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-06-15 10:06:19 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-06-15 10:06:19 -0700 | 
| commit | 19035e5b5d1e3127b4925d86f6a77964f91f2c3c (patch) | |
| tree | c9e7e9073970176a5b0970da715cb6430c3c9069 /include | |
| parent | f9db6e095115f9411b9647bdb9d81fe11f3d8b54 (diff) | |
| parent | eea08f32adb3f97553d49a4f79a119833036000a (diff) | |
Merge branch 'timers-for-linus-migration' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip
* 'timers-for-linus-migration' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
  timers: Logic to move non pinned timers
  timers: /proc/sys sysctl hook to enable timer migration
  timers: Identifying the existing pinned timers
  timers: Framework for identifying pinned timers
  timers: allow deferrable timers for intervals tv2-tv5 to be deferred
Fix up conflicts in kernel/sched.c and kernel/timer.c manually
Diffstat (limited to 'include')
| -rw-r--r-- | include/linux/clockchips.h | 9 | ||||
| -rw-r--r-- | include/linux/hrtimer.h | 7 | ||||
| -rw-r--r-- | include/linux/sched.h | 13 | ||||
| -rw-r--r-- | include/linux/timer.h | 3 | 
4 files changed, 30 insertions, 2 deletions
| diff --git a/include/linux/clockchips.h b/include/linux/clockchips.h index 3a1dbba4d3a..20a100fe2b4 100644 --- a/include/linux/clockchips.h +++ b/include/linux/clockchips.h @@ -143,3 +143,12 @@ extern void clockevents_notify(unsigned long reason, void *arg);  #endif  #endif + +#ifdef CONFIG_GENERIC_CLOCKEVENTS +extern ktime_t clockevents_get_next_event(int cpu); +#else +static inline ktime_t clockevents_get_next_event(int cpu) +{ +	return (ktime_t) { .tv64 = KTIME_MAX }; +} +#endif diff --git a/include/linux/hrtimer.h b/include/linux/hrtimer.h index 0d2f7c8a33d..7400900de94 100644 --- a/include/linux/hrtimer.h +++ b/include/linux/hrtimer.h @@ -30,8 +30,11 @@ struct hrtimer_cpu_base;   * Mode arguments of xxx_hrtimer functions:   */  enum hrtimer_mode { -	HRTIMER_MODE_ABS,	/* Time value is absolute */ -	HRTIMER_MODE_REL,	/* Time value is relative to now */ +	HRTIMER_MODE_ABS = 0x0,		/* Time value is absolute */ +	HRTIMER_MODE_REL = 0x1,		/* Time value is relative to now */ +	HRTIMER_MODE_PINNED = 0x02,	/* Timer is bound to CPU */ +	HRTIMER_MODE_ABS_PINNED = 0x02, +	HRTIMER_MODE_REL_PINNED = 0x03,  };  /* diff --git a/include/linux/sched.h b/include/linux/sched.h index fea9d188dbf..c900aa53007 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h @@ -261,6 +261,7 @@ extern void task_rq_unlock_wait(struct task_struct *p);  extern cpumask_var_t nohz_cpu_mask;  #if defined(CONFIG_SMP) && defined(CONFIG_NO_HZ)  extern int select_nohz_load_balancer(int cpu); +extern int get_nohz_load_balancer(void);  #else  static inline int select_nohz_load_balancer(int cpu)  { @@ -1796,11 +1797,23 @@ extern unsigned int sysctl_sched_child_runs_first;  extern unsigned int sysctl_sched_features;  extern unsigned int sysctl_sched_migration_cost;  extern unsigned int sysctl_sched_nr_migrate; +extern unsigned int sysctl_timer_migration;  int sched_nr_latency_handler(struct ctl_table *table, int write,  		struct file *file, void __user *buffer, size_t *length,  		loff_t *ppos);  #endif +#ifdef CONFIG_SCHED_DEBUG +static inline unsigned int get_sysctl_timer_migration(void) +{ +	return sysctl_timer_migration; +} +#else +static inline unsigned int get_sysctl_timer_migration(void) +{ +	return 1; +} +#endif  extern unsigned int sysctl_sched_rt_period;  extern int sysctl_sched_rt_runtime; diff --git a/include/linux/timer.h b/include/linux/timer.h index 6cdb6f3331f..ccf882eed8f 100644 --- a/include/linux/timer.h +++ b/include/linux/timer.h @@ -163,7 +163,10 @@ extern void add_timer_on(struct timer_list *timer, int cpu);  extern int del_timer(struct timer_list * timer);  extern int mod_timer(struct timer_list *timer, unsigned long expires);  extern int mod_timer_pending(struct timer_list *timer, unsigned long expires); +extern int mod_timer_pinned(struct timer_list *timer, unsigned long expires); +#define TIMER_NOT_PINNED	0 +#define TIMER_PINNED		1  /*   * The jiffies value which is added to now, when there is no timer   * in the timer wheel: | 
