You've already forked linux-apfs
mirror of
https://github.com/linux-apfs/linux-apfs.git
synced 2026-05-01 15:00:59 -07:00
3c00a1fe84
As part of addressing in-kernel y2038 issues, this patch adds update_persistent_clock64() and replaces all the call sites of update_persistent_clock() with this function. This is a __weak implementation, which simply calls the existing y2038 unsafe update_persistent_clock(). This allows architecture specific implementations to be converted independently, and eventually y2038-unsafe update_persistent_clock() can be removed after all its architecture specific implementations have been converted to update_persistent_clock64(). Suggested-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Xunlei Pang <pang.xunlei@linaro.org> Signed-off-by: John Stultz <john.stultz@linaro.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Link: http://lkml.kernel.org/r/1427945681-29972-4-git-send-email-john.stultz@linaro.org Signed-off-by: Ingo Molnar <mingo@kernel.org>
45 lines
1.2 KiB
C
45 lines
1.2 KiB
C
/*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License version 2 as published by
|
|
* the Free Software Foundation.
|
|
*
|
|
*/
|
|
#include <linux/rtc.h>
|
|
#include <linux/time.h>
|
|
|
|
/**
|
|
* rtc_set_ntp_time - Save NTP synchronized time to the RTC
|
|
* @now: Current time of day
|
|
*
|
|
* Replacement for the NTP platform function update_persistent_clock64
|
|
* that stores time for later retrieval by rtc_hctosys.
|
|
*
|
|
* Returns 0 on successful RTC update, -ENODEV if a RTC update is not
|
|
* possible at all, and various other -errno for specific temporary failure
|
|
* cases.
|
|
*
|
|
* If temporary failure is indicated the caller should try again 'soon'
|
|
*/
|
|
int rtc_set_ntp_time(struct timespec64 now)
|
|
{
|
|
struct rtc_device *rtc;
|
|
struct rtc_time tm;
|
|
int err = -ENODEV;
|
|
|
|
if (now.tv_nsec < (NSEC_PER_SEC >> 1))
|
|
rtc_time64_to_tm(now.tv_sec, &tm);
|
|
else
|
|
rtc_time64_to_tm(now.tv_sec + 1, &tm);
|
|
|
|
rtc = rtc_class_open(CONFIG_RTC_HCTOSYS_DEVICE);
|
|
if (rtc) {
|
|
/* rtc_hctosys exclusively uses UTC, so we call set_time here,
|
|
* not set_mmss. */
|
|
if (rtc->ops && (rtc->ops->set_time || rtc->ops->set_mmss))
|
|
err = rtc_set_time(rtc, &tm);
|
|
rtc_class_close(rtc);
|
|
}
|
|
|
|
return err;
|
|
}
|