找回密码
 立即注册

QQ登录

只需一步,快速开始

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

LM75温度传感器的单片机控制程序 带掉电保护功能

[复制链接]
跳转到指定楼层
楼主
ID:210244 发表于 2017-6-11 21:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
基于STC12C5A60S2芯片,有掉电保护程序

单片机源程序如下:
  1. //LM75温度控制器//
  2. //头文件
  3. #include<STC12C5A60S2.h>
  4. #include<intrins.h>
  5. //宏
  6. #define uchar unsigned char
  7. #define uint  unsigned int
  8. #define CONF   0X01  //配置寄存器
  9. #define TEMP   0X00  //温度寄存器只读
  10. #define ALARM  0X03  //超温关闭极限寄存器默认5000H
  11. #define DELAY  0X02  //滞后寄存器默认4B00H
  12. #define WADDR  0X90  //写地址
  13. #define RADDR  0X91  //读地址
  14. //////////////
  15. uchar code tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//共阴  段
  16.                                   //0,    1,   2   3    4    5    6    7    8    9
  17. uchar out[]={0x01,0x02,0x04,0x08};                   //位
  18. uchar discount=0;                                                               
  19. sbit sda=P3^5;
  20. sbit scl=P3^4;
  21. sbit os=P3^2;
  22. sbit key1=P1^0;
  23. sbit key2=P1^1;
  24. sbit key3=P1^4;
  25. sbit redled=P1^2;
  26. uint disshu=0;
  27. float tempchu;
  28. uchar tempcount=0;
  29. uint Tsettemp;
  30. bit dp=0;
  31. uchar dat;
  32. //IAP
  33. #define ENABLE_IAP 0X83
  34. #define IAP_ADDRESS 0X0000//定义EEPROM 的起始地址
  35. sfrIAP_DATA=0XC2;
  36. sfrIAP_ADDRH=0XC3;
  37. sfrIAP_ADDRL=0XC4;
  38. sfrIAP_CMD=0XC5;
  39. sfrIAP_TRIG=0XC6;
  40. sfrIAP_CONTR=0XC7;
  41. //*****************************************************//函数名
  42. void init(void);                                                                             //初始化
  43. void start(void);                                                                            //起始
  44. void stop(void);                                                                             //终止
  45. void ack(void);                                                                                     //应答
  46. void noack(void);                                                                             //非应答
  47. bit rack(void);                                                                                   //接受应答位
  48. void send(uchar date);                                                                   //发送数据 1字节
  49. uchar read(void);                                                                            //接受数据 1字节
  50. uchar w_config(uchar cdata);                                                   //写配置寄存器
  51. uchar Twendu(uchar Twd,uchar wen_high,uchar wen_low);  //高低温
  52. float read_16(uchar addr);                               //读2字节
  53. uchar read8(uchar adder);                                                           //读1字节
  54. void disseg(uint seg);                                                                   //显示
  55. void delay(void);                                                                            //5us
  56. void delay10ms(void);                                  //10us
  57. void delay500ms(void);                                 //500ms
  58. void kaishi(void);                                     //
  59. //AIP                                                                                                   //
  60. void iapidle();                                                                                   //AIP初始化函数
  61. uchar iapreadbyte(uint addr);                                                   //读EEPROM的一个字节地址的内容
  62. void iapprogrambyte(uint addr,uchar dat);                            //写一个字节的IAP/ISP/EEPROM空间
  63. void iaperasesector(uint addr);                                               //扇区擦除
  64. //*****************************************************//
  65. //初始化
  66. void init(void)
  67. {       
  68.         scl=1;
  69.         delay();
  70.         sda=1;
  71.         delay();
  72. }
  73. //起始
  74. void start(void)
  75. {
  76.         scl=1;
  77.         sda=1;
  78.         delay();
  79.         sda=0;
  80.         delay();
  81.         scl=0;
  82. }
  83. //终止
  84. void stop(void)
  85. {
  86.         scl=0;
  87.         sda=0;
  88.         delay();
  89.         scl=1;
  90.         delay();
  91.         sda=1;
  92.         delay();
  93.         sda=0;
  94. }
  95. //应答
  96. void ack(void)
  97. {
  98.         uchar a;
  99.         sda=0;
  100.         scl=1;
  101.         delay();
  102.         while(sda==1&&(a<255))
  103.         {
  104.                 a++;
  105.         }
  106.         scl=0;
  107.         delay();
  108. }
  109. //非应答
  110. void noack(void)
  111. {
  112.         sda=1;
  113.         scl=1;
  114.         delay();
  115.         scl=0;
  116.         sda=0;
  117. }
  118. //接受应答位
  119. bit rack(void)
  120. {
  121.         bit flag;
  122.         scl=1;
  123.         delay();
  124.         flag=sda;
  125.         scl=0;
  126.         delay();
  127.         return flag;
  128. }
  129. //发送数据 1字节
  130. void send(uchar date)
  131. {
  132.         uchar s,temp;
  133.         temp=date;
  134.         for(s=0;s<8;s++)
  135.         {
  136.                 temp=temp<<1;
  137.                 scl=0;
  138.                 delay();
  139.                 sda=CY;
  140.                 delay();
  141.                 scl=1;
  142.                 delay();
  143.         }
  144.         scl=0;
  145.         delay();
  146.         sda=1;
  147.         delay();
  148. }
  149. //接受数据 1字节
  150. uchar read(void)
  151. {
  152.         uchar s,temp;
  153.         scl=0;
  154.         delay();
  155.         sda=1;
  156.         for(s=0;s<8;s++)
  157.         {
  158.                 scl=1;
  159.                 delay();
  160.                 temp=(temp<<1)|sda;
  161.                 scl=0;
  162.                 delay();
  163.         }
  164.         delay();
  165.         return temp;
  166. }
  167. //写配置寄存器
  168. uchar w_config(uchar cdata)
  169. {
  170.         bit i=0;  
  171.         start();
  172.         send(WADDR);
  173.         i=rack();
  174.         if(i)
  175.         {  
  176.                 stop();
  177.                 return 0;
  178.         }   
  179.         send(CONF);
  180.         i=rack();
  181.         if(i)
  182.         {   
  183.                 stop();
  184.                   return 0;
  185.         }   
  186.         send(cdata);
  187.         i=rack();
  188.         if(i)
  189.         {        
  190.                 stop();  
  191.                   return 0;
  192.         }
  193.         delay();
  194.         stop();
  195. }
  196. //写2字节温度
  197. uchar Twendu(uchar Twd,uchar wen_high,uchar wen_low)
  198. {
  199.         bit i=0;
  200.         start();
  201.         send(WADDR);
  202.         i=rack();
  203.         if(i)
  204.         {  
  205.                 return 0;
  206.         }
  207.         send(Twd);
  208.         i=rack();
  209.         if(i)
  210.         {  
  211.                 return 0;
  212.         }
  213.         send(wen_high);
  214.         i=rack();
  215.         if(i)
  216.         {  
  217.                 return 0;
  218.         }
  219.         send(wen_low);
  220.         i=rack();
  221.         if(i)
  222.         {  
  223.                 return 0;
  224.         }
  225.         delay();
  226.         stop();   
  227. }
  228. //读16位
  229. float read_16(uchar addr)
  230. {
  231.         bit i=0;
  232.     float cun16;
  233.         uchar cun1,cun2;
  234.         start();
  235.         send(WADDR);
  236.         i=rack();
  237.         if(i)
  238.         {  
  239.                 stop();
  240.                 return 0;
  241.         }
  242.         send(addr);
  243.         i=rack();
  244.         if(i)
  245.         {
  246.                 stop();
  247.                 return 0;
  248.         }
  249.         start();
  250.         send(RADDR);
  251.         i=rack();
  252.         if(i)
  253.         {  
  254.                 stop();
  255.                 return 0;
  256.         }
  257.          cun1=read();// cun16=read();
  258.                      //cun16=cun16<<8;
  259.          ack();
  260.          cun2=read()>>7;           //cun16|=read();
  261.          noack();
  262.          delay();
  263.          stop();
  264.          if(cun1&0x80)
  265.         {
  266.                 dp=1;
  267.                 cun16=((~(cun1<<1))>>1+1)+cun2*0.5;
  268.         }
  269.         else
  270.         {
  271.                 dp=0;
  272.                 cun16=cun1+cun2*0.5;
  273.         }      
  274.      return cun16;       
  275. }
  276. uchar read8(uchar adder)
  277. {
  278.         uchar i,m;
  279.         start();
  280.         send(WADDR);
  281.         i=rack();
  282.         if(i)
  283.         {  
  284.                 return 0;
  285.         }
  286.         send(adder);
  287.         i=rack();
  288.         if(i)
  289.         {  
  290.                 return 0;
  291.         }
  292.         start();
  293.         send(RADDR);
  294.         i=rack();
  295.         if(i)
  296.         {  
  297.                 return 0;
  298.         }
  299.         m=read();
  300.         noack();
  301.         delay();
  302.         stop();
  303.         return m;
  304. }
  305. //************************************************IAP*************************************************************//
  306. void iapidle()                                                         //****初始化函数
  307. {
  308.         IAP_CONTR=0;                                                 //关闭IAP功能
  309.         IAP_CMD=0;                                                         //CMD寄存器初始化
  310.          IAP_TRIG=0;                                                 //清空触发寄存器
  311.         IAP_ADDRH=0X80;                                                 //数据指针指向非EEPROM区
  312.         IAP_ADDRL=0;                                                 //CLEAR IAP address to preventmisuse
  313. }
  314. uchar iapreadbyte(uint addr)                         //读EEPROM的一个字节地址的内容
  315. {
  316.         IAP_CONTR=ENABLE_IAP;                                 //设置IAP控制寄存器
  317.         IAP_CMD=1;                                                         //设置IAP的命令寄存器为读状态
  318.         IAP_ADDRL=addr;                                                 //设置EERPROM的低8位地址
  319.         IAP_ADDRH=addr>>8;
  320.         IAP_TRIG=0X5A;
  321.         IAP_TRIG=0XA5;
  322.         _nop_();
  323.         _nop_();
  324.         dat=IAP_DATA;
  325.         iapidle();
  326.         return dat;
  327. }
  328. void iapprogrambyte(uint addr,uchar dat) //写一个字节的IAP/ISP/EEPROM空间
  329. {
  330.         IAP_CONTR=ENABLE_IAP;                                 //打开IAP功能并设置等待时间
  331.         IAP_CMD=2;                                                         //设置写命令
  332.         IAP_ADDRL=addr;                                                 //设置字节地址低8位
  333.         IAP_ADDRH=addr>>8;                                         //设置字节地址的高8位
  334.         IAP_DATA=dat;                                                 //写内容
  335.         IAP_TRIG=0X5A;                                                  //发送触发命令1
  336.         IAP_TRIG=0XA5;                                                 //发送触发命令2
  337.         _nop_();                                                         //等待直到写操作完成   60us
  338.         iapidle();
  339. }
  340. void iaperasesector(uint addr)                         //扇区擦除
  341. {
  342.         IAP_CONTR=ENABLE_IAP;                             //开IAP功能并设置等待时间
  343.         IAP_CMD=3;                                                         //设置擦除命令
  344.         IAP_ADDRL=addr;
  345.         IAP_ADDRH=addr>>8;
  346.         IAP_TRIG=0x5a;
  347.         IAP_TRIG=0XA5;
  348.          _nop_();                                                          // 21ms
  349.         iapidle();
  350. }
  351. //************************************************IAP*************************************************************//
  352. void kaishi(void)
  353. {
  354.         P2M0 = 0xff;
  355.         P2M1 = 0x00;                  
  356.         P0M0 = 0xff;
  357.         P0M1 = 0x00;
  358.         TMOD = 0x11;
  359.         ET0 = 1;                                         //定时器中断允许
  360.         TR0 = 1;                                                //定时器0启动
  361.         TH0 = 0x3C;                                                           //定时器0初值      1Ms
  362.     TL0 = 0xb0;
  363.         ET1 = 1;                                         //定时器中断允许
  364.         TR1 = 1;                                                //定时器1启动
  365.         TH1 = 0xFC;                                                           //定时器1初值      1Ms
  366.     TL1 = 0x18;
  367.         EA=1;
  368. }
  369. void main(void)
  370. {
  371.         uchar xuhuan=0;
  372.         bit js=1;
  373.         uchar dat0;
  374.         bit fffz=0;
  375.         float Tset;
  376.         w_config(0x00);       
  377.         iapreadbyte(0x00);                                          //读数
  378.         dat0=dat;
  379.         Twendu(ALARM,dat0,0x00);
  380.         Twendu(DELAY,0x00,0x00);
  381.         kaishi();
  382.         while(1)
  383.         {
  384.                 if(!key1&&js)
  385.                 {
  386.                         delay10ms();
  387.                         if(!key1&&js)
  388.                         {
  389.                                 js=0;
  390.                                 TR0=0;
  391.                                 Tset=read_16(ALARM)*10;
  392.                                 Tsettemp=Tset;
  393.                                 xuhuan=1;
  394.                                 redled=1;
  395.                         }
  396.                 }
  397.                 while(xuhuan==1)
  398.                 {
  399.                         disshu=Tsettemp;
  400.                         if(!key2&&js)
  401.                         {
  402.                                 delay10ms();
  403.                                 if(!key2&&js)
  404.                                         {
  405.                                                 Tsettemp=Tsettemp+10;
  406.                                                 if(Tsettemp>=1500)
  407.                                                 {
  408.                                                    Tsettemp=1500;
  409.                                                 }
  410.                                                 js=0;
  411.                                         }                                       
  412.                         }
  413.                         if(!key3&&js)
  414.                         {
  415.                                 delay10ms();
  416.                                 if(!key3&&js)
  417.                                         {
  418.                                                 Tsettemp=Tsettemp-10;
  419.                                                 if(Tsettemp<=100)
  420.                                                 {
  421.                                                    Tsettemp=100;
  422.                                                 }
  423.                                                 js=0;
  424.                                         }
  425.                         }
  426.                         if(!key1&&js)
  427.                         {
  428.                                 delay10ms();
  429.                                 if(!key1&&js)
  430.                                 {
  431.                                         xuhuan=0;
  432.                                         TR0=1;
  433.                                         js=0;
  434.                                         dat=Tsettemp/10;
  435.                                         iaperasesector(0x00);                                 //擦除
  436.                                         iapprogrambyte(0x00,dat);         //写入
  437.                                         Twendu(ALARM,dat,0x00);
  438.          
  439.                                 }
  440.                         }
  441.                         if(key1&&key2&&key3)
  442.                         {
  443.                                 js=1;
  444.                         }                                               
  445.                 }
  446.                 if(key1&&key2&&key3)
  447.                 {
  448.                         js=1;
  449.                 }
  450.         }       
  451. }
  452. void timer0() interrupt 1                //1000us
  453. {
  454.         float huan=0;
  455.         float qing;
  456.     TH0=0x3c;
  457.     TL0=0xb0;
  458.         tempcount++;
  459.         if(tempcount==3)
  460.         {
  461.                 tempcount=0;
  462.                 huan=read_16(0x00);
  463.                 tempchu=huan*10;
  464.                 disshu=tempchu;
  465.         }
  466.         if((tempchu!=0)&&(Tsettemp!=0))
  467.         {
  468.                 if(tempchu>=Tsettemp)
  469.                 {
  470.                         redled=0;
  471.                 }
  472.         }
  473. }
  474. void timer1() interrupt 3                //1000us
  475. ……………………

  476. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
LM75温度传感器.rar (2.89 KB, 下载次数: 29)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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