找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4392|回复: 1
打印 上一主题 下一主题
收起左侧

AT24C0X掉电存储模块原理图+PCB工程+单片机源码

[复制链接]
跳转到指定楼层
楼主
Altium Designer画的AT24C08掉电存储模块原理图和PCB图如下:(51hei附件中可下载工程文件)

ATMEL24C08掉电存储模块
简要说明:
一、尺寸:全长30mm宽15mm高10mm
二、主芯片:ATMEL24C08芯片
三、工作电压:直流5V
四、特点:电路简单实用,接线简单。
电路支持:ATMEL24C02\ ATMEL24C04\ ATMEL24C08\ ATMEL24C16\ ATMEL24C32.
适用场合:单片机学习、电子竞赛、产品开发、毕业设计。。。
【标注说明】
【参考原理图】
PCB尺寸图】

单片机源程序如下:
  1. #include <reg52.H>
  2. #include <stdio.h>
  3. #include <absacc.h>
  4. unsigned char code table[]={ 0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x40};
  5. signed char sec=1; //定义计数值,每过1 秒,sec加1
  6. unsigned int tcnt; //定时中断次数
  7. unsigned char jd=0;
  8. unsigned char gd=0;
  9. bit write=0; //写24C08 的标志;
  10. sbit gewei=P2^6; //个位选通定义
  11. sbit shiwei=P2^5; //十位选通定义
  12. sbit baiwei=P2^7; //百位选通定义
  13. sbit qianwei=P2^4; //千位选通定义
  14. sbit P10=P1^0;
  15. sbit P11=P1^1;
  16. sbit P12=P1^2;
  17. sbit P13=P1^3;
  18. sbit P14=P1^4;
  19. sbit P15=P1^5;
  20. sbit P16=P1^6;
  21. sbit P17=P1^7;
  22. sbit P30=P3^0;
  23. sbit P31=P3^1;
  24. sbit P32=P3^2;
  25. sbit P35=P3^5;



  26. sbit jia=P2^0;
  27. sbit jian=P2^1;
  28. sbit res=P2^2;

  29. /////////24C08 读写驱动程序////////////////////
  30. sbit scl=P3^3; // 24c08 SCL
  31. sbit sda=P3^4; // 24c08 SDA
  32. void delay1(unsigned char x)
  33. { unsigned int i;
  34. for(i=0;i<x;i++);
  35. ;}
  36. void flash()
  37. { ; ; }
  38. void x24c08_init() //24c08 初始化子程序
  39. {scl=1; flash(); sda=1;                     flash();}
  40. void start() //启动(I方C)总线
  41. {sda=1; flash(); scl=1; flash(); sda=0; flash(); scl=0; flash();}
  42. void stop() //停止(I方C)总线
  43. {sda=0; flash(); scl=1; flash(); sda=1; flash();}
  44. void writex(unsigned char j) //写一个字节
  45. { unsigned char i,temp;
  46. temp=j;
  47. for (i=0;i<8;i++)
  48. {temp=temp<<1; scl=0; flash(); sda=CY; flash(); scl=1; flash();}
  49. scl=0; flash(); sda=1; flash();
  50. }
  51. unsigned char readx() //读一个字节
  52. {
  53. unsigned char i,j,k=0;
  54. scl=0; flash(); sda=1;
  55. for (i=0;i<8;i++)
  56. {
  57. flash(); scl=1; flash();
  58. if (sda==1) j=1;
  59. else j=0;
  60. k=(k<<1)|j;
  61. scl=0;}
  62. flash(); return(k);
  63. }
  64. void clock() //(I方C)线时钟
  65. {
  66. unsigned char i=0;
  67. scl=1; flash();
  68. while ((sda==1)&&(i<255))i++;
  69. scl=0; flash();
  70. }
  71. ////////从24c02 的地址address 中读取一个字节数据/////
  72. unsigned char x24c08_read(unsigned char address)
  73. {
  74. unsigned char i;
  75. start(); writex(0xa0);
  76. clock(); writex(address);
  77. clock(); start();
  78. writex(0xa1); clock();
  79. i=readx(); stop();
  80. delay1(10);
  81. return(i);
  82. }
  83. //////向24c02 的address                     地址中写入一字节数据info/////
  84. void x24c08_write(unsigned char address,unsigned char info)
  85. {
  86. EA=0;
  87. start(); writex(0xa0);
  88. clock(); writex(address);
  89. clock(); writex(info);
  90. clock(); stop();
  91. EA=1;
  92. delay1(50);
  93. }
  94. /////////////24C08 读写驱动程序完/////////////////////
  95. void Delay(unsigned int tc) //延时程序
  96. {
  97. while( tc != 0 )
  98. {unsigned int i;
  99. for(i=0; i<100; i++);
  100. tc--;}
  101. }
  102. void LED() //LED显示函数
  103. {
  104. qianwei=0; P0=0xc0; Delay(3); qianwei=1;
  105. baiwei=0; P0=0xc0; Delay(3); baiwei=1;
  106. shiwei=0; P0=table[sec/10]; Delay(3); shiwei=1;
  107. gewei=0; P0=table[sec%10]; Delay(3); gewei=1;

  108. }

  109. void t0(void) interrupt 1 using 0 //定时中断服务函数
  110. {
  111. TH0=(65536-50000)/256; //对TH0 TL0 赋值
  112. TL0=(65536-50000)%256; //重装计数初值
  113. tcnt++; //每过250ust tcnt 加一
  114. if(tcnt==1) //计满20次(1 秒)时
  115. {
  116. tcnt=0; //重新再计
  117. write=1; //1 秒写一次24C08
  118. }
  119. }
  120. void main(void)
  121. {
  122. TMOD=0x01; //定时器工作在方式1
  123. ET0=1; EA=1;
  124. x24c08_init(); //初始化24C08
  125. sec=x24c08_read(2);//读出保存的数据赋于sec
  126. TH0=(65536-50000)/256;                     //对TH0 TL0 赋值
  127. TL0=(65536-50000)%256; //使定时器0.05 秒中断一次
  128. TR0=1; //开始计时*/

  129. while(1)
  130. {


  131. if(jia==0){Delay(8);   while(!jia){LED();}; {sec++;if(sec==36){sec=0;}} }
  132. if(jian==0){ Delay(8); while(!jian){LED();};{sec--;if(sec<0){sec=35;}} }
  133. if(res==0){sec=0;}
  134. switch(sec)
  135. {
  136. case 0:P1=0X81;P30=1;P31=1;P32=1;P35=1;break;
  137. case 1:P1=0X82;P30=1;P31=1;P32=1;P35=1;break;
  138. case 2:P1=0X84;P30=1;P31=1;P32=1;P35=1;break;
  139. case 3:P1=0X88;P30=1;P31=1;P32=1;P35=1;break;
  140. case 4:P1=0X90;P30=1;P31=1;P32=1;P35=1;break;
  141. case 5:P1=0XA0;P30=1;P31=1;P32=1;P35=1;break;
  142. case 6:P1=0X41;P30=1;P31=1;P32=1;P35=1;break;
  143. case 7:P1=0X42;P30=1;P31=1;P32=1;P35=1;break;
  144. case 8:P1=0X44;P30=1;P31=1;P32=1;P35=1;break;
  145. case 9:P1=0X48;P30=1;P31=1;P32=1;P35=1;break;
  146. case 10:P1=0X50;P30=1;P31=1;P32=1;P35=1;break;
  147. case 11:P1=0X60;P30=1;P31=1;P32=1;P35=1;break;
  148. case 12:P1=0XC1;P30=0;P31=1;P32=1;P35=1;break;
  149. case 13:P1=0XC2;P30=0;P31=1;P32=1;P35=1;break;
  150. case 14:P1=0XC4;P30=0;P31=1;P32=1;P35=1;break;
  151. case 15:P1=0XC8;P30=0;P31=1;P32=1;P35=1;break;
  152. case 16:P1=0XD0;P30=0;P31=1;P32=1;P35=1;break;
  153. case 17:P1=0XE0;P30=0;P31=1;P32=1;P35=1;break;
  154. case 18:P1=0XC1;P30=1;P31=0;P32=1;P35=1;break;
  155. case 19:P1=0XC2;P30=1;P31=0;P32=1;P35=1;break;
  156. case 20:P1=0XC4;P30=1;P31=0;P32=1;P35=1;break;
  157. case 21:P1=0XC8;P30=1;P31=0;P32=1;P35=1;break;
  158. case 22:P1=0XD0;P30=1;P31=0;P32=1;P35=1;break;
  159. case 23:P1=0XE0;P30=1;P31=0;P32=1;P35=1;break;
  160. case 24:P1=0XC1;P30=1;P31=1;P32=0;P35=1;break;
  161. case 25:P1=0XC2;P30=1;P31=1;P32=0;P35=1;break;
  162. case 26:P1=0XC4;P30=1;P31=1;P32=0;P35=1;break;
  163. case 27:P1=0XC8;P30=1;P31=1;P32=0;P35=1;break;
  164. case 28:P1=0XD0;P30=1;P31=1;P32=0;P35=1;break;
  165. case 29:P1=0XE0;P30=1;P31=1;P32=0;P35=1;break;
  166. case 30:P1=0XC1;P30=1;P31=1;P32=1;P35=0;break;
  167. case 31:P1=0XC2;P30=1;P31=1;P32=1;P35=0;break;
  168. case 32:P1=0XC4;P30=1;P31=1;P32=1;P35=0;break;
  169. case 33:P1=0XC8;P30=1;P31=1;P32=1;P35=0;break;
  170. case 34:P1=0XD0;P30=1;P31=1;P32=1;P35=0;break;
  171. case 35:P1=0XE0;P30=1;P31=1;P32=1;P35=0;break;
  172. default:break;
  173. }
  174. LED();
  175. if(write==1) //判断计时器是否计时一秒
  176. {
  177. write=0; //清零
  178. x24c08_write(2,sec); //在24c08 的地址2 中写入数据sec
  179. }
  180. }
  181. }
复制代码

所有资料51hei提供下载:

掉电存储模块DXP资料.rar

54.42 KB, 下载次数: 25, 下载积分: 黑币 -5

ATMEGAL24C08掉电存储模块设计产品使用手册.doc

3.78 MB, 下载次数: 18, 下载积分: 黑币 -5

掉电存储模块原理图.doc

23.5 KB, 下载次数: 19, 下载积分: 黑币 -5

掉电存储模块测试程序.rar

27.44 KB, 下载次数: 21, 下载积分: 黑币 -5

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:194257 发表于 2018-2-24 09:01 | 只看该作者
EEPROM的擦写次数是有限的,每秒写一次的话很快就会导致EEPROM失效的,最好的办法是用一颗大电容或者法拉电容,单片机检测到掉电后利用大电容或者法拉电容的电将资料保存到EEPROM中去。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表