diff options
author | Rob Herring <rob.herring@calxeda.com> | 2013-04-01 20:53:38 +0200 |
---|---|---|
committer | Rob Herring <rob.herring@calxeda.com> | 2013-04-11 01:27:12 +0200 |
commit | 7e48c0b9d9ab07c92cd26f167010cd5a50eb0cec (patch) | |
tree | 05e8d8f956f1b035105fc947cb5ec676a0ddece8 /arch/arm/kernel | |
parent | ARM: sched_clock: allow changing to higher frequency counter (diff) | |
download | linux-7e48c0b9d9ab07c92cd26f167010cd5a50eb0cec.tar.xz linux-7e48c0b9d9ab07c92cd26f167010cd5a50eb0cec.zip |
ARM: make sched_clock just call a function pointer
This converts sched_clock to simply a call to a function pointer in order
to allow overriding it. This will allow for use with 64-bit counters where
overflow handling is not needed.
Signed-off-by: Rob Herring <rob.herring@calxeda.com>
Diffstat (limited to 'arch/arm/kernel')
-rw-r--r-- | arch/arm/kernel/sched_clock.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/arch/arm/kernel/sched_clock.c b/arch/arm/kernel/sched_clock.c index 040168e8a60d..880584852fca 100644 --- a/arch/arm/kernel/sched_clock.c +++ b/arch/arm/kernel/sched_clock.c @@ -165,12 +165,19 @@ void __init setup_sched_clock(u32 (*read)(void), int bits, unsigned long rate) pr_debug("Registered %pF as sched_clock source\n", read); } -unsigned long long notrace sched_clock(void) +static unsigned long long notrace sched_clock_32(void) { u32 cyc = read_sched_clock(); return cyc_to_sched_clock(cyc, sched_clock_mask); } +unsigned long long __read_mostly (*sched_clock_func)(void) = sched_clock_32; + +unsigned long long notrace sched_clock(void) +{ + return sched_clock_func(); +} + void __init sched_clock_postinit(void) { /* |