单片机 I2C操作笔记——以 AT24C04为例
来源:互联网 发布:凯文老师的淘宝店 编辑:程序博客网 时间:2024/06/07 03:30
1.前言
对于大多数工程师而言,I2C永远是一个头疼的问题。相比UART和SPI而言,I2C的时序要复杂一些,I2C组合变化也丰富一些。在这里以AT24C04为例说明I2C使用过程中的一些注意点。
2.AT24C04操作示意图
图 AT24C04操作示意图
示意图说明:示意图分阐述了4种不同的操作方式,例如写单个存储单元,写多个存储单元,读单个存储单元和写单个存储单元。对于单个操作而言,上部为MCU通过I2C输出的相关指令,下部为I2C设备的响应。例如写单个存储单元操作时,MCU发出I2C启动,设备地址,写标志位等,而I2C设备输出多个ACK。
3.若干说明
3.1 基本操作方式
I2C设备的操作可分为写单个存储字节,写多个存储字节,读单个存储字节和读多个存储字节。相对于AT24C04而言,这些读写动作相对于内部的存储单元而言,对于其他的具备I2C接口的AD或传感器而言,存储单元变成了寄存器单元。虽然存在概念上的差别,但是其操作原理确实一样的。
3.2 无应答
在以上4种情况中,无应答为MCU发出,无应答意为MCU不需要从机输出数据,MCU将会停止本次I2C操作。需要说明的是,无应答并不是一种异常情况。
3.3 I2C设备并不只有一个设备地址
这一点往往被忽略,一般情况下认为在I2C启动信号之后的字节为I2C从机地址(7位)。对于AT24C04而言,内部具有4Kb存储位,合计512字节。若需要访问512字节内容,总共需要9根地址线(8位宽度),那么上图中的存储地址(8位长度)显然还差了一位,那么就需要从设备地址中“借”1位,这就使得AT24C04具有两个I2C地址,例如0x50和0x51。
3.4 存储地址
相对于AT24C04而言,存储地址占1个字节。若换成其他I2C设备,例如ADXL345,存储地址被寄存器地址替代即可,其他操作方式相似。但是像AT24C32或AT24C64这样的大容量EEPROM,则存储地址需要2字节描述,也就意味着需要连续发送两个字节地址信息且高字节在前。其他像BH1750这样的光照芯片,存储地址被具体的操作命令替代,使用I2C设备时需要因地制宜,切不可照搬教条。
3.5 连续读和连续写限制
AT24C04中存在页的概念,一页的大小为8字节,若果在单页的范围内,存储地址累加,若超过该页的最大地址,存储地址回到页开始处。所以对于连续读和连续写而言,最大的操作字节数为8。若需要操作的字节内容超过8字节,则需要进行翻页操作,即写入下一页的起始存储地址。
4 总结
I2C设备有很多种,若掌握基本原理,便可见招拆招,那是I2C总线就不那么难了。
5.参考资料
【维基百科I2C】
0 0
- 单片机 I2C操作笔记——以 AT24C04为例
- I2C操作笔记——以 AT24C04为例
- I2C操作笔记——以 AT24C04为例
- I2C操作笔记——以 AT24C04为例
- I2C操作笔记——以 AT24C04为例
- I2C操作笔记——以 AT24C04为例
- I2C操作笔记,以AT24C04为例
- 简单介绍STM32F3系列单片机中片内运算放大器的使用——以STM32F303DISCOVERY板为例
- 51单片机——I2C总线
- At24C04
- Linux Platform Device and Driver(以I2C为例)
- ARP协议实现原理(以单片机51为例)
- 单片机中断系统(部分以AT89S52为例)
- LPC2478通过I2C对AT24C04(EEPROM)进行读写
- STM32F407VE单片机使用I2C接口操作内部控制芯片为RA8816的FYD12864-1001A型的12864液晶
- MSP430 SD卡SPI读写操作(4) —— FatFs文件系统实现(以MSP430F5438A为例)
- DAO操作--以MySQL为例
- 以s3c2440的I2C子系统为例, 分析其代码实现
- ARM9学习笔记之——MMU
- syslog生命周期
- MFC程序动态链接库缺失的解决方法
- 51nod-1007 正整数分组
- Windows 下安装 Tomcat
- 单片机 I2C操作笔记——以 AT24C04为例
- UIDynamic 物理引擎
- 搭建 SpringMVC 框架
- 2016年互联网SEO的营销手段
- 面向报文(UDP)和面向字节流(TCP)的区别
- Linux进程间通信——使用命名管道
- 关于按钮(button)图文上下并存
- SpringMVC浅谈
- 预处理-分节2(条件编译)