忙了一天多终于透彻了,自己写的不好使,用别人的逐步分析改成自己的,我写得非常简洁易懂。

我总结3点需要注意的地方

1.关闭非IIC通信器件,比如我的开发板SDA和SCL也连接了DS1302,造成干扰会没有结果。

2.IIC通信的应答,发送端在SCL为0时将SDA置1,等待接收端拉低SDA;接收端在拉低SDA持续一个周期后,应将SDA置1释放总线。

主机作为发送端等待应答

SDA=1;
SCL=1;
while(SDA);
SCL=0;

主机作为接收端,进行应答或不应答

SDA=0;    //不应答则为1
SCL=1;
SCL=0;
SDA=1;

3.24C02在写入周期完成后还有有内部写入时间Twr,所以可以查手册加入适当时间的延时函数,或者使用查询应答的方式进行延时等待。

总之,关键是注意参考数据手册及IIC总线规范,尤其是芯片的特别说明以及时序的控制,再结合代码就能弄懂了。

下面是我写的代码,用上了所有的功能,包括 Current Read 对应的函数 readnext() 。多字节写入时不用考虑分页问题,函数自动解决,直接给数组即可。使用数码管显示结果。

 #include<reg52.h>

 sbit RST=P2^;    //用来关闭ds1302

 sbit SDA=P2^;
sbit SCL=P2^;
//内部使用的函数
bit start(unsigned char dev);
void stop(void);
bit write_byte(unsigned char dat);
unsigned char read_byte(bit ack);
void waitack(void);
//外部使用
void writes(unsigned char address,unsigned char dat[],unsigned char num);
void reads(unsigned char address,unsigned char dat[],unsigned char num);
unsigned char read(unsigned char address);
void write(unsigned char address,unsigned char dat);
unsigned char readnext(void); /*数码管部分*/
sbit du=P2^;
sbit we=P2^;
void display(void);
void delayms(unsigned time);
unsigned char code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
unsigned char num[]={}; void main(void)
{
//测试用数据
unsigned char a[]={,,,,,,,,};
unsigned char b[]={}; RST=; //关闭ds1302消除影响 write(,);
write(,);
writes(,a,);
b[]=readnext(); //b[9]=6
b[]=readnext(); //b[10]=1
reads(,b,); //b[0-8]=a[0-8]
b[]=readnext(); //b[11]=6
b[]=read(); //b[12]=1 num[]=b[];
num[]=b[];
num[]=b[];
num[]=b[];
num[]=b[];
num[]=b[]; while()
{
display();
}
} //传入设备地址,返回设备是否应答
bit start(unsigned char dev)
{
SDA=;
SCL=;
SDA=;
SCL=;
return write_byte(dev);
} void stop(void)
{
SDA=;
SCL=;
SDA=;
} //传入要写入的字节,返回设备是否应答
bit write_byte(unsigned char dat)
{
unsigned char i=;
bit ack;
while(i--)
{
dat<<=;
SDA=CY;
SCL=;
SCL=;
}
SDA=; //接收设备应答
SCL=;
ack=~SDA;
SCL=;
return ack;
} //在写入后等待24c02完成内部写入
//恢复响应的时间为手册中的twr
void waitack(void)
{
while(!start(0xa0));
stop();
} //传入是否应答设备,返回读取的字节
unsigned char read_byte(bit ack)
{
unsigned char i=,ret; while(i--)
{
ret<<=;
SCL=;
ret|=SDA;
SCL=;
}
SDA=~ack; //应答或不应答设备
SCL=;
SCL=;
SDA=; //应答时要注意的时序
return ret;
} //传入写入地址,数组,写入字节数
//函数自动进行分页写入
void writes(unsigned char address,unsigned char dat[],unsigned char num)
{
unsigned char i; for(i=;i<num;)
{
start(0xa0);
write_byte(address);
do
write_byte(dat[i++]);
while(++address&0x07 && i<num); //分页条件判断
stop();
waitack(); //延时等待以完成内部写入
}
} //传入读取地址,接收用的数组,读取字节数
void reads(unsigned char address,unsigned char dat[],unsigned char num)
{
unsigned char i; start(0xa0);
write_byte(address); start(0xa1); for(i=;i<num-;i++)
dat[i]=read_byte(); dat[i]=read_byte();
stop();
} void write(unsigned char address,unsigned char dat)
{
writes(address,&dat,);
} unsigned char read(unsigned char address)
{
unsigned char ret;
reads(address,&ret,);
return ret;
} //对应手册中的Current Read
unsigned char readnext(void)
{
unsigned char ret;
start(0xa1);
ret=read_byte();
stop();
return ret;
} void delayms(unsigned time)
{
unsigned i,j; for(i=time;i>;i--)
for(j=;j>;j--)
;
} void display(void)
{
unsigned char i; for(i=;i<;i++)
{
P0=;
du=;
du=; P0=~(0x20>>i);
we=;
we=; P0=table[num[i]];
du=;
du=; delayms();
}
}

24C02.c

最新文章

  1. goldengate studio 12.2.1.2.6发布
  2. 性能调优:理解Set Statistics IO输出
  3. osg 纹理访问器
  4. (三)在js(jquery)中获得文本框焦点和失去焦点的方法
  5. MySQL 备份和恢复
  6. MITK Tutorial
  7. isEmpty()与equals()、==“”区别
  8. NOI2013 Day1
  9. .NET获取客户端的操作系统、IP地址、浏览器版本
  10. 多线程(五) java的线程锁
  11. java基础知识6-- 抽象类,抽象方法,接口,构造方法,类方法等易混淆的知识点
  12. Scrapy爬虫框架第八讲【项目实战篇:知乎用户信息抓取】--本文参考静觅博主所写
  13. vim命令编辑Host文件
  14. JS函数&amp;DOM
  15. opencv模板匹配有趣的链接
  16. Win10 Fn键切换
  17. 高级数据库技术SQL
  18. Python可视化库
  19. 【NOI2013】树的计数
  20. Html5使用history对象history.pushState()和history.replaceState()方法添加和修改浏览历史记录

热门文章

  1. 【实习记】2014-09-04浏览代码查middle资料+总结我折腾过的源码浏览器
  2. 使用sqlmap注入DVWA的SQL Injection菜单
  3. js事件流、事件处理程序/事件侦听器
  4. Sass中的Map 详解
  5. 回答了个问题,9x9 乘法表生成器
  6. 将 Wing IDE 与 Maya 结合使用(摘自Maya用户指南)
  7. C语言-06复杂数据类型-01数组
  8. 树莓派-交叉编译环境搭建(Eclipse)
  9. Consistent Hashing原理与实现
  10. BZOJ 1634: [Usaco2007 Jan]Protecting the Flowers 护花