RTC時(shí)間的安全讀取
方法1:
(缺點(diǎn)): for(;RTCCTL01&RTCRDY;) _NOP() ; // 等待RTC有效
這一步最長可能需要等上一秒鐘,對實(shí)時(shí)操作十分不利。
單要這一步: for(;!(RTCCTL01&RTCRDY);) _NOP() ; 雖然可以避免 RTCRDY復(fù)位的時(shí)候去讀取,但是不能避免讀取的還未完成,就遇到RTCRDY 復(fù)位的可能。
//
// //
// 讀取RTC時(shí)鐘 方法1 //
// //
//
unsigned long GetTime(void)
{
int hour,minute,second ;
unsigned long time ;
for(;RTCCTL01&RTCRDY;) _NOP() ; // 等待RTC有效
for(;!(RTCCTL01&RTCRDY);) _NOP() ;
hour = GetRTCHOUR() ;
minute = GetRTCMIN() ;
second = GetRTCSEC() ;
time = (unsigned long)hour*1000000
+(unsigned long)minute*1000
+(unsigned long)second ;
return time ;
}
方法2:
讀取時(shí)鐘 方法2 缺點(diǎn):
(數(shù)據(jù)體結(jié)構(gòu)pTime->wYear )
讀取RTC寄存器或者相關(guān)RTC芯片的絕妙方法
do
{
seconds = FROM_BCD(pRTCReg->BCDSEC & 0x7f);
pTime->wYear = FROM_BCD((pRTCReg->BCDYEAR & 0xff)) + RTC_YEAR_DATUM;
pTime->wMonth = FROM_BCD(pRTCReg->BCDMON & 0x1f);
pTime->wDay = FROM_BCD(pRTCReg->BCDDATE & 0x3f);
pTime->wDayOfWeek = pRTCReg->BCDDAY - 1;
pTime->wHour = FROM_BCD(pRTCReg->BCDHOUR & 0x3f);
pTime->wMinute = FROM_BCD(pRTCReg->BCDMIN & 0x7f);
pTime->wSecond = FROM_BCD(pRTCReg->BCDSEC & 0x7f);
pTime->wMilliseconds= 0;
} while (pTime->wSecond != seconds);
這樣即可防止在讀的過程中出現(xiàn)跨分、時(shí)、日、月、年等跳變時(shí)取得的數(shù)據(jù)不同步。
在計(jì)數(shù)器變化的時(shí)候去讀取,該讀取被判為無效,自動(dòng)忽略。向寄存器寫入范圍外的數(shù)據(jù)和時(shí)間會(huì)導(dǎo)致不可預(yù)見的結(jié)果。
評論