AT24C02写数据介绍
EEPROM的写数据分为:
- 字节写数据模式
- 页写数据模式;
字节写就是一个地址一个数据的写,页写是连续写数据,一个地址多个数据的写,但是页写不能自动跨页,如果超出一页长度,超出的数据会覆盖原先写入的数据。
跨页写数据实现原理:
通过IIC读写AT24C02,百度上面有一大堆例程。但向AT24C02写一个字符串时,例程上基本上都是以页写的形式呈现。
页写入的方式只能写满一页,不能跨页继续写。
在此补充一个实现跨页写的函数,希望可以帮助到大家:
跨页写数据代码实现
#define Page_Byte 8 //页字节8个
#define Max_Addr 0xff //最大可访问地址
unsigned char AT24C02_Write(unsigned char WriteAddr,unsigned char* buffer)
{
unsigned short int BufSize = strlen(buffer); //获取要写入的字符串长度
if((Max_Addr-WriteAddr) < BufSize) //空间不足返回0
return 0;
I2C_Start(); //发I2C起始信号
I2C_Send_Byte(0XA0); //写器件地址
I2C_Wait_Ack(); //等待应答信号
I2C_Send_Byte(WriteAddr); //发送地址
I2C_Wait_Ack(); //等待应答信号
while(*buffer++ != 0)
{
I2C_Send_Byte(*buffer); //发送数据
I2C_Wait_Ack(); //等待应答信号
WriteAddr++; //写入地址加1
if(WriteAddr % Page_Byte == 0) //新的一页
{
I2C_Stop();
delay_24c02();// AT24C02的写入周期是5ms,延时一定要大于或者等于5ms
I2C_Start();
I2C_Send_Byte(0XA0);
I2C_Wait_Ack(); //等待应答信号
I2C_Send_Byte(WriteAddr); //发送地址
I2C_Wait_Ack(); //等待应答信号
}
}
I2C_Stop();
delay_24c02();
return 1;
}
代码说明
在上面的代码中,有两个宏定义,第一个是一页可以写入的字节。在进行页写入的时候,比如写到了地址0x08,那么我们就要对这个地址进行判断,因为0x08已经是新的一页,所以 我们就要给一个停止信号,重新开始一次IIC通信,如何判断一个地址是否是新的一页,就是通过if(WriteAddr % Page_Byte == 0)
这条语句实现的。
第二个宏定义是最大可写入地址,当写入的字节数大于剩余的可写入空间时,就可以通过if((Max_Addr-WriteAddr) < BufSize)
这条语句实现,这样的代码更加规范、安全。
注意事项
由于E2PROM的半导体工艺特性,对E2PROM的写入时间需要5~10ms,但AT24Cxx系列串行E2PROM芯片内部设置了一个具有SRAM性质的输入缓冲器,称为页写缓冲器。
CPU对该芯片写操作时,AT24Cxx系列芯片先将CPU输入的数据暂存在页写缓冲器内,然后,慢慢写入E2PROM中。
因此,CPU对AT24Cxx系列E2PROM一次写入的字节数,受到该芯片页写缓冲器容量的限制。
页写缓冲器的容量为16B,若CPU写入字节数超过芯片页写缓冲器容量,应在一页写完后,隔5~10ms重新启动一次写操作。
而且,若不是从页写缓冲器页内零地址0000写起,一次写入地址超出页内最大地址1111时,也将出错。
例如,若从页内地址0000写起,一次最多可写16字节;
若从页内地址0010写起,一次最多只能写14字节,若要写16字节,超出页内地址1111,将会引起地址翻卷,导致出错。