Commit 09adad17 authored by Baolin Wang's avatar Baolin Wang Committed by James Hogan

MIPS: Convert read_persistent_clock() to read_persistent_clock64()

Since struct timespec is not y2038 safe on 32bit machines, this patch
converts read_persistent_clock() to read_persistent_clock64() using
struct timespec64, as well as converting mktime() to mktime64().
Signed-off-by: default avatarBaolin Wang <baolin.wang@linaro.org>
Acked-by: default avatarArnd Bergmann <arnd@arndb.de>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Huacai Chen <chenhc@lemote.com>
Cc: Paul Burton <paul.burton@mips.com>
Cc: linux-mips@linux-mips.org
Signed-off-by: default avatarJames Hogan <jhogan@kernel.org>
parent d7c72c57
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
#include <asm/dec/ioasic.h> #include <asm/dec/ioasic.h>
#include <asm/dec/machtype.h> #include <asm/dec/machtype.h>
void read_persistent_clock(struct timespec *ts) void read_persistent_clock64(struct timespec64 *ts)
{ {
unsigned int year, mon, day, hour, min, sec, real_year; unsigned int year, mon, day, hour, min, sec, real_year;
unsigned long flags; unsigned long flags;
...@@ -54,7 +54,7 @@ void read_persistent_clock(struct timespec *ts) ...@@ -54,7 +54,7 @@ void read_persistent_clock(struct timespec *ts)
year += real_year - 72 + 2000; year += real_year - 72 + 2000;
ts->tv_sec = mktime(year, mon, day, hour, min, sec); ts->tv_sec = mktime64(year, mon, day, hour, min, sec);
ts->tv_nsec = 0; ts->tv_nsec = 0;
} }
......
...@@ -86,7 +86,7 @@ static inline int mc146818_set_rtc_mmss(unsigned long nowtime) ...@@ -86,7 +86,7 @@ static inline int mc146818_set_rtc_mmss(unsigned long nowtime)
return retval; return retval;
} }
static inline unsigned long mc146818_get_cmos_time(void) static inline time64_t mc146818_get_cmos_time(void)
{ {
unsigned int year, mon, day, hour, min, sec; unsigned int year, mon, day, hour, min, sec;
unsigned long flags; unsigned long flags;
...@@ -113,7 +113,7 @@ static inline unsigned long mc146818_get_cmos_time(void) ...@@ -113,7 +113,7 @@ static inline unsigned long mc146818_get_cmos_time(void)
spin_unlock_irqrestore(&rtc_lock, flags); spin_unlock_irqrestore(&rtc_lock, flags);
year = mc146818_decode_year(year); year = mc146818_decode_year(year);
return mktime(year, mon, day, hour, min, sec); return mktime64(year, mon, day, hour, min, sec);
} }
#endif /* __ASM_MC146818_TIME_H */ #endif /* __ASM_MC146818_TIME_H */
...@@ -136,7 +136,7 @@ static void rtc_end_op(void) ...@@ -136,7 +136,7 @@ static void rtc_end_op(void)
lasat_ndelay(1000); lasat_ndelay(1000);
} }
void read_persistent_clock(struct timespec *ts) void read_persistent_clock64(struct timespec64 *ts)
{ {
unsigned long word; unsigned long word;
unsigned long flags; unsigned long flags;
......
...@@ -29,7 +29,7 @@ void __init plat_time_init(void) ...@@ -29,7 +29,7 @@ void __init plat_time_init(void)
#endif #endif
} }
void read_persistent_clock(struct timespec *ts) void read_persistent_clock64(struct timespec64 *ts)
{ {
ts->tv_sec = mc146818_get_cmos_time(); ts->tv_sec = mc146818_get_cmos_time();
ts->tv_nsec = 0; ts->tv_nsec = 0;
......
...@@ -134,7 +134,7 @@ static void __init estimate_frequencies(void) ...@@ -134,7 +134,7 @@ static void __init estimate_frequencies(void)
} }
} }
void read_persistent_clock(struct timespec *ts) void read_persistent_clock64(struct timespec64 *ts)
{ {
ts->tv_sec = mc146818_get_cmos_time(); ts->tv_sec = mc146818_get_cmos_time();
ts->tv_nsec = 0; ts->tv_nsec = 0;
......
...@@ -188,7 +188,7 @@ int m41t81_set_time(unsigned long t) ...@@ -188,7 +188,7 @@ int m41t81_set_time(unsigned long t)
return 0; return 0;
} }
unsigned long m41t81_get_time(void) time64_t m41t81_get_time(void)
{ {
unsigned int year, mon, day, hour, min, sec; unsigned int year, mon, day, hour, min, sec;
unsigned long flags; unsigned long flags;
...@@ -218,7 +218,7 @@ unsigned long m41t81_get_time(void) ...@@ -218,7 +218,7 @@ unsigned long m41t81_get_time(void)
year += 2000; year += 2000;
return mktime(year, mon, day, hour, min, sec); return mktime64(year, mon, day, hour, min, sec);
} }
int m41t81_probe(void) int m41t81_probe(void)
......
...@@ -168,7 +168,7 @@ int xicor_set_time(unsigned long t) ...@@ -168,7 +168,7 @@ int xicor_set_time(unsigned long t)
return 0; return 0;
} }
unsigned long xicor_get_time(void) time64_t xicor_get_time(void)
{ {
unsigned int year, mon, day, hour, min, sec, y2k; unsigned int year, mon, day, hour, min, sec, y2k;
unsigned long flags; unsigned long flags;
...@@ -201,7 +201,7 @@ unsigned long xicor_get_time(void) ...@@ -201,7 +201,7 @@ unsigned long xicor_get_time(void)
year += (y2k * 100); year += (y2k * 100);
return mktime(year, mon, day, hour, min, sec); return mktime64(year, mon, day, hour, min, sec);
} }
int xicor_probe(void) int xicor_probe(void)
......
...@@ -58,11 +58,11 @@ extern void sb1250_setup(void); ...@@ -58,11 +58,11 @@ extern void sb1250_setup(void);
extern int xicor_probe(void); extern int xicor_probe(void);
extern int xicor_set_time(unsigned long); extern int xicor_set_time(unsigned long);
extern unsigned long xicor_get_time(void); extern time64_t xicor_get_time(void);
extern int m41t81_probe(void); extern int m41t81_probe(void);
extern int m41t81_set_time(unsigned long); extern int m41t81_set_time(unsigned long);
extern unsigned long m41t81_get_time(void); extern time64_t m41t81_get_time(void);
const char *get_system_type(void) const char *get_system_type(void)
{ {
...@@ -87,9 +87,9 @@ enum swarm_rtc_type { ...@@ -87,9 +87,9 @@ enum swarm_rtc_type {
enum swarm_rtc_type swarm_rtc_type; enum swarm_rtc_type swarm_rtc_type;
void read_persistent_clock(struct timespec *ts) void read_persistent_clock64(struct timespec64 *ts)
{ {
unsigned long sec; time64_t sec;
switch (swarm_rtc_type) { switch (swarm_rtc_type) {
case RTC_XICOR: case RTC_XICOR:
...@@ -102,7 +102,7 @@ void read_persistent_clock(struct timespec *ts) ...@@ -102,7 +102,7 @@ void read_persistent_clock(struct timespec *ts)
case RTC_NONE: case RTC_NONE:
default: default:
sec = mktime(2000, 1, 1, 0, 0, 0); sec = mktime64(2000, 1, 1, 0, 0, 0);
break; break;
} }
ts->tv_sec = sec; ts->tv_sec = sec;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment