簡介
CMOS原來指的是一種生產(chǎn)電子電路的工藝,在PC上一般指的是RTC電路單元,因為早期它是由這種工藝生產(chǎn)出來的,所以又把RTC稱作了CMOS。
RTC(Real Time Clock)即實時時鐘,用于保存記錄時間和日期,也可以用來做定時開機功能。 RTC靠一組獨立的電源給它供電,這樣設(shè)計的目的就是為了不受系統(tǒng)電源的影響,可以保持一直有電,哪怕是在關(guān)機狀態(tài)下。 當(dāng)然這是理想狀態(tài)下的,因為會有一些不可抗拒的原因,可能會導(dǎo)致斷電,比如電池電量消耗完。
RTC的供電設(shè)計有兩種:臺式機上使用常見的RTC電池,筆記本上也有使用RTC電池的,但有些為了節(jié)省空間和減低成本,直接共用筆記本電池的電源。 RTC功耗極低,根本不需要憂慮它會對對電池造成大的負(fù)擔(dān)。
要使RTC正常工作,除了電源,還需要一個32.768KHZ的晶振。 RTC通過對晶振所產(chǎn)生的振蕩頻率分頻和累加,得到年、月、日、時、分、秒等時間信息,并將其保存在一段RAM中。

實時傳輸單元內(nèi)存
在UEFI問世之前,BIOS存儲一些變量(如BIOS SETUP設(shè)置)的方法就是放在RTC RAM中的,只要RTC有電,數(shù)據(jù)就可以一直保存。 如果要恢復(fù)默認(rèn)設(shè)置,或忘記密碼等,便可以通過拆卸 RTC 電池的辦法來達到目的。
至今,“清CMOS”這個詞還在沿用,雖然目的都是為了恢復(fù)BIOS SETUP初始值,但原理已經(jīng)變了,UEFI中“清CMOS”并不能達到恢復(fù)默認(rèn)設(shè)置的目的,因為數(shù)據(jù)不是存放在CMOS中了,而是BIOS ROM。 那現(xiàn)在的“清CMOS”是怎么實現(xiàn)的呢? 原理就是BIOS啟動的時候去判斷RTC是否掉過電(如Intel中的RTC_PWR_STS),是的話代碼就執(zhí)行恢復(fù)動作。 注意,這里的恢復(fù)是代碼實現(xiàn)的,而原來利用的是RTC掉電,數(shù)據(jù)會清除的原理!
RTC RAM 共有128字節(jié),前14字節(jié)是有標(biāo)準(zhǔn)定義的,可以用來控制實時時鐘,而其它字節(jié)對現(xiàn)在來說都已經(jīng)過時了,基本沒什么用,最多拿來臨時存一些數(shù)據(jù)作標(biāo)記。

前14字節(jié)定義(具體需要參照各平臺芯片設(shè)計廠商相關(guān)的手冊)
前面所寫的指的是傳統(tǒng)的RTC RAM,后面又有了一個擴展的RTC RAM,它相比傳統(tǒng)的RTC RAM,可使用的寄存器增加到了256個,不過也很少用到。。
訪問
RTC RAM分為兩部分,第一部分傳統(tǒng)CMOS,只有128字節(jié),第二部分為擴展CMOS,有256字節(jié),需要分開使用70/71或72/73端口訪問,每次讀寫只支持單字節(jié)操作。 通過RW查看,如下:


RW中直接可以看到在跳動的秒數(shù),操作系統(tǒng)下的時間和日期都是從RTC讀出來的。 如果在OS下更改時間或日期,RTC中相關(guān)寄存器也會被變更。
代碼訪問CMOS直接使用 IoRead8() 和 IoWrite8() 就可以了,比較簡單,EDK2中有相關(guān)函數(shù),如下:
UINT8
EFIAPI
CmosRead8 (
IN UINTN Index
)
{
IoWrite8(0x70, (UINT8) Index);
return IoRead8 (0x71);
}
UINT8
EFIAPI
CmosWrite8 (
IN UINTN Index,
IN UINT8 Value
)
{
IoWrite8 (0x70, (UINT8) Index);
IoWrite8 (0x71, Value);
return Value;
}
定時開機
定時開機的叫法有幾種,如RTC Wake Up、RTC Alarm、Wake Up From S5 等,原理就是設(shè)置RTC中幾個Alarm寄存器,當(dāng)Alarm寄存器的值跟當(dāng)前時間一樣時,RTC就會產(chǎn)生一個Alarm,如果此時RTC Alarm Enable有被設(shè)置啟用的話,則會產(chǎn)生一個喚醒事件(wake event)喚醒計算機,達到一個定時開機的作用。
定時開機常見的應(yīng)用場景有兩種,一種是在BIOS SETUP做的定時開機功能,另一種則是由APP設(shè)置的定時開機,如常用于測試跑自動開關(guān)機的工具Pwrtest.exe(它是微軟提供的,在SDK中可找到它,由于EWDK包含SDK,所以EWDK也有,用everything搜一下很快可以找到),原理也是在關(guān)機的時候設(shè)置了RTC Alarm, 然后不斷重復(fù)這個動作,便實現(xiàn)了自動開關(guān)機的功能。
-
CMOS
+關(guān)注
關(guān)注
58文章
6190瀏覽量
241590 -
晶振
+關(guān)注
關(guān)注
35文章
3442瀏覽量
72660 -
內(nèi)存
+關(guān)注
關(guān)注
9文章
3173瀏覽量
76118 -
BIOS
+關(guān)注
關(guān)注
6文章
474瀏覽量
48017 -
RTC
+關(guān)注
關(guān)注
2文章
639瀏覽量
71010
發(fā)布評論請先 登錄
基于STM32的USB程序開發(fā)筆記 匯總
Modbus庫開發(fā)筆記之十一:關(guān)于Modbus協(xié)議棧開發(fā)的說明
壇友經(jīng)驗分享之STM32的USB程序開發(fā)筆記
Odrive開發(fā)筆記 精選資料推薦
基于LM3S網(wǎng)絡(luò)開發(fā)筆記8_數(shù)據(jù)采集
基于LM3S網(wǎng)絡(luò)開發(fā)筆記5_初識JavaScript
基于LM3S網(wǎng)絡(luò)開發(fā)筆記3_多網(wǎng)頁開發(fā)
基于LM3S網(wǎng)絡(luò)開發(fā)筆記1_開發(fā)平臺
Qt嵌入式開發(fā)筆記

BIOS開發(fā)筆記:CMOS簡介
評論