clocksource.c 25.3 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/*
 * linux/kernel/time/clocksource.c
 *
 * This file contains the functions which manage clocksource drivers.
 *
 * Copyright (C) 2004, 2005 IBM, John Stultz (johnstul@us.ibm.com)
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 * TODO WishList:
 *   o Allow clocksource drivers to be unregistered
 */

#include <linux/clocksource.h>
#include <linux/sysdev.h>
#include <linux/init.h>
#include <linux/module.h>
30
#include <linux/sched.h> /* for spin_unlock_irq() using preempt_count() m68k */
31
#include <linux/tick.h>
32
#include <linux/kthread.h>
33

34 35 36 37 38 39 40 41
void timecounter_init(struct timecounter *tc,
		      const struct cyclecounter *cc,
		      u64 start_tstamp)
{
	tc->cc = cc;
	tc->cycle_last = cc->read(cc);
	tc->nsec = start_tstamp;
}
42
EXPORT_SYMBOL_GPL(timecounter_init);
43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85

/**
 * timecounter_read_delta - get nanoseconds since last call of this function
 * @tc:         Pointer to time counter
 *
 * When the underlying cycle counter runs over, this will be handled
 * correctly as long as it does not run over more than once between
 * calls.
 *
 * The first call to this function for a new time counter initializes
 * the time tracking and returns an undefined result.
 */
static u64 timecounter_read_delta(struct timecounter *tc)
{
	cycle_t cycle_now, cycle_delta;
	u64 ns_offset;

	/* read cycle counter: */
	cycle_now = tc->cc->read(tc->cc);

	/* calculate the delta since the last timecounter_read_delta(): */
	cycle_delta = (cycle_now - tc->cycle_last) & tc->cc->mask;

	/* convert to nanoseconds: */
	ns_offset = cyclecounter_cyc2ns(tc->cc, cycle_delta);

	/* update time stamp of timecounter_read_delta() call: */
	tc->cycle_last = cycle_now;

	return ns_offset;
}

u64 timecounter_read(struct timecounter *tc)
{
	u64 nsec;

	/* increment time by nanoseconds since last call */
	nsec = timecounter_read_delta(tc);
	nsec += tc->nsec;
	tc->nsec = nsec;

	return nsec;
}
86
EXPORT_SYMBOL_GPL(timecounter_read);
87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107

u64 timecounter_cyc2time(struct timecounter *tc,
			 cycle_t cycle_tstamp)
{
	u64 cycle_delta = (cycle_tstamp - tc->cycle_last) & tc->cc->mask;
	u64 nsec;

	/*
	 * Instead of always treating cycle_tstamp as more recent
	 * than tc->cycle_last, detect when it is too far in the
	 * future and treat it as old time stamp instead.
	 */
	if (cycle_delta > tc->cc->mask / 2) {
		cycle_delta = (tc->cycle_last - cycle_tstamp) & tc->cc->mask;
		nsec = tc->nsec - cyclecounter_cyc2ns(tc->cc, cycle_delta);
	} else {
		nsec = cyclecounter_cyc2ns(tc->cc, cycle_delta) + tc->nsec;
	}

	return nsec;
}
108
EXPORT_SYMBOL_GPL(timecounter_cyc2time);
109

110 111 112 113 114 115
/**
 * clocks_calc_mult_shift - calculate mult/shift factors for scaled math of clocks
 * @mult:	pointer to mult variable
 * @shift:	pointer to shift variable
 * @from:	frequency to convert from
 * @to:		frequency to convert to
116
 * @maxsec:	guaranteed runtime conversion range in seconds
117 118 119 120 121 122 123 124
 *
 * The function evaluates the shift/mult pair for the scaled math
 * operations of clocksources and clockevents.
 *
 * @to and @from are frequency values in HZ. For clock sources @to is
 * NSEC_PER_SEC == 1GHz and @from is the counter frequency. For clock
 * event @to is the counter frequency and @from is NSEC_PER_SEC.
 *
125
 * The @maxsec conversion range argument controls the time frame in
126 127 128 129 130 131 132 133
 * seconds which must be covered by the runtime conversion with the
 * calculated mult and shift factors. This guarantees that no 64bit
 * overflow happens when the input value of the conversion is
 * multiplied with the calculated mult factor. Larger ranges may
 * reduce the conversion accuracy by chosing smaller mult and shift
 * factors.
 */
void
134
clocks_calc_mult_shift(u32 *mult, u32 *shift, u32 from, u32 to, u32 maxsec)
135 136 137 138 139 140 141 142
{
	u64 tmp;
	u32 sft, sftacc= 32;

	/*
	 * Calculate the shift factor which is limiting the conversion
	 * range:
	 */
143
	tmp = ((u64)maxsec * from) >> 32;
144 145 146 147 148 149 150 151 152 153 154
	while (tmp) {
		tmp >>=1;
		sftacc--;
	}

	/*
	 * Find the conversion shift/mult pair which has the best
	 * accuracy and fits the maxsec conversion range:
	 */
	for (sft = 32; sft > 0; sft--) {
		tmp = (u64) to << sft;
155
		tmp += from / 2;
156 157 158 159 160 161 162 163
		do_div(tmp, from);
		if ((tmp >> sftacc) == 0)
			break;
	}
	*mult = tmp;
	*shift = sft;
}

164 165
/*[Clocksource internal variables]---------
 * curr_clocksource:
166
 *	currently selected clocksource.
167 168
 * clocksource_list:
 *	linked list with the registered clocksources
169 170
 * clocksource_mutex:
 *	protects manipulations to curr_clocksource and the clocksource_list
171 172 173
 * override_name:
 *	Name of the user-specified clocksource.
 */
174
static struct clocksource *curr_clocksource;
175
static LIST_HEAD(clocksource_list);
176
static DEFINE_MUTEX(clocksource_mutex);
177
static char override_name[32];
178
static int finished_booting;
179

180
#ifdef CONFIG_CLOCKSOURCE_WATCHDOG
181 182
static void clocksource_watchdog_work(struct work_struct *work);

183 184 185
static LIST_HEAD(watchdog_list);
static struct clocksource *watchdog;
static struct timer_list watchdog_timer;
186
static DECLARE_WORK(watchdog_work, clocksource_watchdog_work);
187
static DEFINE_SPINLOCK(watchdog_lock);
188
static int watchdog_running;
T
Thomas Gleixner 已提交
189

190
static int clocksource_watchdog_kthread(void *data);
191
static void __clocksource_change_rating(struct clocksource *cs, int rating);
192

193
/*
194
 * Interval: 0.5sec Threshold: 0.0625s
195 196
 */
#define WATCHDOG_INTERVAL (HZ >> 1)
197
#define WATCHDOG_THRESHOLD (NSEC_PER_SEC >> 4)
198

199 200 201 202 203 204 205 206 207
static void clocksource_watchdog_work(struct work_struct *work)
{
	/*
	 * If kthread_run fails the next watchdog scan over the
	 * watchdog_list will find the unstable clock again.
	 */
	kthread_run(clocksource_watchdog_kthread, NULL, "kwatchdog");
}

208
static void __clocksource_unstable(struct clocksource *cs)
209 210
{
	cs->flags &= ~(CLOCK_SOURCE_VALID_FOR_HRES | CLOCK_SOURCE_WATCHDOG);
211
	cs->flags |= CLOCK_SOURCE_UNSTABLE;
212 213
	if (finished_booting)
		schedule_work(&watchdog_work);
214 215
}

216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244
static void clocksource_unstable(struct clocksource *cs, int64_t delta)
{
	printk(KERN_WARNING "Clocksource %s unstable (delta = %Ld ns)\n",
	       cs->name, delta);
	__clocksource_unstable(cs);
}

/**
 * clocksource_mark_unstable - mark clocksource unstable via watchdog
 * @cs:		clocksource to be marked unstable
 *
 * This function is called instead of clocksource_change_rating from
 * cpu hotplug code to avoid a deadlock between the clocksource mutex
 * and the cpu hotplug mutex. It defers the update of the clocksource
 * to the watchdog thread.
 */
void clocksource_mark_unstable(struct clocksource *cs)
{
	unsigned long flags;

	spin_lock_irqsave(&watchdog_lock, flags);
	if (!(cs->flags & CLOCK_SOURCE_UNSTABLE)) {
		if (list_empty(&cs->wd_list))
			list_add(&cs->wd_list, &watchdog_list);
		__clocksource_unstable(cs);
	}
	spin_unlock_irqrestore(&watchdog_lock, flags);
}

