diff options
author | Xunlei Pang <pang.xunlei@linaro.org> | 2015-04-01 23:34:26 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2015-04-03 02:18:23 -0400 |
commit | cb850717b076d979058d52529e15f1736359d811 (patch) | |
tree | a2780af9ecf4a770aacf4c72b3efa268536c02a3 | |
parent | a0c2998f918e7e597d3c686c5f3d5a30d0382dd6 (diff) |
ARM, clocksource/drivers: Provide read_boot_clock64() and read_persistent_clock64() and use them
As part of addressing "y2038 problem" for in-kernel uses, this
patch converts read_boot_clock() to read_boot_clock64() and
read_persistent_clock() to read_persistent_clock64() using
timespec64 by converting clock_access_fn to use timespec64.
Signed-off-by: Xunlei Pang <pang.xunlei@linaro.org>
Signed-off-by: John Stultz <john.stultz@linaro.org>
Acked-by: Thierry Reding <treding@nvidia.com> (for tegra part)
Cc: Russell King <rmk@dyn-67.arm.linux.org.uk>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/1427945681-29972-7-git-send-email-john.stultz@linaro.org
Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r-- | arch/arm/include/asm/mach/time.h | 3 | ||||
-rw-r--r-- | arch/arm/kernel/time.c | 6 | ||||
-rw-r--r-- | arch/arm/plat-omap/counter_32k.c | 10 | ||||
-rw-r--r-- | drivers/clocksource/tegra20_timer.c | 10 |
4 files changed, 6 insertions, 23 deletions
diff --git a/arch/arm/include/asm/mach/time.h b/arch/arm/include/asm/mach/time.h index 90c12e1e695c..0f79e4dec7f9 100644 --- a/arch/arm/include/asm/mach/time.h +++ b/arch/arm/include/asm/mach/time.h | |||
@@ -12,8 +12,7 @@ | |||
12 | 12 | ||
13 | extern void timer_tick(void); | 13 | extern void timer_tick(void); |
14 | 14 | ||
15 | struct timespec; | 15 | typedef void (*clock_access_fn)(struct timespec64 *); |
16 | typedef void (*clock_access_fn)(struct timespec *); | ||
17 | extern int register_persistent_clock(clock_access_fn read_boot, | 16 | extern int register_persistent_clock(clock_access_fn read_boot, |
18 | clock_access_fn read_persistent); | 17 | clock_access_fn read_persistent); |
19 | 18 | ||
diff --git a/arch/arm/kernel/time.c b/arch/arm/kernel/time.c index 0cc7e58c47cc..a66e37e211a9 100644 --- a/arch/arm/kernel/time.c +++ b/arch/arm/kernel/time.c | |||
@@ -76,7 +76,7 @@ void timer_tick(void) | |||
76 | } | 76 | } |
77 | #endif | 77 | #endif |
78 | 78 | ||
79 | static void dummy_clock_access(struct timespec *ts) | 79 | static void dummy_clock_access(struct timespec64 *ts) |
80 | { | 80 | { |
81 | ts->tv_sec = 0; | 81 | ts->tv_sec = 0; |
82 | ts->tv_nsec = 0; | 82 | ts->tv_nsec = 0; |
@@ -85,12 +85,12 @@ static void dummy_clock_access(struct timespec *ts) | |||
85 | static clock_access_fn __read_persistent_clock = dummy_clock_access; | 85 | static clock_access_fn __read_persistent_clock = dummy_clock_access; |
86 | static clock_access_fn __read_boot_clock = dummy_clock_access;; | 86 | static clock_access_fn __read_boot_clock = dummy_clock_access;; |
87 | 87 | ||
88 | void read_persistent_clock(struct timespec *ts) | 88 | void read_persistent_clock64(struct timespec64 *ts) |
89 | { | 89 | { |
90 | __read_persistent_clock(ts); | 90 | __read_persistent_clock(ts); |
91 | } | 91 | } |
92 | 92 | ||
93 | void read_boot_clock(struct timespec *ts) | 93 | void read_boot_clock64(struct timespec64 *ts) |
94 | { | 94 | { |
95 | __read_boot_clock(ts); | 95 | __read_boot_clock(ts); |
96 | } | 96 | } |
diff --git a/arch/arm/plat-omap/counter_32k.c b/arch/arm/plat-omap/counter_32k.c index b7b7b0793228..2438b96004c1 100644 --- a/arch/arm/plat-omap/counter_32k.c +++ b/arch/arm/plat-omap/counter_32k.c | |||
@@ -70,14 +70,6 @@ static void omap_read_persistent_clock64(struct timespec64 *ts) | |||
70 | *ts = persistent_ts; | 70 | *ts = persistent_ts; |
71 | } | 71 | } |
72 | 72 | ||
73 | static void omap_read_persistent_clock(struct timespec *ts) | ||
74 | { | ||
75 | struct timespec64 ts64; | ||
76 | |||
77 | omap_read_persistent_clock64(&ts64); | ||
78 | *ts = timespec64_to_timespec(ts64); | ||
79 | } | ||
80 | |||
81 | /** | 73 | /** |
82 | * omap_init_clocksource_32k - setup and register counter 32k as a | 74 | * omap_init_clocksource_32k - setup and register counter 32k as a |
83 | * kernel clocksource | 75 | * kernel clocksource |
@@ -118,7 +110,7 @@ int __init omap_init_clocksource_32k(void __iomem *vbase) | |||
118 | } | 110 | } |
119 | 111 | ||
120 | sched_clock_register(omap_32k_read_sched_clock, 32, 32768); | 112 | sched_clock_register(omap_32k_read_sched_clock, 32, 32768); |
121 | register_persistent_clock(NULL, omap_read_persistent_clock); | 113 | register_persistent_clock(NULL, omap_read_persistent_clock64); |
122 | pr_info("OMAP clocksource: 32k_counter at 32768 Hz\n"); | 114 | pr_info("OMAP clocksource: 32k_counter at 32768 Hz\n"); |
123 | 115 | ||
124 | return 0; | 116 | return 0; |
diff --git a/drivers/clocksource/tegra20_timer.c b/drivers/clocksource/tegra20_timer.c index 4a0a603edecc..5a112d72fc2d 100644 --- a/drivers/clocksource/tegra20_timer.c +++ b/drivers/clocksource/tegra20_timer.c | |||
@@ -141,14 +141,6 @@ static void tegra_read_persistent_clock64(struct timespec64 *ts) | |||
141 | *ts = persistent_ts; | 141 | *ts = persistent_ts; |
142 | } | 142 | } |
143 | 143 | ||
144 | static void tegra_read_persistent_clock(struct timespec *ts) | ||
145 | { | ||
146 | struct timespec ts64; | ||
147 | |||
148 | tegra_read_persistent_clock64(&ts64); | ||
149 | *ts = timespec64_to_timespec(ts64); | ||
150 | } | ||
151 | |||
152 | static unsigned long tegra_delay_timer_read_counter_long(void) | 144 | static unsigned long tegra_delay_timer_read_counter_long(void) |
153 | { | 145 | { |
154 | return readl(timer_reg_base + TIMERUS_CNTR_1US); | 146 | return readl(timer_reg_base + TIMERUS_CNTR_1US); |
@@ -259,7 +251,7 @@ static void __init tegra20_init_rtc(struct device_node *np) | |||
259 | else | 251 | else |
260 | clk_prepare_enable(clk); | 252 | clk_prepare_enable(clk); |
261 | 253 | ||
262 | register_persistent_clock(NULL, tegra_read_persistent_clock); | 254 | register_persistent_clock(NULL, tegra_read_persistent_clock64); |
263 | } | 255 | } |
264 | CLOCKSOURCE_OF_DECLARE(tegra20_rtc, "nvidia,tegra20-rtc", tegra20_init_rtc); | 256 | CLOCKSOURCE_OF_DECLARE(tegra20_rtc, "nvidia,tegra20-rtc", tegra20_init_rtc); |
265 | 257 | ||