如何采用51单片机连接24C02-C语言测试代码

发布者:EnchantingEyes最新更新时间:2020-05-23 来源: eefocus关键字:51单片机  24C02  测试代码 手机看文章 扫描二维码
随时随地手机看文章

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

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


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


主机作为发送端等待应答

如何采用51单片机连接24C02-C语言测试代码

SDA=1;

SCL=1;

while(SDA);

SCL=0;

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

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

SCL=1;

SCL=0;

SDA=1;


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


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


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


1 #include

2

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

4

5

6 sbit SDA=P2^0;

7 sbit SCL=P2^1;

8 //内部使用的函数

9 bit start(unsigned char dev);

10 void stop(void);

11 bit write_byte(unsigned char dat);

12 unsigned char read_byte(bit ack);

13 void waitack(void);

14 //外部使用

15 void writes(unsigned char address,unsigned char dat[],unsigned char num);

16 void reads(unsigned char address,unsigned char dat[],unsigned char num);

17 unsigned char read(unsigned char address);

18 void write(unsigned char address,unsigned char dat);

19 unsigned char readnext(void);

20

21 /*数码管部分*/

22 sbit du=P2^6;

23 sbit we=P2^7;

24 void display(void);

25 void delayms(unsigned time);

26 unsigned char code table[]={

27 0x3f,0x06,0x5b,0x4f,

28 0x66,0x6d,0x7d,0x07,

29 0x7f,0x6f,0x77,0x7c,

30 0x39,0x5e,0x79,0x71};

31 unsigned char num[6]={0};

32

33

34 void main(void)

35 {

36 //测试用数据

37 unsigned char a[9]={2,3,5,7,13,15,11,4,8};

38 unsigned char b[13]={0};

39

40 RST=0; //关闭ds1302消除影响

41

42 write(11,6);

43 write(12,1);

44 writes(2,a,9);

45 b[9]=readnext(); //b[9]=6

46 b[10]=readnext(); //b[10]=1

47 reads(2,b,9); //b[0-8]=a[0-8]

48 b[11]=readnext(); //b[11]=6

49 b[12]=read(12); //b[12]=1

50

51 num[5]=b[3];

52 num[4]=b[6];

53 num[3]=b[9];

54 num[2]=b[10];

55 num[1]=b[11];

56 num[0]=b[12];

57

58 while(1)

59 {

60 display();

61 }

62 }

63

64 //传入设备地址,返回设备是否应答

65 bit start(unsigned char dev)

66 {

67 SDA=1;

68 SCL=1;

69 SDA=0;

70 SCL=0;

71 return write_byte(dev);

72 }

73

74 void stop(void)

75 {

76 SDA=0;

77 SCL=1;

78 SDA=1;

79 }

80

81 //传入要写入的字节,返回设备是否应答

82 bit write_byte(unsigned char dat)

83 {

84 unsigned char i=8;

85 bit ack;

86 while(i--)

87 {

88 dat《《=1;

89 SDA=CY;

90 SCL=1;

91 SCL=0;

92 }

93 SDA=1; //接收设备应答

94 SCL=1;

95 ack=~SDA;

96 SCL=0;

97 return ack;

98 }

99

100 //在写入后等待24c02完成内部写入

101 //恢复响应的时间为手册中的twr

102 void waitack(void)

103 {

104 while(!start(0xa0));

105 stop();

106 }

107

108 //传入是否应答设备,返回读取的字节

109 unsigned char read_byte(bit ack)

110 {

111 unsigned char i=8,ret;

112

113 while(i--)

114 {

115 ret《《=1;

116 SCL=1;

117 ret|=SDA;

118 SCL=0;

119 }

120 SDA=~ack; //应答或不应答设备

121 SCL=1;

122 SCL=0;

123 SDA=1; //应答时要注意的时序

124 return ret;

125 }

126

127 //传入写入地址,数组,写入字节数

128 //函数自动进行分页写入

129 void writes(unsigned char address,unsigned char dat[],unsigned char num)

