当前位置:首页 > 单片机 > 单片机
[导读]据说是AT24C01-AT24C256通用源程序,但按照我的经验,这个源程序仅适合AT24C04-AT24C256。/*Sample:/*main(){.../*ReadMem(l,x,y);/*读。l为本次访问的器件号,在宏定义时分配不同芯片的不同器件号,x为本次欲读出的

据说是AT24C01-AT24C256通用源程序,但按照我的经验,这个源程序仅适合AT24C04-AT24C256。


/*Sample:

/*main(){...

/*ReadMem(l,x,y);/*读。l为本次访问的器件号,在宏定义时分配不同芯片的不同

器件号,

x为本次欲读出的字节数;y为本次读数的起始地址*/

/*...

/*WriteMem(l,x,y);/*写。l为本次访问的器件号,在宏定义时分配不同芯片不同

的器件号,

x为本次欲写入的字节数;y为本次写数的起始地址,

注:当心页写入的地址规律,即页地址在同一页内滚动;否则会出现页溢出*/

/*}*/

#defineWait_1us{_nop_();_nop_();}

#defineWait_2us{Wait_1us;Wait_1us;}

#defineSla_Wr0xa0/*00000000*/

#defineSla_Rd0xa1/*00000001*/

#defineAT24C010x01

#defineAT24C01A0x02

#defineAT24C020x03

#defineAT24C040x04

#defineAT24C080x05

#defineAT24C160x06

#defineAT24C320x07

#defineAT24C640x08

#defineAT24C1280x09

#defineAT24C2560x0a

#defineAT24C5120x0b

#defineMem_SizeAT24C256//01/01A/02/04/08/16/32/64/128/256/512

#defineChip_10x00//本器件的器件地址,可以第一8个不同地址的芯片使之能用同一段程序进行读写

sbitbSda=P3^7;

sbitbScl=P3^6;

bitbScan_Err;

unsignedcharidatacShare_Buf[8]={0,1,2,3,4,5,6,7};//I2creadandwritebuffer

voidStart_I2c(void);

voidEnd_I2c(void);

unsignedcharScan_I2c();

voidSend_I2c(unsignedcharcData);

voidSend_Ack(void);

voidSend_Not_Ack(void);

voidWrite_Mem(unsignedcharcMem_Size,cChips_Address,cData_Size,unsignedint

cStart_Address);

voidRead_Mem(unsignedcharcMem_Size,cChips_Address,cData_Size,unsignedint

cStart_Address);

/************Name:ScanI2c***********

Function:read1bytefrom24C01/512

NO.:1

Runtime:79us1=4+2us0=5+1usf=111kbps/83.3Kbps

**********FunctionStart************/

voidStart_I2c(void)

{

unsignedchar/*idata*/i;

bSda=bScl=1;

for(i=0;i<2;i++);//wait7us

bSda=0;

for(i=0;i<2;i++);//wait7us

bScl=0;

}

/**********FunctionEnd*************/

/************Name:ScanI2c***********

Function:read1bytefrom24C01/512

NO.:1

Runtime:79us1=4+2us0=5+1usf=111kbps/83.3Kbps

**********FunctionStart************/

voidEnd_I2c(void)

{

unsignedchar/*idata*/i;

bSda=0;

bScl=1;

for(i=0;i<2;i++);//wait7us

bSda=1;

}

/**********FunctionEnd*************/

/************Name:ScanI2c***********

Function:read1bytefrom24C01/512

NO.:1

Runtime:79us1=3/5us0=1/5usf=250/100kbps

**********FunctionStart************/

unsignedcharScan_I2c()

{

unsignedchar/*idata*/i,j;//IICdata

bSda=1;

j=0;

for(i=0;i<8;i++)

{

bScl=1;

j<<=1;

Wait_2us;

j|=bSda;

//Scan0Scan1

bScl=0;

Wait_2us;

Wait_2us;

}

returnj;

}

/**********FunctionEnd*************/

/************Name:SendI2c***********

Function:Send1byteto24C01/512

NO.:2

Runtime:82us1=1/3us0=3usf=250/100kbps

**********FunctionStart************/

voidSend_I2c(unsignedcharcData)

{

unsignedchar/*idata*/i;

for(i=0;i<8;i++)

{

bSda=(bit)(cData&0x80);

bScl=1;

cData<<=1;

Wait_2us;

Wait_2us;

bScl=0;

Wait_2us;

}

bSda=bScl=1;//检测ACK

for(i=0;(bSda==1)&&(bScan_Err==0);i++)

{

if(i==30)

bScan_Err=1;//如果101us没有响应就错误

}

bScl=0;

}

/**********FunctionEnd************/

/************Name:SendAck***********

Function:Sendack

NO.:3

Runtime:10us+4us

**********FunctionStart************/

voidSend_Ack(void)

{

unsignedchar/*idata*/i;

bSda=0;

bScl=1;

for(i=0;i<2;i++);//wait8us

bScl=0;

bSda=1;

}

/**********FunctionEnd*************/

/************Name:SendNotAck***********

Function:sendnotack

NO.:4

Runtime:10us+4us

**********FunctionStart************/

voidSend_Not_Ack(void)

{

unsignedchar/*idata*/i;

bScl=bSda=1;

for(i=0;i<2;i++);//wait8us

bScl=0;

}

/**********FunctionEnd*************/

/************Name:WriteMem***********

Function:writedatato24C01/512

NO.:5

Runtime:80us(1byte)*cData_Size+

**********FunctionStart************/

voidWrite_Mem(unsignedcharcMem_Size,cChips_Address,cData_Size,unsignedintcStart_Address)

{

unsignedchar/*idata*/i,cAddress[2];//0-L;1-H

bScan_Err=0;

cAddress[0]=cStart_Address;

cStart_Address>>=8;

cAddress[1]=cStart_Address;

i=Sla_Wr;

i|=cChips_Address;

if(cMem_Size==AT24C256)

i&=0xf7;

Start_I2c();

Send_I2c(i);//SLA:1010xxx0

if(cMem_Size==AT24C256)//1-16用1个字节地址,32-512用2个字节地址,匹配地址AT24C32、64

Send_I2c(cAddress[1]);//先发送高字节地址

Send_I2c(cAddress[0]);//如果是双字节地址则为低地址否则为高地址

for(i=0;(bScan_Err==0)&&(i!=cData_Size);i++)

Send_I2c(cShare_Buf[i]);//写一个字节数据

End_I2c();

}

/**********FunctionEnd*************/

/************Name:ReadMem***********

Function:Readdatafrom24C01/512

NO.:6

Runtime:80us(1byte)*cData_Size+

**********FunctionStart************/

voidRead_Mem(unsignedcharcMem_Size,cChips_Address,cData_Size,unsignedintcStart_Address)

{

unsignedchar/*idata*/i,cAddress[2];

bScan_Err=0;

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

单片机内部有很多的特殊功能寄存器,每个寄存器在单片机内部都分配有唯一的地址,一般我们会根据寄存器功能的不同给寄存器赋予各自的名称,当我们需要在程序中操作这些特殊功能寄存器时,必须要在程序的最前面将这些名称加以声明,声明的...

关键字: C51 数据类型 扩充定义

数据元(Data Element),也称为数据元素,是用一组属性描述其定义、标识、表示和允许值的数据单元,在一定语境下,通常用于构建一个语义正确、独立且无歧义的特定概念语义的信息单元。数据元可以理解为数据的基本单元,将若...

关键字: C51 数据类型

▼点击下方名片,关注公众号▼欢迎关注【玩转单片机与嵌入式】公众号,回复关键字获取更多免费资料。回复【加群】,限时免费进入知识共享群;回复【3D封装库】,常用元器件的3D封装库;回复【电容】,获取电容、元器件选型相关的内容...

关键字: C51 MDK RealView

在Keil C51软件中51单片机的中断服务和外设驱动程序的开发

关键字: keil5 编译 C51

Intel公司1980年推出了MCS-51系列单片机:集成 8位CPU、4K字节ROM、128字节RAM、4个8位并口、1个全双工串行口、2个16位定时/计数器。寻址范围64K,并有控制功能较强的布尔处理器。 80C5...

关键字: C51 KEIL 编程

c上标3下标5怎么算用计算机,c上标3下标5怎么算

关键字: C51 KEIL

▼点击下方名片,关注公众号▼大家好,很高兴和各位一起分享我的第16篇原创文章,喜欢和支持我的工程师,一定记得给我点赞、收藏、分享。加微信[xyzn3333]与作者沟通交流,免费获取更多单片机与嵌入式的海量电子资料。很多初...

关键字: 51单片机 C51

常看见初学者要求使用_at_,这是一种谬误,把C当作ASM看待了。在C中变量的定位是编译器的事情,初学者只要定义变量和变量的作 用域,编译器就把一个固定地址给这个变量。

关键字: C51 单片机 误区 注意事项

简介:编程首要是要考虑程序的可行性,然后是可读性、可移植性、健壮性以及可测试性。这是总则。但是很多人忽略了可读性、可移植性和健壮性(可调试的方法可能歌不相同),这是不对的。

关键字: C51 编程规范 文件配置

如果你用 Keil C51 进行编译,记住一点:它不区分大小写!!!卧槽,今天编程序那个调错啊,就因为一个数组名和一个变量名完全一样,只是大小写不一样罢了,标准 C 我怎么记得这样可以啊……上网一查,卧槽,Keil C5...

关键字: C51 单片机 编程要点
关闭