DSB详细使用方法Word格式.doc
《DSB详细使用方法Word格式.doc》由会员分享,可在线阅读,更多相关《DSB详细使用方法Word格式.doc(10页珍藏版)》请在冰豆网上搜索。
4.DS18B20的使用方法
由于DS18B20采用的是1-Wire总线协议方式,即在一根数据线实现数据的双向传输,而对AT89S51单片机来说,硬件上并不支持单总线协议,因此,我们必须采用软件的方法来模拟单总线的协议时序来完成对DS18B20芯片的访问。
由于DS18B20是在一根I/O线上读写数据,因此,对读写的数据位有着严格的时序要求。
DS18B20有严格的通信协议来保证各位数据传输的正确性和完整性。
该协议定义了几种信号的时序:
初始化时序、读时序、写时序。
所有时序都是将主机作为主设备,单总线器件作为从设备。
而每一次命令和数据的传输都是从主机主动启动写时序开始,如果要求单总线器件回送数据,在进行写命令后,主机需启动读时序完成数据接收。
数据和命令的传输都是低位在先。
DS18B20的复位时序
DS18B20的读时序
对于DS18B20的读时序分为读0时序和读1时序两个过程。
对于DS18B20的读时隙是从主机把单总线拉低之后,在15秒之内就得释放单总线,以让DS18B20把数据传输到单总线上。
DS18B20在完成一个读时序过程,至少需要60us才能完成。
DS18B20的写时序
对于DS18B20的写时序仍然分为写0时序和写1时序两个过程。
对于DS18B20写0时序和写1时序的要求不同,当要写0时序时,单总线要被拉低至少60us,保证DS18B20能够在15us到45us之间能够正确地采样IO总线上的“0”电平,当要写1时序时,单总线被拉低之后,在15us之内就得释放单总线。
DS18B20应用电路图
用一片DS18B20构成测温系统,测量的温度精度达到0.1度,测量的温度的范围在-20度到+100度之间,用8位数码管显示出来。
下图是采用AT89C2051的测温系统硬件原理图.
DS18B20与AT89C2051组成的测温系统源程序
用一片DS18B20构成测温系统,测量的温度精度达到0.1度,测量的温度的范围在-20度到+100度之间,用8位数码管显示出来。
下面是采用AT89C2051单片机与DS18B20的测温系统C语言源程序,硬件电路请参考本站相关文章.
#INclude<
AT89X52.H>
#INclude<
INTRINS.H>
UnsignedCharCodeDisplaybit[]={0xfe,0xfd,0xfb,0xf7,
0xef,0xdf,0xbf,0x7f};
UnsignedCharCodeDisplaycode[]={0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71,0x00,0x40};
UnsignedCharCodeDotcode[32]={0,3,6,9,12,16,19,22,
25,28,31,34,38,41,44,48,
50,53,56,59,63,66,69,72,
75,78,81,84,88,91,94,97};
UnsignedCharDisplaycount;
UnsignedCharDisplaybuf[8]={16,16,16,16,16,16,16,16};
UnsignedCharTimecount;
UnsignedCharReaddata[8];
SbitDQ=P3^7;
BitSflag;
BitResetpulse(Void)
{
UnsignedCharI;
DQ=0;
For(I=255;
I>
0;
I--);
DQ=1;
For(I=60;
Return(DQ);
For(I=200;
}
VoidWritecommandtods18b20(UnsignedCharCommand)
{
UnsignedCharJ;
For(I=0;
I<
8;
I++)
{
If((Command&
0x01)==0)
{
DQ=0;
For(J=35;
J>
J--);
DQ=1;
}
Else
{
DQ=0;
For(J=2;
DQ=1;
For(J=33;
}
Command=_cror_(Command,1);
}
UnsignedCharReaddatafromds18b20(Void)
UnsignedCharTemp;
Temp=0;
Temp=_cror_(Temp,1);
DQ=0;
_nop_();
DQ=1;
For(J=10;
If(DQ==1)
Temp=Temp|0x80;
Temp=Temp|0x00;
For(J=200;
Return(Temp);
VoidMain(Void)
TMOD=0x01;
TH0=(65536-4000)/256;
TL0=(65536-4000)%256;
ET0=1;
EA=1;
While(Resetpulse());
Writecommandtods18b20(0xcc);
Writecommandtods18b20(0x44);
TR0=1;
While
(1)
;
VoidT0(Void)Interrupt1Using0
UnsignedCharX;
UnsignedIntResult;
If(Displaycount==2)
P0=Displaycode[Displaybuf[Displaycount]]|0x80;
Else
{
P0=Displaycode[Displaybuf[Displaycount]];
}
P2=Displaybit[Displaycount];
Displaycount++;
If(Displaycount==8)
Displaycount=0;
Timecount++;
If(Timecount==150)
Timecount=0;
While(Resetpulse());
Writecommandtods18b20(0xcc);
Writecommandtods18b20(0xbe);
Readdata[0]=Readdatafromds18b20();
Readdata[1]=Readdatafromds18b20();
For(X=0;
X<
X++)
Displaybuf[X]=16;
Sflag=0;
If((Readdata[1]&
0xf8)!
=0x00)
Sflag=1;
Readdata[1]=~Readdata[1];
Readdata[0]=~Readdata[0];
Result=Readdata[0]+1;
Readdata[0]=Result;
If(Result>
255)
{
Readdata[1]++;
}
Readdata[1]=Readdata[1]<
<
4;
Readdata[1]=Readdata[1]&
0x70;
X=Readdata[0];
X=X>
>
X=X&
0x0f;
Readd