130 {

131 unsigned char i;

132

133 for(i=0;i

134 {

135 start(0xa0);

136 write_byte(address);

137 do

138 write_byte(dat[i++]);

139 while(++address&0x07 && i

140 stop();

141 waitack(); //延时等待以完成内部写入

142 }

143 }

144

145 //传入读取地址,接收用的数组,读取字节数

146 void reads(unsigned char address,unsigned char dat[],unsigned char num)

147 {

148 unsigned char i;

149

150 start(0xa0);

151 write_byte(address);

152

153 start(0xa1);

154

155 for(i=0;i

156 dat[i]=read_byte(1);

157

158 dat[i]=read_byte(0);

159 stop();

160 }

161

162 void write(unsigned char address,unsigned char dat)

163 {

164 writes(address,&dat,1);

165 }

166

167 unsigned char read(unsigned char address)

168 {

169 unsigned char ret;

170 reads(address,&ret,1);

171 return ret;

172 }

173

174 //对应手册中的Current Read

175 unsigned char readnext(void)

176 {

177 unsigned char ret;

178 start(0xa1);

179 ret=read_byte(0);

180 stop();

181 return ret;

182 }

183

184 void delayms(unsigned TIme)

185 {

186 unsigned i,j;

187

188 for(i=TIme;i》0;i--)

189 for(j=110;j》0;j--)

190 ;

191 }

192

193 void display(void)

194 {

195 unsigned char i;

196

197 for(i=0;i《6;i++)

198 {

199 P0=0;

200 du=1;

201 du=0;

202

203 P0=~(0x20》》i);

204 we=1;

205 we=0;

206

207 P0=table[num[i]];

208 du=1;

209 du=0;

210

211 delayms(1);

212 }

213 }

关键字:51单片机  24C02  测试代码 引用地址:如何采用51单片机连接24C02-C语言测试代码

上一篇:基于51单片机可修改错误功能的计算器工作原理解析
下一篇:基于51单片机对1602液晶板的并行操作

推荐阅读最新更新时间:2024-11-17 17:34

51单片机与递归的问题
在C51中,中断和非中断函数调用同一个函数报警就是RECURSIVE CALL TO FUNCTION。 标准C语言是在堆栈中动态生成局部变量空间,所以可以递归的。 51单片机太弱了,为了提高运行效率,C51采用静态分配局部变量的方式,所以不可递归。 被中断和非中断函数调用的函数,如果在非中断状态运行,发生中断后,局部变量被破坏,中断结束后再执行就完全错误了,这个跟不能递归的原理是一样的,所以Keil也把他列为RECURSIVE CALL TO FUNCTION。 解决方式:在这个公用的函数加reentrant修饰为可重入的。
[单片机]
51单片机的内部结构及其功能作用
中央处理器(CPU): 刚跟大家讲过,需要提醒的是MCS-51的CPU能处理8位二进制数或代码。CPU是单片机的主要核心部件,在CPU里面包含了运算器、控制器以及若干寄存器等部件给成。 内部数据存储器(RAM): MCS-51单片机芯片共有256个RAM单元,其中后128单元被专用寄存器占用(稍后我们详解),能作为寄存器供用户使用的只是前128单元,用于存放可读写的数据。因此通常所说的内部数据存储器就是指前128单元,简称内部RAM。地址范围为00H~FFH(256B)。是一个多用多功能数据存储器,有数据存储、通用工作寄存器、堆栈、位地址等空间。 内部程序存储器(ROM): 在前面也已讲过,MCS-51内部有4KB/
[单片机]
<font color='red'>51单片机</font>的内部结构及其功能作用
C51单片机程序编写注意事项
1.特殊功能寄存器的操作注意事项 在操作特殊功能寄存器时,要注意其他各位的影响。 例如,TMOD定时器的操作。 它控制定时器0和定时器1,高四位控制定时器1,低四位控制定时器0。当我们用字节操作其内容时,一次赋值就是改变其八位的全部内容,。此时,若定时器0在另一个函数中应用,经过次操作就改变了定时器0的内容,是不允许的。所以,最好用位操作的方式。 例: 字节操作:TMOD = 0x01; 改为: 位操作: TMOD |= 0x01;TMOD &= 0xfd; 2.定时器定时的计算: 要定时NS,那么, NS = T * (NT / TSOC ) NS:N秒,NT:是几T的单片机,例如51是12T的,那么NT =
[单片机]
51单片机串口通讯详解
串口,作为单片机程序开发中最常用、最方便,也是应用最广泛的程序调试方法;无论是作为调试工具,打印出调试信息,还是对功能模块进行通信,串口是每个单片机开发人员最常用的单片机外设。 由于大部分51单片机不支持在线调试功能,所以串口作为一种有效的调试功能,所以在51单片机程序开发时,无法进行在线调试,不妨可以多采用串口来进行调试。 1.串口配置 51单片机配置除了需要配置2个8位寄存器SCON、PCON外,还要配置定时器1的控制寄存器TMOD,因为串口在进行收发需要使用定时器来采样。 (1)状态控制寄存器 SCON SCON 是一个逐位定义的 8 位寄存器,用于控制串行通信的方式选择、接收和发送,指 示串口的状态,SCO
[单片机]
<font color='red'>51单片机</font>串口通讯详解
新 MATLAB Test 使工程师和研究人员能大规模开发、执行、测量和管理 MATLAB 代码中的动态测试
新的 MATLAB Test 使工程师和研究人员能够大规模开发、执行、测量和管理 MATLAB 代码中的动态测试 MATLAB 和 Simulink 版本 2023a 还包括全新的与更新的模块集及工具箱,可简化航空航天、汽车和无线通信行业中基于模型的设计 中国 北京,2023 年 3 月 22 日 —— MathWorks 今天发布了 MATLAB® 和 Simulink® 产品系列版本 2023a(R2023a)。 R2023a 推出了两款新产品和增强功能,支持工程师和研究人员开发、执行、管理、测试、验证其 MATLAB 代码工程,并生成相关文档。 MATLAB Test™ 使工程师和研究人员能够大规模开发、执行、测
[工业控制]
8051单片机中DPTR的扩展设计
   摘要 首先对比分析在执行大规模数据转移时,传统805l单片机和进行DPTR扩展后的805l单片机在数据转移执行效率上的差别。通过详细分析DPTR操作所涉及的因素,具体实现对DPTR的扩展,并进行实际仿真测试。   单片机的出现是计算机技术发展史上的一个里程碑,它使计算机从海量数值计算进入到控制领域。在单片机中,以8051系列最为经典,至今仍是最普及、广泛使用的8位MUC架构。北界许多技术人员在其基础上不断进行性能扩展,使得805l系列芯片不断完善,从而形成一个庞大的体系。在传统的8051系列单片机中,设置了一组双字节寄存器(数据指针DPTR),用于访问外接的64 KB数据存储器和I/O接口电路;但在现今的8051单片机应用
[单片机]
51单片机pwm信号模拟
适用所有单片机,晶振为11.0592M #include reg52.h int pwm1=1; 第一路pwm占空比 int pwm2=60; 第二路pwm占空比 sbit led1=P1^0; sbit led2=P1^3; sbit md1=P1^0; void pwm_init() { TMOD|=0x01; TH0=(65536-100)/256; 约1Kmz TL0=(65536-100)%256; ET0=1; EA=1; TR0=1; } void pwm_timer()interrupt 1 { static int c1=0,c2=0; TH0=(65536-100)/256;
[单片机]
C51单片机学习——8×8LED点阵屏学习笔记
1.8×8LED点阵屏电路图 8×8LED点阵屏由8行8列共64个LED灯组成。 通过控制其中部分LED灯亮可以组成图形或者数字,和数码管类似。 点阵分为共阳极和共阴极,行控制线接的LED阳极的点阵称为共阳极点阵,行控制线接的LED阴极的点阵称为共阴极点阵。 如何点亮LED灯:正极给高电平,负极给低电平 2.74HC595芯片 芯片查询链接 管脚说明: 3.点阵模块电路图 4.开发板1602液晶接口电路原理图 5.实践编程 ①显示一个点 参考程序: #include sbit DIO = P3^4; sbit SCK = P3^5; sbit RCK = P3^6; void mian()
[单片机]
C<font color='red'>51单片机</font>学习——8×8LED点阵屏学习笔记
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved