diff options
| author | Arnd Bergmann <arnd@arndb.de> | 2013-05-06 23:43:45 +0200 | 
|---|---|---|
| committer | Arnd Bergmann <arnd@arndb.de> | 2013-05-06 23:43:45 +0200 | 
| commit | 442a33ebce9e02a2dd6662f16c9f2aad834d0115 (patch) | |
| tree | ca8654a286f61da917318645cab9e061095ecdba /arch/arm/kernel/arch_timer.c | |
| parent | a94d236dc355f374857ee4e6e78b7dec8a0f29e3 (diff) | |
| parent | f31c2f1c68aff83277eddc6798adf3438e9c680a (diff) | |
| download | olio-linux-3.10-442a33ebce9e02a2dd6662f16c9f2aad834d0115.tar.xz olio-linux-3.10-442a33ebce9e02a2dd6662f16c9f2aad834d0115.zip  | |
Merge branch 'late/clksrc' into late/cleanup
There is no reason to keep the clksrc cleanups separate from the
other cleanups, and this resolves some merge conflicts.
Conflicts:
	arch/arm/mach-spear/spear13xx.c
	drivers/irqchip/Makefile
Diffstat (limited to 'arch/arm/kernel/arch_timer.c')
| -rw-r--r-- | arch/arm/kernel/arch_timer.c | 29 | 
1 files changed, 13 insertions, 16 deletions
diff --git a/arch/arm/kernel/arch_timer.c b/arch/arm/kernel/arch_timer.c index d957a51435d..59dcdced6e3 100644 --- a/arch/arm/kernel/arch_timer.c +++ b/arch/arm/kernel/arch_timer.c @@ -22,9 +22,11 @@ static unsigned long arch_timer_read_counter_long(void)  	return arch_timer_read_counter();  } -static u32 arch_timer_read_counter_u32(void) +static u32 sched_clock_mult __read_mostly; + +static unsigned long long notrace arch_timer_sched_clock(void)  { -	return arch_timer_read_counter(); +	return arch_timer_read_counter() * sched_clock_mult;  }  static struct delay_timer arch_delay_timer; @@ -37,25 +39,20 @@ static void __init arch_timer_delay_timer_register(void)  	register_current_timer_delay(&arch_delay_timer);  } -int __init arch_timer_of_register(void) +int __init arch_timer_arch_init(void)  { -	int ret; +        u32 arch_timer_rate = arch_timer_get_rate(); -	ret = arch_timer_init(); -	if (ret) -		return ret; +	if (arch_timer_rate == 0) +		return -ENXIO;  	arch_timer_delay_timer_register(); -	return 0; -} - -int __init arch_timer_sched_clock_init(void) -{ -	if (arch_timer_get_rate() == 0) -		return -ENXIO; +	/* Cache the sched_clock multiplier to save a divide in the hot path. */ +	sched_clock_mult = NSEC_PER_SEC / arch_timer_rate; +	sched_clock_func = arch_timer_sched_clock; +	pr_info("sched_clock: ARM arch timer >56 bits at %ukHz, resolution %uns\n", +		arch_timer_rate / 1000, sched_clock_mult); -	setup_sched_clock(arch_timer_read_counter_u32, -			  32, arch_timer_get_rate());  	return 0;  }  |