X-Git-Url: http://git.monstr.eu/?a=blobdiff_plain;f=include%2Fasm-mips%2Frtc.h;h=82ad401c7dcae6839d5ea6b0e7181ce6fca84822;hb=225ec70a8cf5086a70d755e394c56186a30053d3;hp=3c4b637fd925894da65134e0ec82c33d84053f11;hpb=d344c5e0856ad03278d8700b503762dbc8b86e12;p=linux-2.6-microblaze.git diff --git a/include/asm-mips/rtc.h b/include/asm-mips/rtc.h index 3c4b637fd925..82ad401c7dca 100644 --- a/include/asm-mips/rtc.h +++ b/include/asm-mips/rtc.h @@ -15,6 +15,7 @@ #ifdef __KERNEL__ #include +#include #define RTC_PIE 0x40 /* periodic interrupt enable */ #define RTC_AIE 0x20 /* alarm interrupt enable */ @@ -27,11 +28,46 @@ #define RTC_24H 0x02 /* 24 hour mode - else hours bit 7 means pm */ #define RTC_DST_EN 0x01 /* auto switch DST - works f. USA only */ -unsigned int get_rtc_time(struct rtc_time *time); -int set_rtc_time(struct rtc_time *time); -unsigned int get_rtc_ss(void); -int get_rtc_pll(struct rtc_pll_info *pll); -int set_rtc_pll(struct rtc_pll_info *pll); +static inline unsigned int get_rtc_time(struct rtc_time *time) +{ + unsigned long nowtime; + nowtime = rtc_mips_get_time(); + to_tm(nowtime, time); + time->tm_year -= 1900; + + return RTC_24H; +} + +static inline int set_rtc_time(struct rtc_time *time) +{ + unsigned long nowtime; + int ret; + + nowtime = mktime(time->tm_year+1900, time->tm_mon+1, + time->tm_mday, time->tm_hour, time->tm_min, + time->tm_sec); + ret = rtc_mips_set_time(nowtime); + + return ret; +} + +static inline unsigned int get_rtc_ss(void) +{ + struct rtc_time h; + + get_rtc_time(&h); + return h.tm_sec; +} + +static inline int get_rtc_pll(struct rtc_pll_info *pll) +{ + return -EINVAL; +} + +static inline int set_rtc_pll(struct rtc_pll_info *pll) +{ + return -EINVAL; +} #endif #endif