245 246
static void clocksource_watchdog(unsigned long data)
{
247
	struct clocksource *cs;
248 249
	cycle_t csnow, wdnow;
	int64_t wd_nsec, cs_nsec;
250
	int next_cpu;
251 252

	spin_lock(&watchdog_lock);
253 254
	if (!watchdog_running)
		goto out;
255

256 257 258
	list_for_each_entry(cs, &watchdog_list, wd_list) {

		/* Clocksource already marked unstable? */
259
		if (cs->flags & CLOCK_SOURCE_UNSTABLE) {
260 261
			if (finished_booting)
				schedule_work(&watchdog_work);
262
			continue;
263
		}
264

265
		local_irq_disable();
266
		csnow = cs->read(cs);
267 268
		wdnow = watchdog->read(watchdog);
		local_irq_enable();
T
Thomas Gleixner 已提交
269

270 271 272
		/* Clocksource initialized ? */
		if (!(cs->flags & CLOCK_SOURCE_WATCHDOG)) {
			cs->flags |= CLOCK_SOURCE_WATCHDOG;
273 274
			cs->wd_last = wdnow;
			cs->cs_last = csnow;
T
Thomas Gleixner 已提交
275 276 277
			continue;
		}

278 279 280 281
		wd_nsec = clocksource_cyc2ns((wdnow - cs->wd_last) & watchdog->mask,
					     watchdog->mult, watchdog->shift);

		cs_nsec = clocksource_cyc2ns((csnow - cs->cs_last) &
282
					     cs->mask, cs->mult, cs->shift);
283 284 285 286
		cs->cs_last = csnow;
		cs->wd_last = wdnow;

		/* Check the deviation from the watchdog clocksource. */
287 288 289 290 291 292 293 294 295 296 297 298 299 300 301
		if (abs(cs_nsec - wd_nsec) > WATCHDOG_THRESHOLD) {
			clocksource_unstable(cs, cs_nsec - wd_nsec);
			continue;
		}

		if (!(cs->flags & CLOCK_SOURCE_VALID_FOR_HRES) &&
		    (cs->flags & CLOCK_SOURCE_IS_CONTINUOUS) &&
		    (watchdog->flags & CLOCK_SOURCE_IS_CONTINUOUS)) {
			cs->flags |= CLOCK_SOURCE_VALID_FOR_HRES;
			/*
			 * We just marked the clocksource as highres-capable,
			 * notify the rest of the system as well so that we
			 * transition into high-res mode:
			 */
			tick_clock_notify();
302 303 304
		}
	}

305 306 307 308 309 310 311 312 313
	/*
	 * Cycle through CPUs to check if the CPUs stay synchronized
	 * to each other.
	 */
	next_cpu = cpumask_next(raw_smp_processor_id(), cpu_online_mask);
	if (next_cpu >= nr_cpu_ids)
		next_cpu = cpumask_first(cpu_online_mask);
	watchdog_timer.expires += WATCHDOG_INTERVAL;
	add_timer_on(&watchdog_timer, next_cpu);
314
out:
315 316
	spin_unlock(&watchdog_lock);
}
317

318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336
static inline void clocksource_start_watchdog(void)
{
	if (watchdog_running || !watchdog || list_empty(&watchdog_list))
		return;
	init_timer(&watchdog_timer);
	watchdog_timer.function = clocksource_watchdog;
	watchdog_timer.expires = jiffies + WATCHDOG_INTERVAL;
	add_timer_on(&watchdog_timer, cpumask_first(cpu_online_mask));
	watchdog_running = 1;
}

static inline void clocksource_stop_watchdog(void)
{
	if (!watchdog_running || (watchdog && !list_empty(&watchdog_list)))
		return;
	del_timer(&watchdog_timer);
	watchdog_running = 0;
}

337 338 339 340 341 342 343 344
static inline void clocksource_reset_watchdog(void)
{
	struct clocksource *cs;

	list_for_each_entry(cs, &watchdog_list, wd_list)
		cs->flags &= ~CLOCK_SOURCE_WATCHDOG;
}

