基本接口实验D—IIC总线串行通信实验.ppt
文本预览下载声明
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
显示全部