嵌入式處理器MPC8250與CF卡的接口設(shè)計
當(dāng)寫入一個扇區(qū)的數(shù)據(jù)時,首先比較所寫入的扇區(qū)號(CurrSectorNum),是否與備份數(shù)據(jù)的扇區(qū)號(SaveSectorNum)一致,如果一致,則把數(shù)據(jù)寫入備份數(shù)據(jù)中,并且設(shè)置SectorDirty為“1”;否則,判斷備份數(shù)據(jù)是否更改,即SectorDirty是否為“1”;如果不是,則從CF卡中讀取扇區(qū)號為CurrSectorNum的數(shù)據(jù)到tempSect中;否則,先把tempSect的數(shù)據(jù)寫回CF卡,然后從CF卡中讀取扇區(qū)號為CurrSectorNum的數(shù)據(jù)到tempSect中。最后,設(shè)置備份數(shù)據(jù)扇區(qū)號SaveSectorNum為當(dāng)前數(shù)據(jù)的扇區(qū)號CurrSectorNum,將指定數(shù)據(jù)寫到備份數(shù)據(jù)中,并且設(shè)置SectorDirty為“1”。
2.3 讀寫數(shù)據(jù)的相關(guān)寄存器
根據(jù)CF卡標(biāo)準(zhǔn),不能直接訪問CF卡的數(shù)據(jù)區(qū)域,而需要通過訪問CF卡內(nèi)的相關(guān)寄存器(這些寄存器的基地址在CF卡初始化時配置,見2.1節(jié))間接讀取或者寫入數(shù)據(jù)。在訪問CF卡時必須對它們進(jìn)行正確配置:
(1)扇區(qū)數(shù)目寄存器(Sector_CNT Register)
讀寫操作時,保存需要傳送的扇區(qū)數(shù)目。如果為0,則選擇256個扇區(qū);如果操作成功,操作結(jié)束時此寄存器為0;如果操作不成功,此寄存器包含了有待完成的扇區(qū)數(shù)目。
(2)磁頭寄存器(Select_HEAD Register)
其中包含了LBA位(1比特),用于設(shè)置地址訪問方式?!埃薄保煟蹋拢粒撸停铮洌澹牉檫壿嫷刂吩L問方式,“0”為柱面/磁頭/扇區(qū)訪問方式。本系統(tǒng)選擇邏輯地址訪問方式,則該寄存器還包含了邏輯地址的24~27位。
(3)扇區(qū)編號寄存器(Sector_NUM Register)
在采用邏輯地址訪問方式時,該寄存器包含了邏輯地址的0~7位。
(4)柱面低位寄存器(Cylinder_LO Register)
在采用邏輯地址訪問方式時,該寄存器包含了邏輯地址的8~15位。
(5)柱面高位寄存器(Cylinder_HI Register)
在采用邏輯地址訪問方式時,該寄存器包含了邏輯地址的16~23位。
(6)狀態(tài)寄存器(Status Register)
反映了CF卡的狀態(tài),其中包含了CF卡忙(Busy)位、出錯位(Err)、是否準(zhǔn)備就緒位(Rdy)等。
(7)數(shù)據(jù)寄存器(Data Register)
存放讀寫數(shù)據(jù),是一個16位寄存器。
2.4 讀數(shù)據(jù)
從CF卡讀取一個扇區(qū)的數(shù)據(jù),如圖3所示。因為系統(tǒng)采用的CF卡的扇區(qū)大小為:SectorSize = 512字節(jié),假設(shè)讀寫數(shù)據(jù)的地址為Addr,則該地址所在的扇區(qū)號為:
Sector = Addr % SectorSize。
首先配置寄存器,設(shè)置讀取的扇區(qū)數(shù)目、相應(yīng)地址和訪問模式;然后發(fā)送讀命令(0x20),等待CF卡空閑且準(zhǔn)備就緒,再從數(shù)據(jù)寄存器中連續(xù)讀取一個扇區(qū)的數(shù)據(jù);完成讀取后,等待CF卡空閑;程序返回。
2.5 寫數(shù)據(jù)
將數(shù)據(jù)寫入CF卡的操作與從CF卡讀取數(shù)據(jù)的操作類似,如圖4所示。首先配置寄存器,設(shè)置寫入的扇區(qū)數(shù)目、相應(yīng)地址和訪問模式;然后發(fā)送寫命令(0x30),等待CF卡空閑并且處于準(zhǔn)備狀態(tài),連續(xù)向數(shù)據(jù)寄存器寫入一個扇區(qū)的數(shù)據(jù);完成寫入后,等待CF卡空閑,程序返回。
本設(shè)計采用的操作系統(tǒng)是μC/OS——一個源代碼完全公開的嵌入式操作系統(tǒng)。所有讀寫CF卡的函數(shù)都用C語言編制,并能在系統(tǒng)中有效工作。
評論