T
Thomas Gleixner 已提交
345 346
static void clocksource_resume_watchdog(void)
{
347 348
	unsigned long flags;

349 350 351 352 353 354 355 356 357 358 359 360 361
	/*
	 * We use trylock here to avoid a potential dead lock when
	 * kgdb calls this code after the kernel has been stopped with
	 * watchdog_lock held. When watchdog_lock is held we just
	 * return and accept, that the watchdog might trigger and mark
	 * the monitored clock source (usually TSC) unstable.
	 *
	 * This does not affect the other caller clocksource_resume()
	 * because at this point the kernel is UP, interrupts are
	 * disabled and nothing can hold watchdog_lock.
	 */
	if (!spin_trylock_irqsave(&watchdog_lock, flags))
		return;
362 363
	clocksource_reset_watchdog();
	spin_unlock_irqrestore(&watchdog_lock, flags);
T
Thomas Gleixner 已提交
364 365
}

366
static void clocksource_enqueue_watchdog(struct clocksource *cs)
367 368 369 370 371
{
	unsigned long flags;

	spin_lock_irqsave(&watchdog_lock, flags);
	if (cs->flags & CLOCK_SOURCE_MUST_VERIFY) {
372
		/* cs is a clocksource to be watched. */
373
		list_add(&cs->wd_list, &watchdog_list);
374
		cs->flags &= ~CLOCK_SOURCE_WATCHDOG;
375
	} else {
376
		/* cs is a watchdog. */
377
		if (cs->flags & CLOCK_SOURCE_IS_CONTINUOUS)
378
			cs->flags |= CLOCK_SOURCE_VALID_FOR_HRES;
379
		/* Pick the best watchdog. */
380 381 382
		if (!watchdog || cs->rating > watchdog->rating) {
			watchdog = cs;
			/* Reset watchdog cycles */
383
			clocksource_reset_watchdog();
384 385
		}
	}
386 387
	/* Check if the watchdog timer needs to be started. */
	clocksource_start_watchdog();
388 389
	spin_unlock_irqrestore(&watchdog_lock, flags);
}
390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417

static void clocksource_dequeue_watchdog(struct clocksource *cs)
{
	struct clocksource *tmp;
	unsigned long flags;

	spin_lock_irqsave(&watchdog_lock, flags);
	if (cs->flags & CLOCK_SOURCE_MUST_VERIFY) {
		/* cs is a watched clocksource. */
		list_del_init(&cs->wd_list);
	} else if (cs == watchdog) {
		/* Reset watchdog cycles */
		clocksource_reset_watchdog();
		/* Current watchdog is removed. Find an alternative. */
		watchdog = NULL;
		list_for_each_entry(tmp, &clocksource_list, list) {
			if (tmp == cs || tmp->flags & CLOCK_SOURCE_MUST_VERIFY)
				continue;
			if (!watchdog || tmp->rating > watchdog->rating)
				watchdog = tmp;
		}
	}
	cs->flags &= ~CLOCK_SOURCE_WATCHDOG;
	/* Check if the watchdog timer needs to be stopped. */
	clocksource_stop_watchdog();
	spin_unlock_irqrestore(&watchdog_lock, flags);
}

418
static int clocksource_watchdog_kthread(void *data)
419 420 421
{
	struct clocksource *cs, *tmp;
	unsigned long flags;
422
	LIST_HEAD(unstable);
423

424
	mutex_lock(&clocksource_mutex);
425 426 427 428
	spin_lock_irqsave(&watchdog_lock, flags);
	list_for_each_entry_safe(cs, tmp, &watchdog_list, wd_list)
		if (cs->flags & CLOCK_SOURCE_UNSTABLE) {
			list_del_init(&cs->wd_list);
429
			list_add(&cs->wd_list, &unstable);
430 431 432
		}
	/* Check if the watchdog timer needs to be stopped. */
	clocksource_stop_watchdog();
433 434 435 436 437
	spin_unlock_irqrestore(&watchdog_lock, flags);

	/* Needs to be done outside of watchdog lock */
	list_for_each_entry_safe(cs, tmp, &unstable, wd_list) {
		list_del_init(&cs->wd_list);
438
		__clocksource_change_rating(cs, 0);
439
	}
440
	mutex_unlock(&clocksource_mutex);
441
	return 0;
442 443
}

444 445 446
#else /* CONFIG_CLOCKSOURCE_WATCHDOG */

static void clocksource_enqueue_watchdog(struct clocksource *cs)
447 448 449 450
{
	if (cs->flags & CLOCK_SOURCE_IS_CONTINUOUS)
		cs->flags |= CLOCK_SOURCE_VALID_FOR_HRES;
}
T
Thomas Gleixner 已提交
451

452
static inline void clocksource_dequeue_watchdog(struct clocksource *cs) { }
T
Thomas Gleixner 已提交
453
static inline void clocksource_resume_watchdog(void) { }
454
static inline int clocksource_watchdog_kthread(void *data) { return 0; }
455 456

#endif /* CONFIG_CLOCKSOURCE_WATCHDOG */
457

M
Magnus Damm 已提交
458 459 460 461 462 463 464 465 466 467 468 469
/**
 * clocksource_suspend - suspend the clocksource(s)
 */
void clocksource_suspend(void)
{
	struct clocksource *cs;

	list_for_each_entry_reverse(cs, &clocksource_list, list)
		if (cs->suspend)
			cs->suspend(cs);
}

T
Thomas Gleixner 已提交
470 471 472 473 474
/**
 * clocksource_resume - resume the clocksource(s)
 */
void clocksource_resume(void)
{
475
	struct clocksource *cs;
T
Thomas Gleixner 已提交
476

477
	list_for_each_entry(cs, &clocksource_list, list)
T
Thomas Gleixner 已提交
478
		if (cs->resume)
479
			cs->resume(cs);
T
Thomas Gleixner 已提交
480 481 482 483

	clocksource_resume_watchdog();
}

J
Jason Wessel 已提交
484 485 486 487
/**
 * clocksource_touch_watchdog - Update watchdog
 *
 * Update the watchdog after exception contexts such as kgdb so as not
488 489
 * to incorrectly trip the watchdog. This might fail when the kernel
 * was stopped in code which holds watchdog_lock.
J
Jason Wessel 已提交
490 491 492 493 494 495
 */
void clocksource_touch_watchdog(void)
{
	clocksource_resume_watchdog();
}

496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536
/**
 * clocksource_max_deferment - Returns max time the clocksource can be deferred
 * @cs:         Pointer to clocksource
 *
 */
static u64 clocksource_max_deferment(struct clocksource *cs)
{
	u64 max_nsecs, max_cycles;

	/*
	 * Calculate the maximum number of cycles that we can pass to the
	 * cyc2ns function without overflowing a 64-bit signed result. The
	 * maximum number of cycles is equal to ULLONG_MAX/cs->mult which
	 * is equivalent to the below.
	 * max_cycles < (2^63)/cs->mult
	 * max_cycles < 2^(log2((2^63)/cs->mult))
	 * max_cycles < 2^(log2(2^63) - log2(cs->mult))
	 * max_cycles < 2^(63 - log2(cs->mult))
	 * max_cycles < 1 << (63 - log2(cs->mult))
	 * Please note that we add 1 to the result of the log2 to account for
	 * any rounding errors, ensure the above inequality is satisfied and
	 * no overflow will occur.
	 */
	max_cycles = 1ULL << (63 - (ilog2(cs->mult) + 1));

	/*
	 * The actual maximum number of cycles we can defer the clocksource is
	 * determined by the minimum of max_cycles and cs->mask.
	 */
	max_cycles = min_t(u64, max_cycles, (u64) cs->mask);
	max_nsecs = clocksource_cyc2ns(max_cycles, cs->mult, cs->shift);

	/*
	 * To ensure that the clocksource does not wrap whilst we are idle,
	 * limit the time the clocksource can be deferred by 12.5%. Please
	 * note a margin of 12.5% is used because this can be computed with
	 * a shift, versus say 10% which would require division.
	 */
	return max_nsecs - (max_nsecs >> 5);
}

J
John Stultz 已提交
537
#ifndef CONFIG_ARCH_USES_GETTIMEOFFSET
538 539

/**
540
 * clocksource_select - Select the best clocksource available
541
 *
542
 * Private function. Must hold clocksource_mutex when called.
543
 *
544 545
 * Select the clocksource with the best rating, or the clocksource,
 * which is selected by userspace override.
546
 */
