Adds in-kernel hctosys functionality that can be used by ntp sync code. This is an RFC and has not been tested, I just want to check if something similar could solve the problems of those who want the NTP sync mode.
Signed-off-by: Alessandro Zummo <[EMAIL PROTECTED]> Cc: Paul Mundt <[EMAIL PROTECTED]> Cc: David Brownell <[EMAIL PROTECTED]> Cc: David Woodhouse <[EMAIL PROTECTED]> --- drivers/rtc/Kconfig | 19 ++++++++++++++++++- drivers/rtc/Makefile | 1 + drivers/rtc/systohc.c | 35 +++++++++++++++++++++++++++++++++++ 3 files changed, 54 insertions(+), 1 deletions(-) create mode 100644 drivers/rtc/systohc.c diff --git a/drivers/rtc/Kconfig b/drivers/rtc/Kconfig index 8abbb20..1ff9427 100644 --- a/drivers/rtc/Kconfig +++ b/drivers/rtc/Kconfig @@ -30,7 +30,7 @@ config RTC_HCTOSYS unnecessary fsck runs at boot time, and to network better. config RTC_HCTOSYS_DEVICE - string "RTC used to set the system time" + string "RTC used to set the system time on startup and resume" depends on RTC_HCTOSYS = y default "rtc0" help @@ -52,6 +52,23 @@ config RTC_HCTOSYS_DEVICE sleep states. Do not specify an RTC here unless it stays powered during all this system's supported sleep states. +config RTC_SYSTOHC + bool "Set RTC from system time in NTP sync mode" + depends on RTC_CLASS = y + default y + help + If you say yes here, the system time (wall clock) will be written + to the hardware clock every 11 minutes, if the kernel is in NTP + mode and your platforms supports it. + +config RTC_SYSTOHC_DEVICE + string "RTC used to save the system time in NTP sync mode" + depends on RTC_SYSTOHC = y + default "rtc0" + help + The RTC device that will get written with the system time + in NTP mode. + config RTC_DEBUG bool "RTC debug support" depends on RTC_CLASS = y diff --git a/drivers/rtc/Makefile b/drivers/rtc/Makefile index e9e8474..6d1c519 100644 --- a/drivers/rtc/Makefile +++ b/drivers/rtc/Makefile @@ -8,6 +8,7 @@ endif obj-$(CONFIG_RTC_LIB) += rtc-lib.o obj-$(CONFIG_RTC_HCTOSYS) += hctosys.o +obj-$(CONFIG_RTC_SYSTOHC) += systohc.o obj-$(CONFIG_RTC_CLASS) += rtc-core.o rtc-core-y := class.o interface.o diff --git a/drivers/rtc/systohc.c b/drivers/rtc/systohc.c new file mode 100644 index 0000000..41ec77b --- /dev/null +++ b/drivers/rtc/systohc.c @@ -0,0 +1,35 @@ +/* + * RTC subsystem, systohc for ntp use + * + * Copyright (C) 2008 Tower Technologies + * Author: Alessandro Zummo <[EMAIL PROTECTED]> + * + * 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> + +static int rtc_systohc(struct rtc_time *tm) +{ + int err; + struct rtc_time tm; + struct rtc_device *rtc = rtc_class_open(CONFIG_RTC_SYSTOHC_DEVICE); + + if (rtc == NULL) { + printk("%s: unable to open rtc device (%s)\n", + __FILE__, CONFIG_RTC_SYSTOHC_DEVICE); + return -ENODEV; + } + + err = rtc_set_time(rtc, tm); + if (err != 0) + dev_err(rtc->dev.parent, + "systohc: unable to set the hardware clock\n"); + + rtc_class_close(rtc); + + return err; +} +EXPORT_SYMBOL(rtc_systohc); _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev