導(dǎo)讀
RTC是一種用于記錄時間的電子設(shè)備,廣泛應(yīng)用于各種嵌入式系統(tǒng)中。本文通過實(shí)際案例分析RTC在實(shí)際應(yīng)用中的問題并給出實(shí)際建議,如時間“歸零”、RTC時間誤差過大等。
RTC (Real Time Clock):實(shí)時時鐘,是一個獨(dú)立的定時器,無論器件處于運(yùn)行模式、低功耗模式還是復(fù)位狀態(tài),只要電源電壓保持在工作范圍內(nèi),RTC就會一直工作,實(shí)現(xiàn)計時功能。RTC電路雖然簡單,但實(shí)際應(yīng)用中還是會出現(xiàn)一些問題,例如時間“歸零”、RTC時間誤差過大等等,既涉及到硬件方面,也涉及到軟件方面。下面結(jié)合實(shí)際遇到的問題進(jìn)行一些方案討論和建議。
另外,在32位Linux系統(tǒng)上,不可避免的會遇到2038年問題,也放在這里一并闡述。
?從倉庫發(fā)貨的全新產(chǎn)品,為何RTC時間是1970年?
全新產(chǎn)品,開機(jī)后系統(tǒng)時間是1970年,有兩種可能性:
產(chǎn)品RTC電池沒有正確安裝,或者鋰電池與電池倉之間的隔離塑料墊片沒有去掉,RTC沒電不工作。
- 安裝了RTC電池,但RTC電池已經(jīng)被耗盡,這情況一般出現(xiàn)在較長時間庫存產(chǎn)品上。
提示:RTC獨(dú)立供電的產(chǎn)品,使用前必須正確安裝RTC電池,并在第一次開機(jī)的時候設(shè)置正確的RTC時間。庫存產(chǎn)品,不安裝RTC電池,或者在安裝電池時做好供電隔離。
?產(chǎn)品運(yùn)行一段時間后,RTC變成1970年了,引起程序運(yùn)行異常
正常運(yùn)行的系統(tǒng),經(jīng)過一段時間后內(nèi)核出現(xiàn)如下提示:
rtc-pcf8563 0-0051: low voltage detected, date/time is not reliable.
說明RTC電池電壓已經(jīng)偏低。這樣會導(dǎo)致RTC時間不可靠,從而影響到Linux系統(tǒng)時間的準(zhǔn)確性。
PCF8563芯片具有電池電壓檢測功能,當(dāng)電壓低于0.9V時將無法保證時鐘信息的準(zhǔn)確性(參考圖1),進(jìn)而導(dǎo)致系統(tǒng)運(yùn)行異常。
圖1 PCF8563RTC芯片低壓檢測功能
為了避免出現(xiàn)RTC電池電壓偏低的情況,可以做如下方面的考慮:
- 可考慮用可充電的RTC電池,并設(shè)計充電電路;
- 關(guān)閉RTC芯片的CLKOUT功能,降低RTC功耗,延長RTC電池續(xù)航時間;
- 增加超級電容,正常上電時由系統(tǒng)電源供電,系統(tǒng)掉電后由超級電容供電,超級電容耗盡再用鋰電池供電。
圖2是RTC多電源供電參考原理圖。
圖2 RTC多電源供電參考原理圖
設(shè)計時需注意以下幾點(diǎn):
RTC_VDD 僅供電給時鐘芯片的VDD引腳;
預(yù)留CLKOUT 信號測試點(diǎn),用于調(diào)試時鐘精度,調(diào)試結(jié)束后關(guān)閉該功能可減少功耗。
?讓人頭疼的“2038年”問題
先介紹一下UNIX世界的時間,Unix紀(jì)元時間是從協(xié)調(diào)世界時(UTC)1970年1月1日0點(diǎn)開始算起,到現(xiàn)在的總秒數(shù)。這個時間也被稱為POSIX時間。Linux沿用UNIX時間,在32位處理器的Linux系統(tǒng)里,定時器是32位的,最大計數(shù)是0xFFFFFFFF,而在Linux系統(tǒng)中,rtc_time定義的是秒、分、小時等都是有符號整數(shù)。
struct rtc_time { int tm_sec; int tm_min; int tm_hour; int tm_mday; int tm_mon; int tm_year; int tm_wday; int tm_yday; int tm_isdst;};
32位定時器有符號整數(shù)最大計數(shù)為0x7FFFFFF,換算成十進(jìn)制是2147483647。
2147483647秒,換算成年的話,是68.09625973490614年,大概是68年零18天。所以,UNIX時間,從1970年1月1日零時起,經(jīng)過68年零18天后(確切是2038年1月19日中午1107),計數(shù)器溢出,RTC將無法正常工作。在32位系統(tǒng)上解決這個問題,需要升級到Linux內(nèi)核到高版本,同時升級glibc,工作量很大,對一些發(fā)布較久的處理器,原廠不一定能提供新版本內(nèi)核,這是很讓人頭疼的。如果選用選用64位處理器,跑64位Linux系統(tǒng)就沒這個問題了。
升級到64位Linux系統(tǒng)后,RTC計數(shù)器最大值為0x7FFFFFFFFFFFFFFF,換算成十進(jìn)制是9223372036854775807。9223372036854775807秒,換算成年,大約是292億年,完全不用去考慮RTC時間溢出的問題了。
-
Linux
+關(guān)注
關(guān)注
87文章
11292瀏覽量
209326 -
實(shí)時時鐘
+關(guān)注
關(guān)注
4文章
245瀏覽量
65767 -
RTC
+關(guān)注
關(guān)注
2文章
538瀏覽量
66461
發(fā)布評論請先 登錄
相關(guān)推薦
評論