嵌入式处理器MPC8250与CF卡的接口设计(2)
- UID
- 1029342
- 性别
- 男
|
嵌入式处理器MPC8250与CF卡的接口设计(2)
当写入一个扇区的数据时,首先比较所写入的扇区号(CurrSectorNum),是否与备份数据的扇区号(SaveSectorNum)一致,如果一致,则把数据写入备份数据中,并且设置SectorDirty为“1”;否则,判断备份数据是否更改,即SectorDirty是否为“1”;如果不是,则从CF卡中读取扇区号为CurrSectorNum的数据到tempSect中;否则,先把tempSect的数据写回CF卡,然后从CF卡中读取扇区号为CurrSectorNum的数据到tempSect中。最后,设置备份数据扇区号SaveSectorNum为当前数据的扇区号CurrSectorNum,将指定数据写到备份数据中,并且设置SectorDirty为“1”。2.3 读写数据的相关寄存器根据CF卡标准,不能直接访问CF卡的数据区域,而需要通过访问CF卡内的相关寄存器(这些寄存器的基地址在CF卡初始化时配置,见2.1节)间接读取或者写入数据。在访问CF卡时必须对它们进行正确配置:(1)扇区数目寄存器(Sector_CNT Register)读写操作时,保存需要传送的扇区数目。如果为0,则选择256个扇区;如果操作成功,操作结束时此寄存器为0;如果操作不成功,此寄存器包含了有待完成的扇区数目。(2)磁头寄存器(Select_HEAD Register)其中包含了LBA位(1比特),用于设置地址访问方式。“1”LBA_Mode为逻辑地址访问方式,“0”为柱面/磁头/扇区访问方式。本系统选择逻辑地址访问方式,则该寄存器还包含了逻辑地址的24~27位。(3)扇区编号寄存器(Sector_NUM Register)在采用逻辑地址访问方式时,该寄存器包含了逻辑地址的0~7位。(4)柱面低位寄存器(Cylinder_LO Register)在采用逻辑地址访问方式时,该寄存器包含了逻辑地址的8~15位。(5)柱面高位寄存器(Cylinder_HI Register)在采用逻辑地址访问方式时,该寄存器包含了逻辑地址的16~23位。(6)状态寄存器(Status Register)反映了CF卡的状态,其中包含了CF卡忙(Busy)位、出错位(Err)、是否准备就绪位(Rdy)等。(7)数据寄存器(Data Register)存放读写数据,是一个16位寄存器。2.4 读数据从CF卡读取一个扇区的数据,如图3所示。因为系统采用的CF卡的扇区大小为:SectorSize = 512字节,假设读写数据的地址为Addr,则该地址所在的扇区号为:Sector = Addr % SectorSize。首先配置寄存器,设置读取的扇区数目、相应地址和访问模式;然后发送读命令(0x20),等待CF卡空闲且准备就绪,再从数据寄存器中连续读取一个扇区的数据;完成读取后,等待CF卡空闲;程序返回。2.5 写数据将数据写入CF卡的操作与从CF卡读取数据的操作类似,如图4所示。首先配置寄存器,设置写入的扇区数目、相应地址和访问模式;然后发送写命令(0x30),等待CF卡空闲并且处于准备状态,连续向数据寄存器写入一个扇区的数据;完成写入后,等待CF卡空闲,程序返回。本设计采用的操作系统是μC/OS——一个源代码完全公开的嵌入式操作系统。所有读写CF卡的函数都用C语言编制,并能在系统中有效工作。 |
|
|
|
|
|