/********************************************************************** * AT24C0X I2C通信原理 * 说明: * 之前接触AT24C02用的相对比较多,这次接触到AT24C08,存储量大了 * 数据存储方式也就不一样,另外就是之前在Linux下面有标准AT24系列驱动, * 目前的FPGA需要编写操作PCIe控制I2C Master驱动,对EEPROM进行存取操作。 * * 2018-11-7 深圳 宝安西乡 曾剑锋 *********************************************************************/ 一、参考文档 1. AT24C0X Datasheet https://www.mouser.com/ds/2/268/atmel_doc0180-1065439.pdf 2. AT24C02/04/08 地址理解 https://blog.csdn.net/qq_38405680/article/details/81360604 3. altera I2C master driver https://github.com/torvalds/linux/blob/master/drivers/i2c/busses/i2c-altera.c 4. AT24 Linux driver https://github.com/torvalds/linux/blob/master/drivers/misc/eeprom/at24.c
5. AT24CXX之设备寻址和页寻址解读
https://wenku.baidu.com/view/6898d9ba6394dd88d0d233d4b14e852458fb39cd.html 二、器件信息 1. 测试AT24C02,刚开始用2.5V电压操作,I2C通信无ACK信号,换成3.3V正常,不过手册中有涉及1.8V,跟芯片型号有关; 2. AT24C02,存储空间为2K bit = 256B,8bit地址空间足够,所以只有一个地址页,也就是一个AT24C02只有一个I2C地址; 4. AT24C02一次连续写入,最多8 Byte; 3. AT24C08,存储空间为8K bit = 1024B = 4 * 256B,4 * 8bit地址空间足够,所以只有四个地址页,也就是一个AT24C08只有四个I2C地址,原地址引脚A0/A1无效,对应地址位变为页选择位; 5. AT24C08一次连续写入,最多16 Byte; 6. 貌似在读的时候没有读取多少个字节的限制; 7. Linux驱动中有标准的AT24系列的驱动,如果需要了解更多的实际代码操作细节,可以分析这部分驱动;