📄 18b20.lst
字号:
C51 COMPILER V8.02 18B20 01/08/2009 15:59:33 PAGE 1
C51 COMPILER V8.02, COMPILATION OF MODULE 18B20
OBJECT MODULE PLACED IN 18b20.OBJ
COMPILER INVOKED BY: C:\Keil\C51\BIN\C51.EXE 18b20.c BROWSE DEBUG OBJECTEXTEND
line level source
1 //***********DS18B20数字温度计C程序****************//
2 //*MCU: AT89C51 //
3 //*MCU-crystal: 12M // //
4 //*Description: //
5 //DS18B20的读写程序,数据脚P3.4 //
6 //温度传感器18B20汇编程序,采用器件默认的12位转化 //
7 //最大转化时间750微秒,显示温度-55到+125度,显示精度 //
8 //为0.1度,显示采用4位LED共阳显示测温值 //
9 //P1口为段码输入,P0~P3为位选 //
10 /***************************************************/
11
12 #include "reg51.h"
13 #include "intrins.h" //_nop_();延时函数用
14 #define Disdata P0 //段码输出口
15 #define discan P2 //扫描口
16 #define uchar unsigned char
17 #define uint unsigned int
18 sbit DQ=P2^7; //温度输入口
19 sbit DIN=P0^7; //LED小数点控制
20 uint h;
21 uint temp;
22 //
23 //
24 //**************温度小数部分用查表法***********//
25 uint code dis_7[]={0x03,0x9F,0x25,0x0D,0x99,0x49,0x41,0x1F,0x01,0x09,0xfd};
26 uchar code ditab[16]=
27 {0x00,0x01,0x01,0x02,0x03,0x03,0x04,0x04,0x05,0x06,0x06,0x07,0x08,0x08,0x09,0x09};
28 //uchar code dis_7[12]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xff,0xbf};
29 //共阳LED段码表 "0" "1" "2" "3" "4" "5" "6" "7" "8" "9" "不亮" "-"
30 uchar code scan_con[4]={0xf7,0xfb,0xfd,0xfe}; //列扫描控制字
31 uchar data temp_data[2]={0x00,0x00}; //读出温度暂放
32 uchar data display[5]={0x00,0x00,0x00,0x00,0x00}; //显示单元数据,共4个数据和一个运算暂用
33
34 //
35 //
36 //
37 /*****************11us延时函数*************************/
38 //
39 void delay(uint t)
40 {
41 1 for (;t>0;t--);
42 1 }
43 //
44
45 /****************显示扫描函数***************************/
46 scan()
47 {
48 1 char k;
49 1 for(k=0;k<4;k++) //4位LED扫描控制
50 1 {
51 2 Disdata=dis_7[display[k]]; //数据显示
52 2 if (k==1){DIN=0;} //小数点显示
53 2 discan=scan_con[k]; //位选
54 2 delay(300);
55 2 }
C51 COMPILER V8.02 18B20 01/08/2009 15:59:33 PAGE 2
56 1 }
57 //
58 //
59 /****************DS18B20复位函数************************
60 ow_reset(void)
61 {
62 char presence=1;
63 while(presence)
64 {
65 while(presence)
66 {
67 DQ=1;_nop_();_nop_();//从高拉倒低
68 DQ=0;
69 delay(50); //550 us
70 DQ=1;
71 delay(6); //66 us
72 presence=DQ; //presence=0 复位成功,继续下一步
73 }
74 delay(45); //延时500 us
75 presence=~DQ;
76 }
77 DQ=1; //拉高电平
78 }*/
79
80 //上面的复位可以
81
82 //复位函数
83 void ow_reset()
84 {
85 1 DQ = 0;
86 1 delay(48);//此处延时严格>480us
87 1 DQ = 1;
88 1 //delay(3);//此处可要也可不要!
89 1 while(DQ);
90 1 delay(5);
91 1 DQ=1;
92 1 //delay(29);
93 1 }
94 //
95 //
96 /****************DS18B20写命令函数************************/
97 //向1-WIRE 总线上写1个字节
98 void write_byte(uchar val)
99 {
100 1 uchar i;
101 1 for(i=8;i>0;i--)
102 1 {
103 2 DQ=1;_nop_();_nop_(); //从高拉倒低
104 2 DQ=0;_nop_();_nop_();_nop_();_nop_(); //5 us
105 2 DQ=val&0x01; //最低位移出
106 2 delay(5); //55 us 15us~120us
107 2 val=val/2; //右移1位
108 2 }
109 1 DQ=1;
110 1 delay(1);
111 1 }
112 //
113 /****************DS18B20读1字节函数************************/
114 //从总线上取1个字节
115 uchar read_byte(void)
116 {
117 1 uchar i;
C51 COMPILER V8.02 18B20 01/08/2009 15:59:33 PAGE 3
118 1 uchar value=0;
119 1 for(i=8;i>0;i--)
120 1 {
121 2 DQ=1;_nop_();_nop_();
122 2 value>>=1;
123 2 DQ=0;_nop_();_nop_();_nop_();_nop_(); //4 us
124 2 DQ=1;_nop_();_nop_();_nop_();_nop_(); //4 us
125 2 if(DQ)value|=0x80;
126 2 delay(6); //66 us
127 2 }
128 1 DQ=1;
129 1 return(value);
130 1 }
131 //
132 /****************读出温度函数************************/
133 //
134 read_temp()
135 {
136 1 ow_reset(); //总线复位
137 1 delay(200); //此处的延时必须要加?????????????????????????????????????
138 1 write_byte(0xcc); //发命令
139 1 write_byte(0x44); //发转换命令
140 1 ow_reset();
141 1 delay(1);
142 1 write_byte(0xcc); //发命令
143 1 write_byte(0xbe);
144 1 temp_data[0]=read_byte(); //读温度值的第字节
145 1 temp_data[1]=read_byte(); //读温度值的高字节
146 1 temp=temp_data[1];
147 1 temp<<=8;
148 1 temp=temp|temp_data[0]; // 两字节合成一个整型变量。
149 1 return temp; //返回温度值
150 1 }
151 //
152 /****************温度数据处理函数************************/
153
154 //二进制高字节的低半字节和低字节的高半字节组成一字节,这个
155 //字节的二进制转换为十进制后,就是温度值的百、十、个位值,而剩
156 //下的低字节的低半字节转化成十进制后,就是温度值的小数部分
157
158 /********************************************************/
159 work_temp(uint tem)
160 {
161 1 uchar n=0;
162 1 if(tem>6348) // 温度值正负判断
163 1 {tem=65536-tem;n=1;} // 负温度求补码,标志位置1
164 1 display[4]=tem&0x0f; // 取小数部分的值
165 1 display[3]=ditab[display[4]]; // 存入小数部分显示值
166 1 display[4]=tem>>4; // 取中间八位,即整数部分的值
167 1 display[0]=display[4]/100; // 取百位数据暂存
168 1 display[2]=display[4]%100; // 取后两位数据暂存
169 1 display[1]=display[2]/10; // 取十位数据暂存
170 1 display[2]=display[2]%10;
171 1 /******************符号位显示判断**************************/
172 1 if(!display[0])
173 1 {
174 2 display[0]=0x0a; //最高位为0时不显示
175 2 if(!display[2])
176 2 {
177 3 display[2]=0x0a; //次高位为0时不显示
178 3 }
179 2 }
C51 COMPILER V8.02 18B20 01/08/2009 15:59:33 PAGE 4
180 1 if(n){display[0]=0x0b;} //负温度时最高位显示"-"
181 1 }
182 //
183 //
184 /****************主函数************************/
185 main()
186 {
187 1 Disdata=0xff; //初始化端口
188 1 discan=0xff;
189 1 for(h=0;h<4;h++) //开机显示"8888"
190 1 {display[h]=8;}
191 1 ow_reset(); //开机先转换一次
192 1 write_byte(0xcc); //Skip ROM
193 1 write_byte(0x44); //发转换命令
194 1 for(h=0;h<100;h++) //开机显示"8888"
195 1 {scan();}
196 1 while(1)
197 1 {
198 2 work_temp(read_temp()); //处理温度数据
199 2 scan(); //显示温度值
200 2 }
201 1 }
202 //
203 //***********************结束**************************//
204
MODULE INFORMATION: STATIC OVERLAYABLE
CODE SIZE = 425 ----
CONSTANT SIZE = 42 ----
XDATA SIZE = ---- ----
PDATA SIZE = ---- ----
DATA SIZE = 11 ----
IDATA SIZE = ---- ----
BIT SIZE = ---- ----
END OF MODULE INFORMATION.
C51 COMPILATION COMPLETE. 0 WARNING(S), 0 ERROR(S)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -