打印
[DemoCode下载]

24C01--24C256共9种EEPROM的字节读写操作程序

[复制链接]
3757|13
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
zhuomuniao110|  楼主 | 2016-9-29 14:47 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
个通用的24C01-24C256共9种EEPROM的字节读写操作[url=]程序[/url]
此程序有五个入口条件,分别为读写[url=]数据[/url]缓冲区指针,
进行读写的字节数,EEPROM首址,EEPROM控制字节,
以及EEPROM类型。此程序结构性良好,具有极好的容错性,程序机器码也不多:


沙发
zhuomuniao110|  楼主 | 2016-9-29 14:49 | 只看该作者
#pragma  ot(6,SIZE)
#include
#include
#define  ERRORCOUNT 10
sbit     SDA="P0"^0;
sbit     SCL="P0"^1;
enum  eepromtype  {M2401,M2402,M2404,M2408,M2416,M2432,M2464,M24128,M24256};
enum  eepromtype EepromType;
//DataBuff为读写数据输入/输出缓冲区的首址
//ByteQuantity 为要读写数据的字节数量
//Address 为EEPROM的片内地址
//ControlByte 为EEPROM的控制字节,具体形式为(1)(0)(1)(0)(A2)(A1)(A0)(R/W),其中R/W="1",
//表示读操作,R/W="0"为写操作,A2,A1,A0为EEPROM的页选或片选地址;
//EepromType为枚举变量,需为M2401至M24256中的一种,分别对应24C01至24C256;
//函数返回值为一个位变量,若返回1表示此次操作失效,0表示操作成功;
//ERRORCOUNT为允许最大次数,若出现ERRORCOUNT次操作失效后,则函数中止操作,并返回1
//SDA和SCL由用户自定义,这里暂定义为P0^0和P0^1;
//其余的用户不用管,只要把只子程序放在你的程序中并调用它就可以了;
/***********************************************************************************/
bit   RW24XX(unsigned char *DataBuff,unsigned char ByteQuantity,unsigned int Address,
                     unsigned char ControlByte,enum eepromtype EepromType)
{
void Delay(unsigned char DelayCount);
void IICStart(void);
void IICStop(void);
bit  IICRecAck(void);
void IICNoAck(void);
void IICAck(void);
unsigned char IICReceiveByte(void);
void IICSendByte(unsigned char sendbyte);
unsigned char data j,i="ERRORCOUNT";
bit      errorflag="1";
while(i--)
   {
   IICStart();
   IICSendByte(ControlByte&0xfe);
   if(IICRecAck())
       continue;
   if(EepromType>M2416)
      {
      IICSendByte((unsigned char)(Address>>8));
      if(IICRecAck())
         continue;
      }
   IICSendByte((unsigned char)Address);
   if(IICRecAck())
       continue;
   if(!(ControlByte&0x01))
      {
      j="ByteQuantity";
      errorflag="0";                      //********clr errorflag
      while(j--)
        {
        IICSendByte(*DataBuff++);
        if(!IICRecAck())
           continue;
        errorflag="1";
        break;
        }
      if(errorflag==1)
        continue;
      break;
      }
   else
     {
     IICStart();
     IICSendByte(ControlByte);
     if(IICRecAck())
       continue;
     while(--ByteQuantity)
       {
       *DataBuff++=IICReceiveByte();
       IICAck();
       }
     *DataBuff="IICReceiveByte"();        //read last byte data
     IICNoAck();
     errorflag="0";
     break;
     }
  }
IICStop();
if(!(ControlByte&0x01))
  {
  Delay(255);
  Delay(255);
  Delay(255);
  Delay(255);
  }
return(errorflag);
}
/*****************以下是对IIC总线的操作子程序***/
/*****************启动总线**********************/
void IICStart(void)
{
SCL="0";                  //
SDA="1";
SCL="1";
_nop_();
_nop_();
_nop_();
SDA="0";
_nop_();
_nop_();
_nop_();
_nop_();
SCL="0";
SDA="1";                  //
}
/*****************停止IIC总线****************/
void IICStop(void)
{
SCL="0";
SDA="0";
SCL="1";
_nop_();
_nop_();
_nop_();
SDA="1";
_nop_();
_nop_();
_nop_();
SCL="0";
}
/**************检查应答位*******************/
bit IICRecAck(void)
{
SCL="0";
SDA="1";
SCL="1";
_nop_();
_nop_();
_nop_();
_nop_();
CY="SDA";                 //因为返回值总是放在CY中的
SCL="0";
return(CY);
}
/***************对IIC总线产生应答*******************/
void IICACK(void)
{
SDA="0";
SCL="1";
_nop_();
_nop_();
_nop_();
_nop_();
SCL="0";
_nop_();
SDA="1";
}
/*****************不对IIC总线产生应答***************/
void IICNoAck(void)
{
SDA="1";
SCL="1";
_nop_();
_nop_();
_nop_();
_nop_();
SCL="0";
}
/*******************向IIC总线写数据*********************/
void IICSendByte(unsigned char sendbyte)
{
unsigned char data j="8";
for(;j>0;j--)
   {
   SCL="0";
   sendbyte<<=1;        //无论C51怎样实现这个操作,始终会使CY="sendbyte"^7;
   SDA="CY";
   SCL="1";
   }
SCL="0";
}
/**********************从IIC总线上读数据子程序**********/
unsigned char IICReceiveByte(void)
{
register receivebyte,i="8";
SCL="0";
while(i--)
   {
   SCL="1";
   receivebyte=(receivebyte<<1)|SDA;
   SCL="0";
   }
return(receivebyte);
}
/***************一个简单延时程序************************/
void Delay(unsigned char DelayCount)
{
while(DelayCount--);
}