547
static void clocksource_select(void)
548
{
549
	struct clocksource *best, *cs;
550

551
	if (!finished_booting || list_empty(&clocksource_list))
552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575
		return;
	/* First clocksource on the list has the best rating. */
	best = list_first_entry(&clocksource_list, struct clocksource, list);
	/* Check for the override clocksource. */
	list_for_each_entry(cs, &clocksource_list, list) {
		if (strcmp(cs->name, override_name) != 0)
			continue;
		/*
		 * Check to make sure we don't switch to a non-highres
		 * capable clocksource if the tick code is in oneshot
		 * mode (highres or nohz)
		 */
		if (!(cs->flags & CLOCK_SOURCE_VALID_FOR_HRES) &&
		    tick_oneshot_mode_active()) {
			/* Override clocksource cannot be used. */
			printk(KERN_WARNING "Override clocksource %s is not "
			       "HRT compatible. Cannot switch while in "
			       "HRT/NOHZ mode\n", cs->name);
			override_name[0] = 0;
		} else
			/* Override clocksource can be used. */
			best = cs;
		break;
	}
576 577 578 579 580
	if (curr_clocksource != best) {
		printk(KERN_INFO "Switching to clocksource %s\n", best->name);
		curr_clocksource = best;
		timekeeping_notify(curr_clocksource);
	}
581
}
582

J
John Stultz 已提交
583
#else /* !CONFIG_ARCH_USES_GETTIMEOFFSET */
584 585 586 587 588

static inline void clocksource_select(void) { }

#endif

589 590 591 592 593 594 595 596 597
/*
 * clocksource_done_booting - Called near the end of core bootup
 *
 * Hack to avoid lots of clocksource churn at boot time.
 * We use fs_initcall because we want this to start before
 * device_initcall but after subsys_initcall.
 */
static int __init clocksource_done_booting(void)
{
598 599 600 601
	mutex_lock(&clocksource_mutex);
	curr_clocksource = clocksource_default_clock();
	mutex_unlock(&clocksource_mutex);

602
	finished_booting = 1;
603 604 605 606 607 608

	/*
	 * Run the watchdog first to eliminate unstable clock sources
	 */
	clocksource_watchdog_kthread(NULL);

609
	mutex_lock(&clocksource_mutex);
610
	clocksource_select();
611
	mutex_unlock(&clocksource_mutex);
612 613 614 615
	return 0;
}
fs_initcall(clocksource_done_booting);

616 617
/*
 * Enqueue the clocksource sorted by rating
618
 */
619
static void clocksource_enqueue(struct clocksource *cs)
620
{
621 622
	struct list_head *entry = &clocksource_list;
	struct clocksource *tmp;
623

624
	list_for_each_entry(tmp, &clocksource_list, list)
625
		/* Keep track of the place, where to insert */
626 627 628
		if (tmp->rating >= cs->rating)
			entry = &tmp->list;
	list_add(&cs->list, entry);
629 630
}

631
/**
632
 * __clocksource_updatefreq_scale - Used update clocksource with new freq
633 634 635 636
 * @t:		clocksource to be registered
 * @scale:	Scale factor multiplied against freq to get clocksource hz
 * @freq:	clocksource frequency (cycles per second) divided by scale
 *
637
 * This should only be called from the clocksource->enable() method.
638 639
 *
 * This *SHOULD NOT* be called directly! Please use the
640
 * clocksource_updatefreq_hz() or clocksource_updatefreq_khz helper functions.
641
 */
642
void __clocksource_updatefreq_scale(struct clocksource *cs, u32 scale, u32 freq)
643
{
644
	u64 sec;
645

646
	/*
647 648 649 650 651 652 653 654
	 * Calc the maximum number of seconds which we can run before
	 * wrapping around. For clocksources which have a mask > 32bit
	 * we need to limit the max sleep time to have a good
	 * conversion precision. 10 minutes is still a reasonable
	 * amount. That results in a shift value of 24 for a
	 * clocksource with mask >= 40bit and f >= 4GHz. That maps to
	 * ~ 0.06ppm granularity for NTP. We apply the same 12.5%
	 * margin as we do in clocksource_max_deferment()
655
	 */
656 657 658 659 660 661 662 663
	sec = (cs->mask - (cs->mask >> 5));
	do_div(sec, freq);
	do_div(sec, scale);
	if (!sec)
		sec = 1;
	else if (sec > 600 && cs->mask > UINT_MAX)
		sec = 600;

664
	clocks_calc_mult_shift(&cs->mult, &cs->shift, freq,
665
			       NSEC_PER_SEC / scale, sec * scale);
666
	cs->max_idle_ns = clocksource_max_deferment(cs);
667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683
}
EXPORT_SYMBOL_GPL(__clocksource_updatefreq_scale);

/**
 * __clocksource_register_scale - Used to install new clocksources
 * @t:		clocksource to be registered
 * @scale:	Scale factor multiplied against freq to get clocksource hz
 * @freq:	clocksource frequency (cycles per second) divided by scale
 *
 * Returns -EBUSY if registration fails, zero otherwise.
 *
 * This *SHOULD NOT* be called directly! Please use the
 * clocksource_register_hz() or clocksource_register_khz helper functions.
 */
int __clocksource_register_scale(struct clocksource *cs, u32 scale, u32 freq)
{

684
	/* Initialize mult/shift and max_idle_ns */
685
	__clocksource_updatefreq_scale(cs, scale, freq);
686

687
	/* Add clocksource to the clcoksource list */
688 689 690
	mutex_lock(&clocksource_mutex);
	clocksource_enqueue(cs);
	clocksource_enqueue_watchdog(cs);
691
	clocksource_select();
692 693 694 695 696 697
	mutex_unlock(&clocksource_mutex);
	return 0;
}
EXPORT_SYMBOL_GPL(__clocksource_register_scale);


698
/**
699
 * clocksource_register - Used to install new clocksources
700 701 702 703
 * @t:		clocksource to be registered
 *
 * Returns -EBUSY if registration fails, zero otherwise.
 */
704
int clocksource_register(struct clocksource *cs)
705
{
706 707 708
	/* calculate max idle time permitted for this clocksource */
	cs->max_idle_ns = clocksource_max_deferment(cs);

709
	mutex_lock(&clocksource_mutex);
710
	clocksource_enqueue(cs);
711
	clocksource_enqueue_watchdog(cs);
712
	clocksource_select();
713
	mutex_unlock(&clocksource_mutex);
714
	return 0;
715
}
716
EXPORT_SYMBOL(clocksource_register);
717

718 719 720 721 722 723 724 725
static void __clocksource_change_rating(struct clocksource *cs, int rating)
{
	list_del(&cs->list);
	cs->rating = rating;
	clocksource_enqueue(cs);
	clocksource_select();
}

726
/**
727
 * clocksource_change_rating - Change the rating of a registered clocksource
728
 */
729
void clocksource_change_rating(struct clocksource *cs, int rating)
730
{
731
	mutex_lock(&clocksource_mutex);
732
	__clocksource_change_rating(cs, rating);
733
	mutex_unlock(&clocksource_mutex);
734
}
735
EXPORT_SYMBOL(clocksource_change_rating);
736

737 738 739 740 741
/**
 * clocksource_unregister - remove a registered clocksource
 */
void clocksource_unregister(struct clocksource *cs)
{
742
	mutex_lock(&clocksource_mutex);
743
	clocksource_dequeue_watchdog(cs);
744
	list_del(&cs->list);
745
	clocksource_select();
746
	mutex_unlock(&clocksource_mutex);
747
}
748
EXPORT_SYMBOL(clocksource_unregister);
749

750
#ifdef CONFIG_SYSFS
751 752 753 754 755 756 757 758
/**
 * sysfs_show_current_clocksources - sysfs interface for current clocksource
 * @dev:	unused
 * @buf:	char buffer to be filled with clocksource list
 *
 * Provides sysfs interface for listing current clocksource.
 */
static ssize_t
759 760
sysfs_show_current_clocksources(struct sys_device *dev,
				struct sysdev_attribute *attr, char *buf)
761
{
762
	ssize_t count = 0;
763

764
	mutex_lock(&clocksource_mutex);
765
	count = snprintf(buf, PAGE_SIZE, "%s\n", curr_clocksource->name);
766
	mutex_unlock(&clocksource_mutex);
767

768
	return count;
769 770 771 772 773 774 775 776 777
}

/**
 * sysfs_override_clocksource - interface for manually overriding clocksource
 * @dev:	unused
 * @buf:	name of override clocksource
 * @count:	length of buffer
 *
 * Takes input from sysfs interface for manually overriding the default
778
 * clocksource selection.
779 780
 */
