diff options
Diffstat (limited to 'arch/sh/boards/mach-sh03/rtc.c')
| -rw-r--r-- | arch/sh/boards/mach-sh03/rtc.c | 51 | 
1 files changed, 31 insertions, 20 deletions
| diff --git a/arch/sh/boards/mach-sh03/rtc.c b/arch/sh/boards/mach-sh03/rtc.c index dc3d50e3b7a2..8b23ed7c201c 100644 --- a/arch/sh/boards/mach-sh03/rtc.c +++ b/arch/sh/boards/mach-sh03/rtc.c @@ -13,8 +13,9 @@  #include <linux/bcd.h>  #include <linux/rtc.h>  #include <linux/spinlock.h> -#include <asm/io.h> -#include <asm/rtc.h> +#include <linux/io.h> +#include <linux/rtc.h> +#include <linux/platform_device.h>  #define RTC_BASE	0xb0000000  #define RTC_SEC1	(RTC_BASE + 0) @@ -38,7 +39,7 @@  static DEFINE_SPINLOCK(sh03_rtc_lock); -unsigned long get_cmos_time(void) +static int sh03_rtc_gettimeofday(struct device *dev, struct rtc_time *tm)  {  	unsigned int year, mon, day, hour, min, sec; @@ -75,17 +76,18 @@ unsigned long get_cmos_time(void)  	}  	spin_unlock(&sh03_rtc_lock); -	return mktime(year, mon, day, hour, min, sec); -} -void sh03_rtc_gettimeofday(struct timespec *tv) -{ +	tm->tm_sec  = sec; +	tm->tm_min  = min; +	tm->tm_hour = hour; +	tm->tm_mday = day; +	tm->tm_mon  = mon; +	tm->tm_year = year - 1900; -	tv->tv_sec = get_cmos_time(); -	tv->tv_nsec = 0; +	return 0;  } -static int set_rtc_mmss(unsigned long nowtime) +static int set_rtc_mmss(struct rtc_time *tm)  {  	int retval = 0;  	int real_seconds, real_minutes, cmos_minutes; @@ -97,8 +99,8 @@ static int set_rtc_mmss(unsigned long nowtime)  		if (!(__raw_readb(RTC_CTL) & RTC_BUSY))  			break;  	cmos_minutes = (__raw_readb(RTC_MIN1) & 0xf) + (__raw_readb(RTC_MIN10) & 0xf) * 10; -	real_seconds = nowtime % 60; -	real_minutes = nowtime / 60; +	real_seconds = tm->tm_sec; +	real_minutes = tm->tm_min;  	if (((abs(real_minutes - cmos_minutes) + 15)/30) & 1)  		real_minutes += 30;		/* correct for half hour time zone */  	real_minutes %= 60; @@ -112,22 +114,31 @@ static int set_rtc_mmss(unsigned long nowtime)  		printk_once(KERN_NOTICE  		       "set_rtc_mmss: can't update from %d to %d\n",  		       cmos_minutes, real_minutes); -		retval = -1; +		retval = -EINVAL;  	}  	spin_unlock(&sh03_rtc_lock);  	return retval;  } -int sh03_rtc_settimeofday(const time_t secs) +int sh03_rtc_settimeofday(struct device *dev, struct rtc_time *tm)  { -	unsigned long nowtime = secs; - -	return set_rtc_mmss(nowtime); +	return set_rtc_mmss(tm);  } -void sh03_time_init(void) +static const struct rtc_class_ops rtc_generic_ops = { +	.read_time = sh03_rtc_gettimeofday, +	.set_time = sh03_rtc_settimeofday, +}; + +static int __init sh03_time_init(void)  { -	rtc_sh_get_time = sh03_rtc_gettimeofday; -	rtc_sh_set_time = sh03_rtc_settimeofday; +	struct platform_device *pdev; + +	pdev = platform_device_register_data(NULL, "rtc-generic", -1, +					     &rtc_generic_ops, +					     sizeof(rtc_generic_ops)); + +	return PTR_ERR_OR_ZERO(pdev);  } +arch_initcall(sh03_time_init); | 