使用特权

评论回复
板凳
捉虫天师| | 2016-9-30 17:12 | 只看该作者
研究下代码,是如何实现不同系列的统一操作的。

使用特权

评论回复
地板
mintspring| | 2016-10-8 18:25 | 只看该作者
程序不错,放那个独立的文件里面,直接调用,应该很嗨皮。

使用特权

评论回复
5
lovecat2015| | 2016-10-9 19:37 | 只看该作者

像这种eeprom读写速度有多快?

使用特权

评论回复
6
wahahaheihei| | 2016-10-10 16:27 | 只看该作者
lovecat2015 发表于 2016-10-9 19:37
像这种eeprom读写速度有多快?

看这个芯片接口了,就是普通的I2C速度。。。你单片机能快到哪儿?比如你用51.

使用特权

评论回复
7
neeringstu| | 2016-10-11 19:40 | 只看该作者
都是用单片机写的,有没有arm的

使用特权

评论回复
8
huangcunxiake| | 2016-10-11 20:50 | 只看该作者
neeringstu 发表于 2016-10-11 19:40
都是用单片机写的,有没有arm的

ARM不同厂家用的寄存器不同,你把人家给你的程序关于寄存器操作的换成对应ARM的指令替换了就对了。如果有方向寄存器设置的作为一个。

使用特权

评论回复
9
捉虫天师| | 2016-10-12 23:31 | 只看该作者
只要把只子程序放在你的程序中并调用它就可以了

使用特权

评论回复
10
huangcunxiake| | 2016-10-13 20:43 | 只看该作者
此程序结构性良好,具有极好的容错性

使用特权

评论回复
11
heisexingqisi| | 2016-10-15 22:27 | 只看该作者
EepromType为枚举变量,需为M2401至M24256中的一种,分别对应24C01至24C256

使用特权

评论回复
12
zhuomuniao110|  楼主 | 2016-10-19 15:27 | 只看该作者
lovecat2015 发表于 2016-10-9 19:37
像这种eeprom读写速度有多快?

这些都快不了,很慢的。

使用特权

评论回复
13
ailingg| | 2017-11-11 11:54 | 只看该作者
本帖最后由 ailingg 于 2017-11-11 20:27 编辑

没有自动换页功能,一次写入不能超过一页字节数。

使用特权

评论回复
14
金创图| | 2017-11-11 11:59 | 只看该作者
需要烧写IC考虑一下金创图IC自动烧录机和代工烧录服务。
咨询:13670018818
微信:shop8199或13670018818

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

207

主题

3379

帖子

10

粉丝