2  * linux/kernel/time/tick-common.c
 
   4  * This file contains the base functions to manage periodic tick
 
   7  * Copyright(C) 2005-2006, Thomas Gleixner <tglx@linutronix.de>
 
   8  * Copyright(C) 2005-2007, Red Hat, Inc., Ingo Molnar
 
   9  * Copyright(C) 2006-2007, Timesys Corp., Thomas Gleixner
 
  11  * This code is licenced under the GPL version 2. For details see
 
  12  * kernel-base/COPYING.
 
  14 #include <linux/cpu.h>
 
  15 #include <linux/err.h>
 
  16 #include <linux/hrtimer.h>
 
  17 #include <linux/irq.h>
 
  18 #include <linux/percpu.h>
 
  19 #include <linux/profile.h>
 
  20 #include <linux/sched.h>
 
  21 #include <linux/tick.h>
 
  23 #include "tick-internal.h"
 
  28 DEFINE_PER_CPU(struct tick_device, tick_cpu_device);
 
  30  * Tick next event: keeps track of the tick time
 
  32 ktime_t tick_next_period;
 
  34 int tick_do_timer_cpu __read_mostly = -1;
 
  35 DEFINE_SPINLOCK(tick_device_lock);
 
  38  * Debugging: see timer_list.c
 
  40 struct tick_device *tick_get_device(int cpu)
 
  42         return &per_cpu(tick_cpu_device, cpu);
 
  46  * tick_is_oneshot_available - check for a oneshot capable event device
 
  48 int tick_is_oneshot_available(void)
 
  50         struct clock_event_device *dev = __get_cpu_var(tick_cpu_device).evtdev;
 
  52         return dev && (dev->features & CLOCK_EVT_FEAT_ONESHOT);
 
  58 static void tick_periodic(int cpu)
 
  60         if (tick_do_timer_cpu == cpu) {
 
  61                 write_seqlock(&xtime_lock);
 
  63                 /* Keep track of the next tick event */
 
  64                 tick_next_period = ktime_add(tick_next_period, tick_period);
 
  67                 write_sequnlock(&xtime_lock);
 
  70         update_process_times(user_mode(get_irq_regs()));
 
  71         profile_tick(CPU_PROFILING);
 
  75  * Event handler for periodic ticks
 
  77 void tick_handle_periodic(struct clock_event_device *dev)
 
  79         int cpu = smp_processor_id();
 
  84         if (dev->mode != CLOCK_EVT_MODE_ONESHOT)
 
  87          * Setup the next period for devices, which do not have
 
  90         next = ktime_add(dev->next_event, tick_period);
 
  92                 if (!clockevents_program_event(dev, next, ktime_get()))
 
  95                 next = ktime_add(next, tick_period);
 
 100  * Setup the device for a periodic tick
 
 102 void tick_setup_periodic(struct clock_event_device *dev, int broadcast)
 
 104         tick_set_periodic_handler(dev, broadcast);
 
 106         /* Broadcast setup ? */
 
 107         if (!tick_device_is_functional(dev))
 
 110         if (dev->features & CLOCK_EVT_FEAT_PERIODIC) {
 
 111                 clockevents_set_mode(dev, CLOCK_EVT_MODE_PERIODIC);
 
 117                         seq = read_seqbegin(&xtime_lock);
 
 118                         next = tick_next_period;
 
 119                 } while (read_seqretry(&xtime_lock, seq));
 
 121                 clockevents_set_mode(dev, CLOCK_EVT_MODE_ONESHOT);
 
 124                         if (!clockevents_program_event(dev, next, ktime_get()))
 
 126                         next = ktime_add(next, tick_period);
 
 132  * Setup the tick device
 
 134 static void tick_setup_device(struct tick_device *td,
 
 135                               struct clock_event_device *newdev, int cpu,
 
 139         void (*handler)(struct clock_event_device *) = NULL;
 
 142          * First device setup ?
 
 146                  * If no cpu took the do_timer update, assign it to
 
 149                 if (tick_do_timer_cpu == -1) {
 
 150                         tick_do_timer_cpu = cpu;
 
 151                         tick_next_period = ktime_get();
 
 152                         tick_period = ktime_set(0, NSEC_PER_SEC / HZ);
 
 156                  * Startup in periodic mode first.
 
 158                 td->mode = TICKDEV_MODE_PERIODIC;
 
 160                 handler = td->evtdev->event_handler;
 
 161                 next_event = td->evtdev->next_event;
 
 167          * When the device is not per cpu, pin the interrupt to the
 
 170         if (!cpus_equal(newdev->cpumask, cpumask))
 
 171                 irq_set_affinity(newdev->irq, cpumask);
 
 174          * When global broadcasting is active, check if the current
 
 175          * device is registered as a placeholder for broadcast mode.
 
 176          * This allows us to handle this x86 misfeature in a generic
 
 179         if (tick_device_uses_broadcast(newdev, cpu))
 
 182         if (td->mode == TICKDEV_MODE_PERIODIC)
 
 183                 tick_setup_periodic(newdev, 0);
 
 185                 tick_setup_oneshot(newdev, handler, next_event);
 
 189  * Check, if the new registered device should be used.
 
 191 static int tick_check_new_device(struct clock_event_device *newdev)
 
 193         struct clock_event_device *curdev;
 
 194         struct tick_device *td;
 
 195         int cpu, ret = NOTIFY_OK;
 
 199         spin_lock_irqsave(&tick_device_lock, flags);
 
 201         cpu = smp_processor_id();
 
 202         if (!cpu_isset(cpu, newdev->cpumask))
 
 205         td = &per_cpu(tick_cpu_device, cpu);
 
 207         cpumask = cpumask_of_cpu(cpu);
 
 209         /* cpu local device ? */
 
 210         if (!cpus_equal(newdev->cpumask, cpumask)) {
 
 213                  * If the cpu affinity of the device interrupt can not
 
 216                 if (!irq_can_set_affinity(newdev->irq))
 
 220                  * If we have a cpu local device already, do not replace it
 
 221                  * by a non cpu local device
 
 223                 if (curdev && cpus_equal(curdev->cpumask, cpumask))
 
 228          * If we have an active device, then check the rating and the oneshot
 
 233                  * Prefer one shot capable devices !
 
 235                 if ((curdev->features & CLOCK_EVT_FEAT_ONESHOT) &&
 
 236                     !(newdev->features & CLOCK_EVT_FEAT_ONESHOT))
 
 241                 if (curdev->rating >= newdev->rating)
 
 246          * Replace the eventually existing device by the new
 
 247          * device. If the current device is the broadcast device, do
 
 248          * not give it back to the clockevents layer !
 
 250         if (tick_is_broadcast_device(curdev)) {
 
 251                 clockevents_set_mode(curdev, CLOCK_EVT_MODE_SHUTDOWN);
 
 254         clockevents_exchange_device(curdev, newdev);
 
 255         tick_setup_device(td, newdev, cpu, cpumask);
 
 256         if (newdev->features & CLOCK_EVT_FEAT_ONESHOT)
 
 257                 tick_oneshot_notify();
 
 259         spin_unlock_irqrestore(&tick_device_lock, flags);
 
 264          * Can the new device be used as a broadcast device ?
 
 266         if (tick_check_broadcast_device(newdev))
 
 269         spin_unlock_irqrestore(&tick_device_lock, flags);
 
 275  * Shutdown an event device on a given cpu:
 
 277  * This is called on a life CPU, when a CPU is dead. So we cannot
 
 278  * access the hardware device itself.
 
 279  * We just set the mode and remove it from the lists.
 
 281 static void tick_shutdown(unsigned int *cpup)
 
 283         struct tick_device *td = &per_cpu(tick_cpu_device, *cpup);
 
 284         struct clock_event_device *dev = td->evtdev;
 
 287         spin_lock_irqsave(&tick_device_lock, flags);
 
 288         td->mode = TICKDEV_MODE_PERIODIC;
 
 291                  * Prevent that the clock events layer tries to call
 
 292                  * the set mode function!
 
 294                 dev->mode = CLOCK_EVT_MODE_UNUSED;
 
 295                 clockevents_exchange_device(dev, NULL);
 
 298         /* Transfer the do_timer job away from this cpu */
 
 299         if (*cpup == tick_do_timer_cpu) {
 
 300                 int cpu = first_cpu(cpu_online_map);
 
 302                 tick_do_timer_cpu = (cpu != NR_CPUS) ? cpu : -1;
 
 304         spin_unlock_irqrestore(&tick_device_lock, flags);
 
 307 static void tick_suspend(void)
 
 309         struct tick_device *td = &__get_cpu_var(tick_cpu_device);
 
 312         spin_lock_irqsave(&tick_device_lock, flags);
 
 313         clockevents_set_mode(td->evtdev, CLOCK_EVT_MODE_SHUTDOWN);
 
 314         spin_unlock_irqrestore(&tick_device_lock, flags);
 
 317 static void tick_resume(void)
 
 319         struct tick_device *td = &__get_cpu_var(tick_cpu_device);
 
 321         int broadcast = tick_resume_broadcast();
 
 323         spin_lock_irqsave(&tick_device_lock, flags);
 
 324         clockevents_set_mode(td->evtdev, CLOCK_EVT_MODE_RESUME);
 
 327                 if (td->mode == TICKDEV_MODE_PERIODIC)
 
 328                         tick_setup_periodic(td->evtdev, 0);
 
 330                         tick_resume_oneshot();
 
 332         spin_unlock_irqrestore(&tick_device_lock, flags);
 
 336  * Notification about clock event devices
 
 338 static int tick_notify(struct notifier_block *nb, unsigned long reason,
 
 343         case CLOCK_EVT_NOTIFY_ADD:
 
 344                 return tick_check_new_device(dev);
 
 346         case CLOCK_EVT_NOTIFY_BROADCAST_ON:
 
 347         case CLOCK_EVT_NOTIFY_BROADCAST_OFF:
 
 348                 tick_broadcast_on_off(reason, dev);
 
 351         case CLOCK_EVT_NOTIFY_BROADCAST_ENTER:
 
 352         case CLOCK_EVT_NOTIFY_BROADCAST_EXIT:
 
 353                 tick_broadcast_oneshot_control(reason);
 
 356         case CLOCK_EVT_NOTIFY_CPU_DEAD:
 
 357                 tick_shutdown_broadcast_oneshot(dev);
 
 358                 tick_shutdown_broadcast(dev);
 
 362         case CLOCK_EVT_NOTIFY_SUSPEND:
 
 364                 tick_suspend_broadcast();
 
 367         case CLOCK_EVT_NOTIFY_RESUME:
 
 378 static struct notifier_block tick_notifier = {
 
 379         .notifier_call = tick_notify,
 
 383  * tick_init - initialize the tick control
 
 385  * Register the notifier with the clockevents framework
 
 387 void __init tick_init(void)
 
 389         clockevents_register_notifier(&tick_notifier);