diff options
| author | Ingo Molnar <mingo@kernel.org> | 2013-12-17 09:27:08 -0500 |
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2013-12-17 09:27:08 -0500 |
| commit | bb799d3b980eb803ca2da4a4eefbd9308f8d988a (patch) | |
| tree | 69fbe0cd6d47b23a50f5e1d87bf7489532fae149 /arch/s390/kernel/time.c | |
| parent | 919fc6e34831d1c2b58bfb5ae261dc3facc9b269 (diff) | |
| parent | 319e2e3f63c348a9b66db4667efa73178e18b17d (diff) | |
Merge tag 'v3.13-rc4' into core/locking
Merge Linux 3.13-rc4, to refresh this rather old tree with the latest fixes.
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'arch/s390/kernel/time.c')
| -rw-r--r-- | arch/s390/kernel/time.c | 46 |
1 files changed, 22 insertions, 24 deletions
diff --git a/arch/s390/kernel/time.c b/arch/s390/kernel/time.c index 064c3082ab33..dd95f1631621 100644 --- a/arch/s390/kernel/time.c +++ b/arch/s390/kernel/time.c | |||
| @@ -108,20 +108,10 @@ static void fixup_clock_comparator(unsigned long long delta) | |||
| 108 | set_clock_comparator(S390_lowcore.clock_comparator); | 108 | set_clock_comparator(S390_lowcore.clock_comparator); |
| 109 | } | 109 | } |
| 110 | 110 | ||
| 111 | static int s390_next_ktime(ktime_t expires, | 111 | static int s390_next_event(unsigned long delta, |
| 112 | struct clock_event_device *evt) | 112 | struct clock_event_device *evt) |
| 113 | { | 113 | { |
| 114 | struct timespec ts; | 114 | S390_lowcore.clock_comparator = get_tod_clock() + delta; |
| 115 | u64 nsecs; | ||
| 116 | |||
| 117 | ts.tv_sec = ts.tv_nsec = 0; | ||
| 118 | monotonic_to_bootbased(&ts); | ||
| 119 | nsecs = ktime_to_ns(ktime_add(timespec_to_ktime(ts), expires)); | ||
| 120 | do_div(nsecs, 125); | ||
| 121 | S390_lowcore.clock_comparator = sched_clock_base_cc + (nsecs << 9); | ||
| 122 | /* Program the maximum value if we have an overflow (== year 2042) */ | ||
| 123 | if (unlikely(S390_lowcore.clock_comparator < sched_clock_base_cc)) | ||
| 124 | S390_lowcore.clock_comparator = -1ULL; | ||
| 125 | set_clock_comparator(S390_lowcore.clock_comparator); | 115 | set_clock_comparator(S390_lowcore.clock_comparator); |
| 126 | return 0; | 116 | return 0; |
| 127 | } | 117 | } |
| @@ -146,15 +136,14 @@ void init_cpu_timer(void) | |||
| 146 | cpu = smp_processor_id(); | 136 | cpu = smp_processor_id(); |
| 147 | cd = &per_cpu(comparators, cpu); | 137 | cd = &per_cpu(comparators, cpu); |
| 148 | cd->name = "comparator"; | 138 | cd->name = "comparator"; |
| 149 | cd->features = CLOCK_EVT_FEAT_ONESHOT | | 139 | cd->features = CLOCK_EVT_FEAT_ONESHOT; |
| 150 | CLOCK_EVT_FEAT_KTIME; | ||
| 151 | cd->mult = 16777; | 140 | cd->mult = 16777; |
| 152 | cd->shift = 12; | 141 | cd->shift = 12; |
| 153 | cd->min_delta_ns = 1; | 142 | cd->min_delta_ns = 1; |
| 154 | cd->max_delta_ns = LONG_MAX; | 143 | cd->max_delta_ns = LONG_MAX; |
| 155 | cd->rating = 400; | 144 | cd->rating = 400; |
| 156 | cd->cpumask = cpumask_of(cpu); | 145 | cd->cpumask = cpumask_of(cpu); |
| 157 | cd->set_next_ktime = s390_next_ktime; | 146 | cd->set_next_event = s390_next_event; |
| 158 | cd->set_mode = s390_set_mode; | 147 | cd->set_mode = s390_set_mode; |
| 159 | 148 | ||
| 160 | clockevents_register_device(cd); | 149 | clockevents_register_device(cd); |
| @@ -221,21 +210,30 @@ struct clocksource * __init clocksource_default_clock(void) | |||
| 221 | return &clocksource_tod; | 210 | return &clocksource_tod; |
| 222 | } | 211 | } |
| 223 | 212 | ||
| 224 | void update_vsyscall_old(struct timespec *wall_time, struct timespec *wtm, | 213 | void update_vsyscall(struct timekeeper *tk) |
| 225 | struct clocksource *clock, u32 mult) | ||
| 226 | { | 214 | { |
| 227 | if (clock != &clocksource_tod) | 215 | u64 nsecps; |
| 216 | |||
| 217 | if (tk->clock != &clocksource_tod) | ||
| 228 | return; | 218 | return; |
| 229 | 219 | ||
| 230 | /* Make userspace gettimeofday spin until we're done. */ | 220 | /* Make userspace gettimeofday spin until we're done. */ |
| 231 | ++vdso_data->tb_update_count; | 221 | ++vdso_data->tb_update_count; |
| 232 | smp_wmb(); | 222 | smp_wmb(); |
| 233 | vdso_data->xtime_tod_stamp = clock->cycle_last; | 223 | vdso_data->xtime_tod_stamp = tk->clock->cycle_last; |
| 234 | vdso_data->xtime_clock_sec = wall_time->tv_sec; | 224 | vdso_data->xtime_clock_sec = tk->xtime_sec; |
| 235 | vdso_data->xtime_clock_nsec = wall_time->tv_nsec; | 225 | vdso_data->xtime_clock_nsec = tk->xtime_nsec; |
| 236 | vdso_data->wtom_clock_sec = wtm->tv_sec; | 226 | vdso_data->wtom_clock_sec = |
| 237 | vdso_data->wtom_clock_nsec = wtm->tv_nsec; | 227 | tk->xtime_sec + tk->wall_to_monotonic.tv_sec; |
| 238 | vdso_data->ntp_mult = mult; | 228 | vdso_data->wtom_clock_nsec = tk->xtime_nsec + |
| 229 | + (tk->wall_to_monotonic.tv_nsec << tk->shift); | ||
| 230 | nsecps = (u64) NSEC_PER_SEC << tk->shift; | ||
| 231 | while (vdso_data->wtom_clock_nsec >= nsecps) { | ||
| 232 | vdso_data->wtom_clock_nsec -= nsecps; | ||
| 233 | vdso_data->wtom_clock_sec++; | ||
| 234 | } | ||
| 235 | vdso_data->tk_mult = tk->mult; | ||
| 236 | vdso_data->tk_shift = tk->shift; | ||
| 239 | smp_wmb(); | 237 | smp_wmb(); |
| 240 | ++vdso_data->tb_update_count; | 238 | ++vdso_data->tb_update_count; |
| 241 | } | 239 | } |
