65 lines
1.2 KiB
C
65 lines
1.2 KiB
C
|
/*
|
||
|
* A glue layer that provides RTC read/write to drivers/char/genrtc.c driver
|
||
|
* based on MIPS internal RTC routines. It does take care locking
|
||
|
* issues so that we are SMP/Preemption safe.
|
||
|
*
|
||
|
* Copyright (C) 2004 MontaVista Software Inc.
|
||
|
* Author: Jun Sun, jsun@mvista.com or jsun@junsun.net
|
||
|
*
|
||
|
* Please read the COPYING file for all license details.
|
||
|
*/
|
||
|
|
||
|
#include <linux/spinlock.h>
|
||
|
|
||
|
#include <asm/rtc.h>
|
||
|
#include <asm/time.h>
|
||
|
|
||
|
static spinlock_t mips_rtc_lock = SPIN_LOCK_UNLOCKED;
|
||
|
|
||
|
unsigned int get_rtc_time(struct rtc_time *time)
|
||
|
{
|
||
|
unsigned long nowtime;
|
||
|
|
||
|
spin_lock(&mips_rtc_lock);
|
||
|
nowtime = rtc_get_time();
|
||
|
to_tm(nowtime, time);
|
||
|
time->tm_year -= 1900;
|
||
|
spin_unlock(&mips_rtc_lock);
|
||
|
|
||
|
return RTC_24H;
|
||
|
}
|
||
|
|
||
|
int set_rtc_time(struct rtc_time *time)
|
||
|
{
|
||
|
unsigned long nowtime;
|
||
|
int ret;
|
||
|
|
||
|
spin_lock(&mips_rtc_lock);
|
||
|
nowtime = mktime(time->tm_year+1900, time->tm_mon+1,
|
||
|
time->tm_mday, time->tm_hour, time->tm_min,
|
||
|
time->tm_sec);
|
||
|
ret = rtc_set_time(nowtime);
|
||
|
spin_unlock(&mips_rtc_lock);
|
||
|
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
unsigned int get_rtc_ss(void)
|
||
|
{
|
||
|
struct rtc_time h;
|
||
|
|
||
|
get_rtc_time(&h);
|
||
|
return h.tm_sec;
|
||
|
}
|
||
|
|
||
|
int get_rtc_pll(struct rtc_pll_info *pll)
|
||
|
{
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
|
||
|
int set_rtc_pll(struct rtc_pll_info *pll)
|
||
|
{
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
|