DS18B20时序.docx

上传人:b****1 文档编号:1760012 上传时间:2022-10-23 格式:DOCX 页数:11 大小:119.08KB
下载 相关 举报
DS18B20时序.docx_第1页
第1页 / 共11页
DS18B20时序.docx_第2页
第2页 / 共11页
DS18B20时序.docx_第3页
第3页 / 共11页
DS18B20时序.docx_第4页
第4页 / 共11页
DS18B20时序.docx_第5页
第5页 / 共11页
点击查看更多>>
下载资源
资源描述

DS18B20时序.docx

《DS18B20时序.docx》由会员分享,可在线阅读,更多相关《DS18B20时序.docx(11页珍藏版)》请在冰豆网上搜索。

DS18B20时序.docx

DS18B20时序

DS18B20时序

DS18B20时序

DS18B20时序

Author:

exploer

CIEE,CAU2008-9-16

本文档参照Maxim公司DS18B20的Datasheet而完成。

其中,加了灰框的部分为原文档内容,其中英文部分为官方文档内容,中文部分为本人的翻译。

限于本人水平,本文档可能存在错误或者让人误解的内容,对于因此引起的一切问题作者(exploer,CIEE-CAU)概不负责。

INITIALIZATIONPROCEDURE—RESETANDPRESENCEPULSES

初始化序列——复位和存在脉冲

AllcommunicationwiththeDS18B20beginswithaninitializationsequencethatconsistsofaresetpulsefromthemasterfollowedbyapresencepulsefromtheDS18B20.ThisisillustratedinFigure13.WhentheDS18B20sendsthepresencepulseinresponsetothereset,itisindicatingtothemasterthatitisonthebusandreadytooperate.

DS18B20的所有通信都由由复位脉冲组成的初始化序列开始。

该初始化序列由主机发出,后跟由DS18B20发出的存在脉冲(presencepulse)。

下图(插图13,即如下截图)阐述了这一点。

当发出应答复位脉冲的存在脉冲后,DS18B20通知主机它在总线上并且准备好操作了。

Duringtheinitializationsequencethebusmastertransmits(TX)theresetpulsebypullingthe1-Wirebuslowforaminimumof480μs.Thebusmasterthenreleasesthebusandgoesintoreceivemode(RX).

在初始化步骤中,总线上的主机通过拉低单总线至少480μs来产生复位脉冲。

然后总线主机释放总线并进入接收模式。

Whenthebusisreleased,the5kΩpullupresistorpullsthe1-Wirebushigh.WhentheDS18B20detectsthisrisingedge,itwaits15μsto60μsandthentransmitsapresencepulsebypullingthe1-Wirebuslowfor60μsto240μs.

当总线释放后,5kΩ的上拉电阻把单总线上的电平拉回高电平。

当DS18B20检测到上升沿后等待15到60us,然后以拉低总线60-240us的方式发出存在脉冲。

如文档所述,主机将总线拉低最短480us,之后释放总线。

由于5kΩ上拉电阻的作用,总线恢复到高电平。

DS18B20检测到上升沿后等待15到60us,发出存在脉冲:

拉低总线60-240us。

至此,初始化和存在时序完毕。

根据上述要求编写的复位函数为:

首先是延时函数:

(由于DS18B20延时均以15us为单位,故编写了延时单位为15us的延时函数,注意:

以下延时函数晶振为12MHz)

/*

************************************

函数:

Delayxus_DS18B20

功能:

DS18B20延时函数

参数:

t为定时时间长度

返回:

说明:

延时公式:

15n+15(近似),晶振12Mhz

******************************************

*/

voidDelayxus_DS18B20(unsignedintt)

{

for(t;t>0;t--)

{

_nop_();_nop_();_nop_();_nop_();

}

_nop_();_nop_();

}

延时函数反汇编代码(方便分析延时公式)

C:

0x00317F01MOVR7,#0x01

C:

0x00337E00MOVR6,#0x00

C:

0x00351206A6LCALLdelayxus(C:

06A6)

38:

voidDelayxus_DS18B20(unsignedintt)

39:

{

40:

for(t;t>0;t--)

C:

0x06A6D3SETBC

C:

0x06A7EFMOVA,R7

C:

0x06A89400SUBBA,#0x00

C:

0x06AAEEMOVA,R6

C:

0x06AB9400SUBBA,#0x00

C:

0x06AD400BJCC:

06BA

41:

{

42:

_nop_();_nop_();_nop_();_nop_();

C:

0x06AF00NOP

C:

0x06B000NOP

C:

0x06B100NOP

C:

0x06B200NOP

43:

}

C:

0x06B3EFMOVA,R7

C:

0x06B41FDECR7

C:

0x06B570EFJNZDelayxus_DS18B20(C:

06A6)

C:

0x06B71EDECR6

C:

0x06B880ECSJMPDelayxus_DS18B20(C:

06A6)

44:

_nop_();_nop_();

C:

0x06BA00NOP

C:

0x06BB00NOP

45:

}

C:

0x06BC22RET

分析上述反汇编代码,可知延时公式为15*(t+1)

/*

************************************

函数:

RST_DS18B20

功能:

复位DS18B20,读取存在脉冲并返回

参数:

返回:

1:

复位成功;0:

复位失败

说明:

拉低总线至少480us;可用于检测DS18B20工作是否正常

******************************************

*/

bitRST_DS18B20()

{

bitret="1";

DQ=0;/*拉低总线*/

Delayxus_DS18B20(32);/*为保险起见,延时495us*/

DQ=1;/*释放总线,DS18B20检测到上升沿后会发送存在脉冲*/

Delayxus_DS18B20(4);/*需要等待15~60us,这里延时75us后可以保证接受到的是存在脉冲(如果通信正常的话)*/

ret=DQ;

Delayxus_DS18B20(14);/*延时495us,让ds18b20释放总线,避免影响到下一步的操作*/

DQ=1;/*释放总线*/

return(~ret);

}

写时序:

READ/WRITETIMESLOTS

读写时隙

ThebusmasterwritesdatatotheDS18B20duringwritetimeslotsandreadsdatafromtheDS18B20duringreadtimeslots.Onebitofdataistransmittedoverthe1-Wirebuspertimeslot.

主机在写时隙向DS18B20写入数据,并在读时隙从DS18B20读入数据。

在单总线上每个时隙只传送一位数据。

WRITETIMESLOTS

写时间隙

Therearetwotypesofwritetimeslots:

“Write1”timeslotsand“Write0”timeslots.ThebusmasterusesaWrite1timeslottowritealogic1totheDS18B20andaWrite0timeslottowritealogic0totheDS18B20.Allwritetimeslotsmustbeaminimumof60μsindurationwithaminimumofa1μsrecovery

timebetweenindividualwriteslots.Bothtypesofwritetimeslotsareinitiatedbythemasterpullingthe1-Wirebuslow(seeFigure14).

有两种写时隙:

写“0”时间隙和写“1”时间隙。

总线主机使用写“1”时间隙向DS18B20写入逻辑1,使用写“0”时间隙向DS18B20写入逻辑0.所有的写时隙必须有最少60us的持续时间,相邻两个写时隙必须要有最少1us的恢复时间。

两种写时隙都通过主机拉低总线产生(见插图14)。

TogenerateaWrite1timeslot,afterpullingthe1-Wirebuslow,thebusmastermustreleasethe1-Wirebuswithin15μs.Whenthebusisreleased,the5kΩpullupresistorwillpullthebushigh.TogenerateaWrite0timeslot,afterpullingthe1-Wirebuslow,thebusmastermustcontinuetoholdthebuslowfor

thedurationofthetimeslot(atleast60μs).

为产生写1时隙,在拉低总线后主机必须在15μs内释放总线。

在总线被释放后,由于5kΩ上拉电阻的作用,总线恢复为高电平。

为产生写0时隙,在拉低总线后主机必须继续拉低总线以满足时隙持续时间的要求(至少60μs)。

TheDS18B20samplesthe1-Wirebusduringawindowthatlastsfrom15μsto60μsafterthemasterinitiatesthewritetimeslot.Ifthebusishighduringthesamplingwindow,a1iswrittentotheDS18B20.Ifthelineislow,a0iswrittentotheDS18B20.

在主机产生写时隙后,DS18B20会在其后的15到60us的一个时间窗口内采样单总线。

在采样的时间窗口内,如果总线为高电平,主机会向DS18B20写入1;如果总线为低电平,主机会向DS18B20写入0。

如文档所述,所有的写时隙必须至少有60us的持续时间。

相邻两个写时隙必须要有最少1us的恢复时间。

所有的写时隙(写0和写1)都由拉低总线产生。

为产生写1时隙,在拉低总线后主机必须在15us内释放总线(拉低的电平要持续至少1us)。

由于上拉电阻的作用,总线电平恢复为高电平,直到完成写时隙。

为产生写0

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 自然科学 > 生物学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1