diff options
Diffstat (limited to 'kernel/time/tick-common.c')
| -rw-r--r-- | kernel/time/tick-common.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/kernel/time/tick-common.c b/kernel/time/tick-common.c index 43ba1bdec14c..bfda3f7f0716 100644 --- a/kernel/time/tick-common.c +++ b/kernel/time/tick-common.c | |||
| @@ -298,18 +298,17 @@ static void tick_shutdown(unsigned int *cpup) | |||
| 298 | spin_unlock_irqrestore(&tick_device_lock, flags); | 298 | spin_unlock_irqrestore(&tick_device_lock, flags); |
| 299 | } | 299 | } |
| 300 | 300 | ||
| 301 | static void tick_suspend_periodic(void) | 301 | static void tick_suspend(void) |
| 302 | { | 302 | { |
| 303 | struct tick_device *td = &__get_cpu_var(tick_cpu_device); | 303 | struct tick_device *td = &__get_cpu_var(tick_cpu_device); |
| 304 | unsigned long flags; | 304 | unsigned long flags; |
| 305 | 305 | ||
| 306 | spin_lock_irqsave(&tick_device_lock, flags); | 306 | spin_lock_irqsave(&tick_device_lock, flags); |
| 307 | if (td->mode == TICKDEV_MODE_PERIODIC) | 307 | clockevents_set_mode(td->evtdev, CLOCK_EVT_MODE_SHUTDOWN); |
| 308 | clockevents_set_mode(td->evtdev, CLOCK_EVT_MODE_SHUTDOWN); | ||
| 309 | spin_unlock_irqrestore(&tick_device_lock, flags); | 308 | spin_unlock_irqrestore(&tick_device_lock, flags); |
| 310 | } | 309 | } |
| 311 | 310 | ||
| 312 | static void tick_resume_periodic(void) | 311 | static void tick_resume(void) |
| 313 | { | 312 | { |
| 314 | struct tick_device *td = &__get_cpu_var(tick_cpu_device); | 313 | struct tick_device *td = &__get_cpu_var(tick_cpu_device); |
| 315 | unsigned long flags; | 314 | unsigned long flags; |
| @@ -317,6 +316,8 @@ static void tick_resume_periodic(void) | |||
| 317 | spin_lock_irqsave(&tick_device_lock, flags); | 316 | spin_lock_irqsave(&tick_device_lock, flags); |
| 318 | if (td->mode == TICKDEV_MODE_PERIODIC) | 317 | if (td->mode == TICKDEV_MODE_PERIODIC) |
| 319 | tick_setup_periodic(td->evtdev, 0); | 318 | tick_setup_periodic(td->evtdev, 0); |
| 319 | else | ||
| 320 | tick_resume_oneshot(); | ||
| 320 | spin_unlock_irqrestore(&tick_device_lock, flags); | 321 | spin_unlock_irqrestore(&tick_device_lock, flags); |
| 321 | } | 322 | } |
| 322 | 323 | ||
| @@ -348,13 +349,13 @@ static int tick_notify(struct notifier_block *nb, unsigned long reason, | |||
| 348 | break; | 349 | break; |
| 349 | 350 | ||
| 350 | case CLOCK_EVT_NOTIFY_SUSPEND: | 351 | case CLOCK_EVT_NOTIFY_SUSPEND: |
| 351 | tick_suspend_periodic(); | 352 | tick_suspend(); |
| 352 | tick_suspend_broadcast(); | 353 | tick_suspend_broadcast(); |
| 353 | break; | 354 | break; |
| 354 | 355 | ||
| 355 | case CLOCK_EVT_NOTIFY_RESUME: | 356 | case CLOCK_EVT_NOTIFY_RESUME: |
| 356 | if (!tick_resume_broadcast()) | 357 | if (!tick_resume_broadcast()) |
| 357 | tick_resume_periodic(); | 358 | tick_resume(); |
| 358 | break; | 359 | break; |
| 359 | 360 | ||
| 360 | default: | 361 | default: |
