aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Stultz <john.stultz@linaro.org>2011-11-14 17:05:44 -0500
committerJohn Stultz <john.stultz@linaro.org>2012-01-26 22:44:27 -0500
commit92c1d3ed4dc0b8cfb10e85ed0c9934db41efc027 (patch)
tree233556d74e7bd062d8e174bc0a33fdc2dc7f95b1
parentbd3312681f69207a40431981c1bce1afdc9b7975 (diff)
time: Remove most of xtime_lock usage in timekeeping.c
Now that ntp.c's locking is reworked, we can remove most of the xtime_lock usage in timekeeping.c The remaining xtime_lock presence is really for jiffies access and the global load calculation. CC: Thomas Gleixner <tglx@linutronix.de> CC: Eric Dumazet <eric.dumazet@gmail.com> CC: Richard Cochran <richardcochran@gmail.com> Signed-off-by: John Stultz <john.stultz@linaro.org>
-rw-r--r--kernel/time/timekeeping.c44
1 files changed, 15 insertions, 29 deletions
diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c
index cdae24655c8d..74bb5701e0b3 100644
--- a/kernel/time/timekeeping.c
+++ b/kernel/time/timekeeping.c
@@ -172,7 +172,6 @@ static inline s64 timekeeping_get_ns_raw(void)
172 return clocksource_cyc2ns(cycle_delta, clock->mult, clock->shift); 172 return clocksource_cyc2ns(cycle_delta, clock->mult, clock->shift);
173} 173}
174 174
175/* must hold xtime_lock */
176void timekeeping_leap_insert(int leapsecond) 175void timekeeping_leap_insert(int leapsecond)
177{ 176{
178 unsigned long flags; 177 unsigned long flags;
@@ -372,13 +371,12 @@ EXPORT_SYMBOL(do_gettimeofday);
372int do_settimeofday(const struct timespec *tv) 371int do_settimeofday(const struct timespec *tv)
373{ 372{
374 struct timespec ts_delta; 373 struct timespec ts_delta;
375 unsigned long flags1,flags2; 374 unsigned long flags;
376 375
377 if ((unsigned long)tv->tv_nsec >= NSEC_PER_SEC) 376 if ((unsigned long)tv->tv_nsec >= NSEC_PER_SEC)
378 return -EINVAL; 377 return -EINVAL;
379 378
380 write_seqlock_irqsave(&xtime_lock, flags1); 379 write_seqlock_irqsave(&timekeeper.lock, flags);
381 write_seqlock_irqsave(&timekeeper.lock, flags2);
382 380
383 timekeeping_forward_now(); 381 timekeeping_forward_now();
384 382
@@ -395,8 +393,7 @@ int do_settimeofday(const struct timespec *tv)
395 update_vsyscall(&timekeeper.xtime, &timekeeper.wall_to_monotonic, 393 update_vsyscall(&timekeeper.xtime, &timekeeper.wall_to_monotonic,
396 timekeeper.clock, timekeeper.mult); 394 timekeeper.clock, timekeeper.mult);
397 395
398 write_sequnlock_irqrestore(&timekeeper.lock, flags2); 396 write_sequnlock_irqrestore(&timekeeper.lock, flags);
399 write_sequnlock_irqrestore(&xtime_lock, flags1);
400 397
401 /* signal hrtimers about time change */ 398 /* signal hrtimers about time change */
402 clock_was_set(); 399 clock_was_set();
@@ -415,13 +412,12 @@ EXPORT_SYMBOL(do_settimeofday);
415 */ 412 */
416int timekeeping_inject_offset(struct timespec *ts) 413int timekeeping_inject_offset(struct timespec *ts)
417{ 414{
418 unsigned long flags1,flags2; 415 unsigned long flags;
419 416
420 if ((unsigned long)ts->tv_nsec >= NSEC_PER_SEC) 417 if ((unsigned long)ts->tv_nsec >= NSEC_PER_SEC)
421 return -EINVAL; 418 return -EINVAL;
422 419
423 write_seqlock_irqsave(&xtime_lock, flags1); 420 write_seqlock_irqsave(&timekeeper.lock, flags);
424 write_seqlock_irqsave(&timekeeper.lock, flags2);
425 421
426 timekeeping_forward_now(); 422 timekeeping_forward_now();
427 423
@@ -435,8 +431,7 @@ int timekeeping_inject_offset(struct timespec *ts)
435 update_vsyscall(&timekeeper.xtime, &timekeeper.wall_to_monotonic, 431 update_vsyscall(&timekeeper.xtime, &timekeeper.wall_to_monotonic,
436 timekeeper.clock, timekeeper.mult); 432 timekeeper.clock, timekeeper.mult);
437 433
438 write_sequnlock_irqrestore(&timekeeper.lock, flags2); 434 write_sequnlock_irqrestore(&timekeeper.lock, flags);
439 write_sequnlock_irqrestore(&xtime_lock, flags1);
440 435
441 /* signal hrtimers about time change */ 436 /* signal hrtimers about time change */
442 clock_was_set(); 437 clock_was_set();
@@ -598,9 +593,7 @@ void __init timekeeping_init(void)
598 593
599 seqlock_init(&timekeeper.lock); 594 seqlock_init(&timekeeper.lock);
600 595
601 write_seqlock_irqsave(&xtime_lock, flags);
602 ntp_init(); 596 ntp_init();
603 write_sequnlock_irqrestore(&xtime_lock, flags);
604 597
605 write_seqlock_irqsave(&timekeeper.lock, flags); 598 write_seqlock_irqsave(&timekeeper.lock, flags);
606 clock = clocksource_default_clock(); 599 clock = clocksource_default_clock();
@@ -661,7 +654,7 @@ static void __timekeeping_inject_sleeptime(struct timespec *delta)
661 */ 654 */
662void timekeeping_inject_sleeptime(struct timespec *delta) 655void timekeeping_inject_sleeptime(struct timespec *delta)
663{ 656{
664 unsigned long flags1,flags2; 657 unsigned long flags;
665 struct timespec ts; 658 struct timespec ts;
666 659
667 /* Make sure we don't set the clock twice */ 660 /* Make sure we don't set the clock twice */
@@ -669,8 +662,7 @@ void timekeeping_inject_sleeptime(struct timespec *delta)
669 if (!(ts.tv_sec == 0 && ts.tv_nsec == 0)) 662 if (!(ts.tv_sec == 0 && ts.tv_nsec == 0))
670 return; 663 return;
671 664
672 write_seqlock_irqsave(&xtime_lock, flags1); 665 write_seqlock_irqsave(&timekeeper.lock, flags);
673 write_seqlock_irqsave(&timekeeper.lock, flags2);
674 666
675 timekeeping_forward_now(); 667 timekeeping_forward_now();
676 668
@@ -681,8 +673,7 @@ void timekeeping_inject_sleeptime(struct timespec *delta)
681 update_vsyscall(&timekeeper.xtime, &timekeeper.wall_to_monotonic, 673 update_vsyscall(&timekeeper.xtime, &timekeeper.wall_to_monotonic,
682 timekeeper.clock, timekeeper.mult); 674 timekeeper.clock, timekeeper.mult);
683 675
684 write_sequnlock_irqrestore(&timekeeper.lock, flags2); 676 write_sequnlock_irqrestore(&timekeeper.lock, flags);
685 write_sequnlock_irqrestore(&xtime_lock, flags1);
686 677
687 /* signal hrtimers about time change */ 678 /* signal hrtimers about time change */
688 clock_was_set(); 679 clock_was_set();
@@ -698,15 +689,14 @@ void timekeeping_inject_sleeptime(struct timespec *delta)
698 */ 689 */
699static void timekeeping_resume(void) 690static void timekeeping_resume(void)
700{ 691{
701 unsigned long flags1,flags2; 692 unsigned long flags;
702 struct timespec ts; 693 struct timespec ts;
703 694
704 read_persistent_clock(&ts); 695 read_persistent_clock(&ts);
705 696
706 clocksource_resume(); 697 clocksource_resume();
707 698
708 write_seqlock_irqsave(&xtime_lock, flags1); 699 write_seqlock_irqsave(&timekeeper.lock, flags);
709 write_seqlock_irqsave(&timekeeper.lock, flags2);
710 700
711 if (timespec_compare(&ts, &timekeeping_suspend_time) > 0) { 701 if (timespec_compare(&ts, &timekeeping_suspend_time) > 0) {
712 ts = timespec_sub(ts, timekeeping_suspend_time); 702 ts = timespec_sub(ts, timekeeping_suspend_time);
@@ -716,8 +706,7 @@ static void timekeeping_resume(void)
716 timekeeper.clock->cycle_last = timekeeper.clock->read(timekeeper.clock); 706 timekeeper.clock->cycle_last = timekeeper.clock->read(timekeeper.clock);
717 timekeeper.ntp_error = 0; 707 timekeeper.ntp_error = 0;
718 timekeeping_suspended = 0; 708 timekeeping_suspended = 0;
719 write_sequnlock_irqrestore(&timekeeper.lock, flags2); 709 write_sequnlock_irqrestore(&timekeeper.lock, flags);
720 write_sequnlock_irqrestore(&xtime_lock, flags1);
721 710
722 touch_softlockup_watchdog(); 711 touch_softlockup_watchdog();
723 712
@@ -729,14 +718,13 @@ static void timekeeping_resume(void)
729 718
730static int timekeeping_suspend(void) 719static int timekeeping_suspend(void)
731{ 720{
732 unsigned long flags1,flags2; 721 unsigned long flags;
733 struct timespec delta, delta_delta; 722 struct timespec delta, delta_delta;
734 static struct timespec old_delta; 723 static struct timespec old_delta;
735 724
736 read_persistent_clock(&timekeeping_suspend_time); 725 read_persistent_clock(&timekeeping_suspend_time);
737 726
738 write_seqlock_irqsave(&xtime_lock, flags1); 727 write_seqlock_irqsave(&timekeeper.lock, flags);
739 write_seqlock_irqsave(&timekeeper.lock, flags2);
740 timekeeping_forward_now(); 728 timekeeping_forward_now();
741 timekeeping_suspended = 1; 729 timekeeping_suspended = 1;
742 730
@@ -759,8 +747,7 @@ static int timekeeping_suspend(void)
759 timekeeping_suspend_time = 747 timekeeping_suspend_time =
760 timespec_add(timekeeping_suspend_time, delta_delta); 748 timespec_add(timekeeping_suspend_time, delta_delta);
761 } 749 }
762 write_sequnlock_irqrestore(&timekeeper.lock, flags2); 750 write_sequnlock_irqrestore(&timekeeper.lock, flags);
763 write_sequnlock_irqrestore(&xtime_lock, flags1);
764 751
765 clockevents_notify(CLOCK_EVT_NOTIFY_SUSPEND, NULL); 752 clockevents_notify(CLOCK_EVT_NOTIFY_SUSPEND, NULL);
766 clocksource_suspend(); 753 clocksource_suspend();
@@ -1006,7 +993,6 @@ static cycle_t logarithmic_accumulation(cycle_t offset, int shift)
1006/** 993/**
1007 * update_wall_time - Uses the current clocksource to increment the wall time 994 * update_wall_time - Uses the current clocksource to increment the wall time
1008 * 995 *
1009 * Called from the timer interrupt, must hold a write on xtime_lock.
1010 */ 996 */
1011static void update_wall_time(void) 997static void update_wall_time(void)
1012{ 998{