diff options
author | Bitan Biswas <bbiswas@nvidia.com> | 2014-05-23 00:14:47 +0530 |
---|---|---|
committer | Riham Haidar <rhaidar@nvidia.com> | 2014-05-27 14:23:03 -0700 |
commit | e1470d63d7f3faa76bc85e8c55822e5835f8f9a7 (patch) | |
tree | baf563e9563efef973ef394fe7857b7cebc60f0d /kernel | |
parent | 37b02dab58ad9bd04ba4e898929333f72aa9ed4d (diff) |
time: tegra: post-lp0 sync system to rtc time
Ensure system time is read from rtc i.e. PMIC RTC
in case of tegra after system resume.
- Change is applicable to all PMIC RTC drivers.
bug 1510843
Reviewed-on: http://git-master/r/413365/
Reviewed-on: http://git-master/r/414163/
Reviewed-on: http://git-master/r/414169/
Reviewed-on: http://git-master/r/414200/
Reviewed-on: http://git-master/r/414201/
Change-Id: I8194f9f4be581216d662e6a6e0d7e98a9495159c
Signed-off-by: Bitan Biswas <bbiswas@nvidia.com>
Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com>
Reviewed-on: http://git-master/r/414203
GVS: Gerrit_Virtual_Submit
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/time/alarmtimer.c | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/kernel/time/alarmtimer.c b/kernel/time/alarmtimer.c index 0f69cecc93cd..62da1374fef6 100644 --- a/kernel/time/alarmtimer.c +++ b/kernel/time/alarmtimer.c @@ -268,11 +268,37 @@ static int alarmtimer_suspend(struct device *dev) } return ret; } + +static void sync_to_rtc_time(struct device *dev) +{ + struct timespec ts_old; + struct rtc_time tm; + + /* log old system time */ + getnstimeofday(&ts_old); + rtc_time_to_tm(ts_old.tv_sec, &tm); + pr_info("alarmtimer: old system time %d-%02d-%02d %02d:%02d:%02d.%09lu UTC\n", + tm.tm_year + 1900, tm.tm_mon + 1, tm.tm_mday, + tm.tm_hour, tm.tm_min, tm.tm_sec, ts_old.tv_nsec); + +#ifdef CONFIG_RTC_HCTOSYS + rtc_hctosys(); +#else + pr_info("%s %s line=%d, missing function to sync system time to rtc time\n", + __FILE__, __func__, __LINE__); +#endif + return; +} #else static int alarmtimer_suspend(struct device *dev) { return 0; } + +static void sync_to_rtc_time(struct device *dev) +{ + return 0; +} #endif static void alarmtimer_freezerset(ktime_t absexp, enum alarmtimer_type type) @@ -765,6 +791,7 @@ out: /* Suspend hook structures */ static const struct dev_pm_ops alarmtimer_pm_ops = { .suspend = alarmtimer_suspend, + .complete = sync_to_rtc_time, }; static struct platform_driver alarmtimer_driver = { |