Merge branch 'for-rmk/arch-timer-cleanups' of git://linux-arm.org/linux-mr into devel-stable
Please pull these arch_timer cleanups I've been holding onto for a while. They're the same as my last posting [1], but have been rebased to v3.10-rc3. [1] http://lists.infradead.org/pipermail/linux-arm-kernel/2013-May/170602.html -- Mark Rutland
This commit is contained in:
commit
fd8957a96d
@ -80,15 +80,6 @@ static inline u32 arch_timer_get_cntfrq(void)
|
|||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline u64 arch_counter_get_cntpct(void)
|
|
||||||
{
|
|
||||||
u64 cval;
|
|
||||||
|
|
||||||
isb();
|
|
||||||
asm volatile("mrrc p15, 0, %Q0, %R0, c14" : "=r" (cval));
|
|
||||||
return cval;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u64 arch_counter_get_cntvct(void)
|
static inline u64 arch_counter_get_cntvct(void)
|
||||||
{
|
{
|
||||||
u64 cval;
|
u64 cval;
|
||||||
|
@ -153,6 +153,13 @@ THUMB( orr r7, #(1 << 30) ) @ HSCTLR.TE
|
|||||||
mrc p15, 4, r7, c14, c1, 0 @ CNTHCTL
|
mrc p15, 4, r7, c14, c1, 0 @ CNTHCTL
|
||||||
orr r7, r7, #3 @ PL1PCEN | PL1PCTEN
|
orr r7, r7, #3 @ PL1PCEN | PL1PCTEN
|
||||||
mcr p15, 4, r7, c14, c1, 0 @ CNTHCTL
|
mcr p15, 4, r7, c14, c1, 0 @ CNTHCTL
|
||||||
|
mov r7, #0
|
||||||
|
mcrr p15, 4, r7, r7, c14 @ CNTVOFF
|
||||||
|
|
||||||
|
@ Disable virtual timer in case it was counting
|
||||||
|
mrc p15, 0, r7, c14, c3, 1 @ CNTV_CTL
|
||||||
|
bic r7, #1 @ Clear ENABLE
|
||||||
|
mcr p15, 0, r7, c14, c3, 1 @ CNTV_CTL
|
||||||
1:
|
1:
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -497,6 +497,10 @@ vcpu .req r0 @ vcpu pointer always in r0
|
|||||||
add r5, vcpu, r4
|
add r5, vcpu, r4
|
||||||
strd r2, r3, [r5]
|
strd r2, r3, [r5]
|
||||||
|
|
||||||
|
@ Ensure host CNTVCT == CNTPCT
|
||||||
|
mov r2, #0
|
||||||
|
mcrr p15, 4, r2, r2, c14 @ CNTVOFF
|
||||||
|
|
||||||
1:
|
1:
|
||||||
#endif
|
#endif
|
||||||
@ Allow physical timer/counter access for the host
|
@ Allow physical timer/counter access for the host
|
||||||
|
@ -76,7 +76,7 @@ config SOC_EXYNOS5440
|
|||||||
default y
|
default y
|
||||||
depends on ARCH_EXYNOS5
|
depends on ARCH_EXYNOS5
|
||||||
select ARCH_HAS_OPP
|
select ARCH_HAS_OPP
|
||||||
select ARM_ARCH_TIMER
|
select HAVE_ARM_ARCH_TIMER
|
||||||
select AUTO_ZRELADDR
|
select AUTO_ZRELADDR
|
||||||
select PINCTRL
|
select PINCTRL
|
||||||
select PINCTRL_EXYNOS5440
|
select PINCTRL_EXYNOS5440
|
||||||
|
@ -23,7 +23,7 @@ config ARCH_R8A73A4
|
|||||||
select ARCH_WANT_OPTIONAL_GPIOLIB
|
select ARCH_WANT_OPTIONAL_GPIOLIB
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
select CPU_V7
|
select CPU_V7
|
||||||
select ARM_ARCH_TIMER
|
select HAVE_ARM_ARCH_TIMER
|
||||||
select SH_CLK_CPG
|
select SH_CLK_CPG
|
||||||
select RENESAS_IRQC
|
select RENESAS_IRQC
|
||||||
|
|
||||||
@ -56,7 +56,7 @@ config ARCH_R8A7790
|
|||||||
select ARCH_WANT_OPTIONAL_GPIOLIB
|
select ARCH_WANT_OPTIONAL_GPIOLIB
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
select CPU_V7
|
select CPU_V7
|
||||||
select ARM_ARCH_TIMER
|
select HAVE_ARM_ARCH_TIMER
|
||||||
select SH_CLK_CPG
|
select SH_CLK_CPG
|
||||||
select RENESAS_IRQC
|
select RENESAS_IRQC
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ config ARCH_TEGRA_3x_SOC
|
|||||||
|
|
||||||
config ARCH_TEGRA_114_SOC
|
config ARCH_TEGRA_114_SOC
|
||||||
bool "Enable support for Tegra114 family"
|
bool "Enable support for Tegra114 family"
|
||||||
select ARM_ARCH_TIMER
|
select HAVE_ARM_ARCH_TIMER
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
select ARM_L1_CACHE_SHIFT_6
|
select ARM_L1_CACHE_SHIFT_6
|
||||||
select CPU_FREQ_TABLE if CPU_FREQ
|
select CPU_FREQ_TABLE if CPU_FREQ
|
||||||
|
@ -2,7 +2,7 @@ config ARCH_VIRT
|
|||||||
bool "Dummy Virtual Machine" if ARCH_MULTI_V7
|
bool "Dummy Virtual Machine" if ARCH_MULTI_V7
|
||||||
select ARCH_WANT_OPTIONAL_GPIOLIB
|
select ARCH_WANT_OPTIONAL_GPIOLIB
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
select ARM_ARCH_TIMER
|
select HAVE_ARM_ARCH_TIMER
|
||||||
select ARM_PSCI
|
select ARM_PSCI
|
||||||
select HAVE_SMP
|
select HAVE_SMP
|
||||||
select CPU_V7
|
select CPU_V7
|
||||||
|
@ -110,16 +110,6 @@ static inline void __cpuinit arch_counter_set_user_access(void)
|
|||||||
asm volatile("msr cntkctl_el1, %0" : : "r" (cntkctl));
|
asm volatile("msr cntkctl_el1, %0" : : "r" (cntkctl));
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline u64 arch_counter_get_cntpct(void)
|
|
||||||
{
|
|
||||||
u64 cval;
|
|
||||||
|
|
||||||
isb();
|
|
||||||
asm volatile("mrs %0, cntpct_el0" : "=r" (cval));
|
|
||||||
|
|
||||||
return cval;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u64 arch_counter_get_cntvct(void)
|
static inline u64 arch_counter_get_cntvct(void)
|
||||||
{
|
{
|
||||||
u64 cval;
|
u64 cval;
|
||||||
|
@ -186,27 +186,19 @@ u32 arch_timer_get_rate(void)
|
|||||||
return arch_timer_rate;
|
return arch_timer_rate;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
u64 arch_timer_read_counter(void)
|
||||||
* Some external users of arch_timer_read_counter (e.g. sched_clock) may try to
|
|
||||||
* call it before it has been initialised. Rather than incur a performance
|
|
||||||
* penalty checking for initialisation, provide a default implementation that
|
|
||||||
* won't lead to time appearing to jump backwards.
|
|
||||||
*/
|
|
||||||
static u64 arch_timer_read_zero(void)
|
|
||||||
{
|
{
|
||||||
return 0;
|
return arch_counter_get_cntvct();
|
||||||
}
|
}
|
||||||
|
|
||||||
u64 (*arch_timer_read_counter)(void) = arch_timer_read_zero;
|
|
||||||
|
|
||||||
static cycle_t arch_counter_read(struct clocksource *cs)
|
static cycle_t arch_counter_read(struct clocksource *cs)
|
||||||
{
|
{
|
||||||
return arch_timer_read_counter();
|
return arch_counter_get_cntvct();
|
||||||
}
|
}
|
||||||
|
|
||||||
static cycle_t arch_counter_read_cc(const struct cyclecounter *cc)
|
static cycle_t arch_counter_read_cc(const struct cyclecounter *cc)
|
||||||
{
|
{
|
||||||
return arch_timer_read_counter();
|
return arch_counter_get_cntvct();
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct clocksource clocksource_counter = {
|
static struct clocksource clocksource_counter = {
|
||||||
@ -287,7 +279,7 @@ static int __init arch_timer_register(void)
|
|||||||
cyclecounter.mult = clocksource_counter.mult;
|
cyclecounter.mult = clocksource_counter.mult;
|
||||||
cyclecounter.shift = clocksource_counter.shift;
|
cyclecounter.shift = clocksource_counter.shift;
|
||||||
timecounter_init(&timecounter, &cyclecounter,
|
timecounter_init(&timecounter, &cyclecounter,
|
||||||
arch_counter_get_cntpct());
|
arch_counter_get_cntvct());
|
||||||
|
|
||||||
if (arch_timer_use_virtual) {
|
if (arch_timer_use_virtual) {
|
||||||
ppi = arch_timer_ppi[VIRT_PPI];
|
ppi = arch_timer_ppi[VIRT_PPI];
|
||||||
@ -376,11 +368,6 @@ static void __init arch_timer_init(struct device_node *np)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (arch_timer_use_virtual)
|
|
||||||
arch_timer_read_counter = arch_counter_get_cntvct;
|
|
||||||
else
|
|
||||||
arch_timer_read_counter = arch_counter_get_cntpct;
|
|
||||||
|
|
||||||
arch_timer_register();
|
arch_timer_register();
|
||||||
arch_timer_arch_init();
|
arch_timer_arch_init();
|
||||||
}
|
}
|
||||||
|
@ -32,7 +32,7 @@
|
|||||||
#ifdef CONFIG_ARM_ARCH_TIMER
|
#ifdef CONFIG_ARM_ARCH_TIMER
|
||||||
|
|
||||||
extern u32 arch_timer_get_rate(void);
|
extern u32 arch_timer_get_rate(void);
|
||||||
extern u64 (*arch_timer_read_counter)(void);
|
extern u64 arch_timer_read_counter(void);
|
||||||
extern struct timecounter *arch_timer_get_timecounter(void);
|
extern struct timecounter *arch_timer_get_timecounter(void);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
Loading…
Reference in New Issue
Block a user