📄 温度器(已成功显示).lst
字号:
C51 COMPILER V8.02 温度芲(_殉晒ο允_) 06/01/2007 22:24:04 PAGE 1
C51 COMPILER V8.02, COMPILATION OF MODULE 温度芲(_殉晒ο允_)
OBJECT MODULE PLACED IN 温度器(已成功显示).OBJ
COMPILER INVOKED BY: G:\8.02\C51\BIN\C51.EXE 温度器(已成功显示).c BROWSE DEBUG OBJECTEXTEND
line level source
1 #include <AT89X52.H>
2 #include <INTRINS.h>
3 unsigned char code Tab[]={0xff,0Xfd,0xff,0xfe,0xff,0xf7,0xff,0xfb,0xff,0xdf,0xff,0xef,0xff,0x7f,0xff,0xbf
-,
4 0Xfd,0xff,0xfe,0xff,0xf7,0xff,0xfb,0xff,0xdf,0xff,0xef,0xff,0x7f,0xff,0xbf,0xff
-};
5 unsigned char code codedisplay[]={0xFF,0xFF,0xFF,0xE7,0xDB,0xBD,0xBD,0xBD,0xBD,0xBD,0xBD,0xBD,0xDB,0xE7,0
-xFF,0xFF,/*"0",0*/
6 0xFF,0xFF,0xFF,0xEF,0x8F,0xEF,0xEF,0xEF,0xEF,0xEF,0xEF,0xEF,0xEF,0x83,0
-xFF,0xFF,/*"1",1*/
7 0xFF,0xFF,0xFF,0xC3,0xBD,0xBD,0xBD,0xFB,0xFB,0xF7,0xEF,0xDF,0xBD,0x81,0
-xFF,0xFF,/*"2",2*/
8 0xFF,0xFF,0xFF,0xC3,0xBD,0xBD,0xFB,0xE7,0xFB,0xFD,0xFD,0xBD,0xBB,0xC7,0xFF,0xFF,/*"3",3*/
9 0xFF,0xFF,0xFF,0xFB,0xF3,0xEB,0xDB,0xDB,0xBB,0xBB,0x81,0xFB,0xFB,0xE1,0
-xFF,0xFF,/*"4",4*/
10 0xFF,0xFF,0xFF,0x81,0xBF,0xBF,0xBF,0xA7,0x9B,0xFD,0xFD,0xBD,0xBB,0xC7,0
-xFF,0xFF,/*"5",5*/
11 0xFF,0xFF,0xFF,0xE3,0xDB,0xBF,0xBF,0xA7,0x9B,0xBD,0xBD,0xBD,0xDB,0xE7,0xFF,0xFF,/*"6",6*/
12 0xFF,0xFF,0xFF,0x81,0xBB,0xBB,0xF7,0xF7,0xEF,0xEF,0xEF,0xEF,0xEF,0xEF,0xFF,0xFF,/*"7",7*/
13 0xFF,0xFF,0xFF,0xC3,0xBD,0xBD,0xBD,0xDB,0xE7,0xDB,0xBD,0xBD,0xBD,0xC3,0xFF,0xFF,/*"8",8*/
14 0xFF,0xFF,0xFF,0xE7,0xDB,0xBD,0xBD,0xBD,0xD9,0xE5,0xFD,0xFD,0xDB,0xC7,0xFF,0xFF};/*"9",9*/
15
16
17
18 unsigned char m;
19 unsigned int result,count=0;
20 void delay(void)
21 { unsigned char i,j;
22 1 for(i=0;i<15;i++){ for(j=0;j<50;j++) ; }
23 1 }
24
25 unsigned char displaycount,x;
26 unsigned char displaybuf[8]={0,0,0,0,0,0,0,0};
27 unsigned char timecount;
28 unsigned char readdata[8];
29 unsigned long a,aa,bb;
30 sbit DQ=P2^6; //选P3.7口与DS18B20的数字信号输出端DQ相连
31 bit sflag;
32
33 bit resetpulse(void) //DS18B20初始化实现对DS18B20的复位
34 { unsigned char pre;
35 1 unsigned char i;
36 1 DQ=0; //发出复位脉冲,将数据线下拉480μS-960μS
37 1 for(i=220;i>0;i--); //(改!!!!!!!!!!!!!!!!!!!!)
38 1 DQ=1; //DS18B20等待15μS-60μS
39 1 for(i=60;i>0;i--);
40 1 pre=DQ;
41 1 for(i=150;i>0;i--);
42 1 return(pre); // DS18B20返回60μS-240μS存在低脉冲,判断是否准备好接受或发送数据
43 1 }
44
45 void writecommandtods18b20(unsigned char command) //写时序
46 {
47 1 unsigned char i;
48 1 unsigned char j;
C51 COMPILER V8.02 温度芲(_殉晒ο允_) 06/01/2007 22:24:04 PAGE 2
49 1
50 1 for(i=0;i<8;i++)
51 1 {
52 2 if((command & 0x01)==0) //写0时序
53 2 {
54 3 DQ=0; //拉低单总线至少60μS,保证DS18B20在15μS-45μS时可以正确地采样I/O总线上的低电平
55 3 for(j=35;j>0;j--);
56 3 DQ=1;
57 3 }
58 2 else //写1时序
59 2 {
60 3 DQ=0; //拉低单总线后,在15us之内就得释放
61 3 for(j=2;j>0;j--);
62 3 DQ=1;
63 3 for(j=33;j>0;j--);
64 3 }
65 2 command=_cror_(command,1);
66 2 }
67 1 }
68
69 unsigned char readdatafromds18b20(void) //读时序
70 {
71 1 unsigned char i;
72 1 unsigned char j;
73 1 unsigned char temp;
74 1
75 1 temp=0;
76 1 for(i=0;i<8;i++)
77 1 {
78 2 temp=_cror_(temp,1);
79 2 DQ=0; //单总线拉低后,读时序开始
80 2 _nop_();
81 2 _nop_();
82 2 DQ=1; //停止将数据线拉低,以读取数据
83 2 for(j=10;j>0;j--);
84 2 if(DQ==1)
85 2 {
86 3 temp=temp | 0x80;
87 3 }
88 2 else
89 2 {
90 3 temp=temp | 0x00;
91 3 }
92 2 for(j=20;j>0;j--); ////////////////////(改!!!!!!!!!!!!)
93 2 }
94 1 return(temp);
95 1 }
96
97
98
99 void main(void)
100 { SCON=0; P1=0;
101 1 //while(resetpulse()); //写前调用初始化程序对DS18B20复位
102 1 //writecommandtods18b20(0xcc); //单片DS18B20工作,跳过读ROM中64位地址的过程
103 1 //writecommandtods18b20(0x44); //启动DS18B20进行温度转化,将结果存入内部RAM中
104 1 while(1)
105 1 {
106 2 for(m=0;m<16;m++)
107 2 { SBUF=codedisplay[displaybuf[0]*16+m]; while(!TI) ; TI=0;
108 3 SBUF=codedisplay[displaybuf[1]*16+m]; while(!TI) ; TI=0;
109 3 SBUF=codedisplay[displaybuf[2]*16+m]; while(!TI) ; TI=0;
110 3 SBUF=codedisplay[displaybuf[3]*16+m]; while(!TI) ; TI=0;
C51 COMPILER V8.02 温度芲(_殉晒ο允_) 06/01/2007 22:24:04 PAGE 3
111 3 SBUF=codedisplay[displaybuf[4]*16+m]; while(!TI) ; TI=0;
112 3 SBUF=codedisplay[displaybuf[5]*16+m]; while(!TI) ; TI=0;
113 3 SBUF=codedisplay[displaybuf[6]*16+m]; while(!TI) ; TI=0;
114 3 SBUF=codedisplay[displaybuf[7]*16+m]; while(!TI) ; TI=0;
115 3 //P2_0=0;P2_1=0;P2_1=1;P2_1=0;P2_0=1;
116 3 SBUF=Tab[2*m]; while(!TI) ; TI=0;
117 3 SBUF=Tab[2*m+1];while(!TI) ; TI=0;
118 3
119 3 P3_4=0;P3_4=1; P3_4=0;
120 3 delay();
121 3 count++;
122 3 if(count==600)
123 3 { count=0;
124 4 while(resetpulse()); //写前调用初始化程序对DS18B20复位
125 4 writecommandtods18b20(0xcc); //单片DS18B20工作,跳过读ROM中64位地址的过程
126 4 writecommandtods18b20(0xbe); // 读DS18B20RAM中温度数据
127 4 readdata[0]=readdatafromds18b20(); //温度数据低8位赋值
128 4 readdata[1]=readdatafromds18b20(); //温度数据高8位赋值
129 4 sflag=0;
130 4 if((readdata[1] & 0xf8)!=0x00) //温度数据高5位为1时,温度为负值
131 4 {
132 5 sflag=1;
133 5 readdata[1]=~readdata[1]; //对负温度值进行取反加1操作
134 5 readdata[0]=~readdata[0];
135 5 result=readdata[0]+1;
136 5 readdata[0]=result;
137 5 if(result>255)
138 5 {
139 6 readdata[1]++;
140 6 }
141 5 }
142 4 readdata[1]=readdata[1]&0x07; //将代表符号的高5位数屏蔽
143 4 aa=625;bb=(readdata[1]*256+readdata[0]);
144 4 a=bb*aa; //计算实际温度值
145 4
146 4
147 4
148 4 displaybuf[0]=a/100000; //给各显示位赋温度值
149 4 displaybuf[1]=a%100000/10000;
150 4 displaybuf[2]=a%10000/1000;
151 4 displaybuf[3]=a%1000/100;
152 4 displaybuf[4]=a%100/10;
153 4 displaybuf[5]=a%10;
154 4 while(resetpulse());
155 4 writecommandtods18b20(0xcc);
156 4 writecommandtods18b20(0x44);
157 4 }
158 3 }}}
159
160
161
162
163
164
MODULE INFORMATION: STATIC OVERLAYABLE
CODE SIZE = 838 ----
CONSTANT SIZE = 192 ----
XDATA SIZE = ---- ----
PDATA SIZE = ---- ----
DATA SIZE = 36 ----
C51 COMPILER V8.02 温度芲(_殉晒ο允_) 06/01/2007 22:24:04 PAGE 4
IDATA SIZE = ---- ----
BIT SIZE = 1 ----
END OF MODULE INFORMATION.
C51 COMPILATION COMPLETE. 0 WARNING(S), 0 ERROR(S)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -