一种PowerPC处理器与CF卡的接口设计方案
A位(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语言编制,并能在系统中有效工作。
- 基于PowerPC和嵌入式Linux的VPN网关设计(11-01)
- μC/OS的任务调度实现方法及其在PowerPC上的优化(10-29)
- 基于PowerPC和Linux的VPN网关设计(01-14)
- uCOS-II优先级任务调度在PowerPC上的移植和优化(08-15)
- 全新EDK8.1简化嵌入式设计(06-04)
- ARM DSP X86 POWERPC MIPS FPGA简介(11-11)