static ssize_t sysfs_override_clocksource(struct sys_device *dev,
781
					  struct sysdev_attribute *attr,
782 783 784
					  const char *buf, size_t count)
{
	size_t ret = count;
785

786 787 788 789 790 791 792 793
	/* strings from sysfs write are not 0 terminated! */
	if (count >= sizeof(override_name))
		return -EINVAL;

	/* strip of \n: */
	if (buf[count-1] == '\n')
		count--;

794
	mutex_lock(&clocksource_mutex);
795

796 797
	if (count > 0)
		memcpy(override_name, buf, count);
798
	override_name[count] = 0;
799
	clocksource_select();
800

801
	mutex_unlock(&clocksource_mutex);
802 803 804 805 806 807 808 809 810 811 812 813

	return ret;
}

/**
 * sysfs_show_available_clocksources - sysfs interface for listing clocksource
 * @dev:	unused
 * @buf:	char buffer to be filled with clocksource list
 *
 * Provides sysfs interface for listing registered clocksources
 */
static ssize_t
814 815 816
sysfs_show_available_clocksources(struct sys_device *dev,
				  struct sysdev_attribute *attr,
				  char *buf)
817
{
818
	struct clocksource *src;
819
	ssize_t count = 0;
820

821
	mutex_lock(&clocksource_mutex);
822
	list_for_each_entry(src, &clocksource_list, list) {
823 824 825 826 827 828
		/*
		 * Don't show non-HRES clocksource if the tick code is
		 * in one shot mode (highres=on or nohz=on)
		 */
		if (!tick_oneshot_mode_active() ||
		    (src->flags & CLOCK_SOURCE_VALID_FOR_HRES))
829
			count += snprintf(buf + count,
830 831
				  max((ssize_t)PAGE_SIZE - count, (ssize_t)0),
				  "%s ", src->name);
832
	}
833
	mutex_unlock(&clocksource_mutex);
834

835 836
	count += snprintf(buf + count,
			  max((ssize_t)PAGE_SIZE - count, (ssize_t)0), "\n");
837

838
	return count;
839 840 841 842 843
}

/*
 * Sysfs setup bits:
 */
844
static SYSDEV_ATTR(current_clocksource, 0644, sysfs_show_current_clocksources,
D
Daniel Walker 已提交
845
		   sysfs_override_clocksource);
846

847
static SYSDEV_ATTR(available_clocksource, 0444,
D
Daniel Walker 已提交
848
		   sysfs_show_available_clocksources, NULL);
849 850

static struct sysdev_class clocksource_sysclass = {
851
	.name = "clocksource",
852 853 854 855 856 857 858
};

static struct sys_device device_clocksource = {
	.id	= 0,
	.cls	= &clocksource_sysclass,
};

859
static int __init init_clocksource_sysfs(void)
860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876
{
	int error = sysdev_class_register(&clocksource_sysclass);

	if (!error)
		error = sysdev_register(&device_clocksource);
	if (!error)
		error = sysdev_create_file(
				&device_clocksource,
				&attr_current_clocksource);
	if (!error)
		error = sysdev_create_file(
				&device_clocksource,
				&attr_available_clocksource);
	return error;
}

device_initcall(init_clocksource_sysfs);
877
#endif /* CONFIG_SYSFS */
878 879 880 881 882 883 884 885 886 887

/**
 * boot_override_clocksource - boot clock override
 * @str:	override name
 *
 * Takes a clocksource= boot argument and uses it
 * as the clocksource override name.
 */
static int __init boot_override_clocksource(char* str)
{
888
	mutex_lock(&clocksource_mutex);
889 890
	if (str)
		strlcpy(override_name, str, sizeof(override_name));
891
	mutex_unlock(&clocksource_mutex);
892 893 894 895 896 897 898 899 900 901 902 903 904 905
	return 1;
}

__setup("clocksource=", boot_override_clocksource);

/**
 * boot_override_clock - Compatibility layer for deprecated boot option
 * @str:	override name
 *
 * DEPRECATED! Takes a clock= boot argument and uses it
 * as the clocksource override name
 */
static int __init boot_override_clock(char* str)
{
906 907 908 909 910 911 912
	if (!strcmp(str, "pmtmr")) {
		printk("Warning: clock=pmtmr is deprecated. "
			"Use clocksource=acpi_pm.\n");
		return boot_override_clocksource("acpi_pm");
	}
	printk("Warning! clock= boot option is deprecated. "
		"Use clocksource=xyz\n");
913 914 915 916
	return boot_override_clocksource(str);
}

__setup("clock=", boot_override_clock);