文档详情

基本接口实验D—IIC总线串行通信实验.ppt

发布:2017-07-07约2.06千字共28页下载文档
文本预览下载声明
IIC总线串行通信实验;IIC总线介绍;IIC总线介绍;IIC总线的寻址方式;;带 IIC总线接口的 EEPROM有许多型号,其中 AT24CXX系列使用十分普遍。产 品 包 括AT2401/02/04/08/16等 ,其 容 量: 128x8/256x8/512x8/1024x8/2048x8,适用于 2V~5V 的低电压的操作。具有低功耗和高可靠性等优点。 AT24 系列存储器芯片采用 CMOS 工艺制造,内置有高压泵,可在单电压供电条件下工作。其标准封装为 8 脚 DIP 封装形式,如图 :; EEPROM 读写操作 ;IIC总线可构成多主和主从系统。在多主系统结构中,系统通过硬件或软件仲裁获得总线控制使用权。应用系统中 IIC 总线多采用主从结构,即总线上只有一个主控节点,总线上的其它设备都作为从设备。IIC总线上的设备寻址由器件地址接线决定,并且通过访问地址最低位来控制读写方向。 IIC 总线的读写控制逻辑 开始条件(START_C) 在开始条件下,当 SCL 为高电平时,SDA 由高转为低。 停止条件(STOP_C) 在停止条件下,当 SCL 为高电平时,SDA 由低转为高。 确认信号(ACK) 在接收方应答下,每收到一个字节后便将 SDA 电平拉低。 数据传送(Read/Write) IIC 总线启动或应答后 SCL 高电平期间数据串行传送;低电平期间为数据准备,并允许 SDA线上数据电平变换。总线以字节(8bit)为单位传送数据,且高有效位(MSB)在前。IIC数据传送时序如图 所示:;开始和结束条件;确认信号(ACK);AT24CXX 的数据操作格式 ;写入操作格式:;读出操作格式;S3C2410X IIC 接口 ;IIC 总线控制寄存器 IICCON;IIC 总线状态寄存器 IICSTAT;IIC 总线地址寄存器 IICADD和 发送接收移位寄存器 IICDS ;实验设计;主发送程序设计流程图 ;主接收程序设计流程图 ;2. 电路设计 EduKit-III 实验平台中,使用 S3C2410X 处理器内置的 IIC 控制器作为 IIC 通信主设备,AT24C04 EEPROM 为从设备。电路设计如图 所示:;实验操作步骤 ;观察实验结果;程序分析;2. 中断服务程序 void iic_int_24c04(void) { ClearPending(BIT_IIC); f_nGetACK = 1; };void iic_write_24c040(UINT32T unSlaveAddr,UINT32T unAddr,UINT8T ucData) { f_nGetACK = 0; // Send control byte rIICDS = unSlaveAddr; rIICSTAT = 0xf0; while(f_nGetACK == 0); f_nGetACK = 0; //Send address rIICDS = unAddr; rIICCON = 0xaf; while(f_nGetACK == 0); f_nGetACK = 0; // Send data rIICDS = ucData; rIICCON = 0xaf; while(f_nGetACK == 0); f_nGetACK = 0; // End send rIICSTAT =0xd0; rIICCON = 0xaf; delay(5); };void read_24c040(UINT32T unSlaveAddr,UINT32T unAddr,UINT8T *pData) { f_nGetACK = 0; rIICDS = unSlaveAddr; rIICSTAT = 0xf0; while(f_nGetACK == 0); f_nGetACK = 0; rIICDS = unAddr; rIICCON = 0xaf; while(f_nGetACK == 0); f_nGetACK = 0; rIICDS = unSlaveAddr; rIICSTAT = 0xb0; rIICCON = 0xaf; while(f_nGetACK == 0); f_nGetACK = 0; cRecvByte = rIICDS; rIICCON = 0x2f; delay(1); cRecvByte = rIICDS; rIICS
显示全部
相似文档