- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
DS18B20时序详解1
DS18B20时序详解
初始化时序:
DS18B20的所有通信都是以由复位脉冲组成的初始化序列开始的。该初始化序列由主机发出,后跟由DS18B20发出的存在脉冲(presence pulse)。下图阐述了这一点。
DS18B20发出存在脉冲,以通知主机它在总线上并且准备好操作了。
在初始化时序中,总线上的主机通过拉低单总线至少480μs来发送复位脉冲。然后总线主机释放总线并进入接收模式。总线释放后,4.7kΩ的上拉电阻把单总线上的电平拉回高电平。当DS18B20检测到上升沿后等待15到60us,然后以拉低总线60-240us的方式发出存在脉冲。
如上所述,主机将总线拉低最短480us,之后释放总线。由4.7kΩ上拉电阻将总线恢复到高电平。DS18B20检测到上升沿后等待15到60us,发出存在脉冲:拉低总线60-240us。至此,初始化和存在时序完毕。
?? ? /*延时函数:(由于DS18B20延时均以15us为单位,故编写了延时单位为15us的延时函数,注意:以下延时函数晶???为12MHz)*/? ? /*? ? ************************************? ? 函数:Delayxus_DS18B20? ? 功能:DS18B20延时函数? ? 参数:t为定时时间长度? ? 返回:无? ? 说明: 延时公式:15n+15(近似),晶振12Mhz? ? ******************************************? ? */? ? void Delayxus_DS18B20(unsigned int t)? ? {? ?? ?? ? for(t;t0;t--)? ?? ?? ? {? ?? ?? ?? ?? ???_nop_();_nop_();_nop_();_nop_();? ?? ?? ? }? ???? ?? ?? ? _nop_(); _nop_();? ? }
/*? ? ************************************? ? 函数:RST_DS18B20? ? 功能:复位DS18B20,读取存在脉冲并返回? ? 参数:无? ? 返回:1:复位成功 ;0:复位失败? ? 说明: 拉低总线至少480us ;可用于检测DS18B20工作是否正常? ? ******************************************? ? */? ? bit RST_DS18B20()? ? {? ?? ?? ?? ?? ?? ?? ? bit ret=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);? ? }
写时序:
主机在写时隙向DS18B20写入数据,在读时隙从DS18B20读取数据。在单总线上每个时隙只传送一位数据。
有两种写时隙:写“0”时间隙和写“1”时间隙。总线主机使用写“1”时间隙向DS18B20写入逻辑1,使用写“0”时间隙向DS18B20写入逻辑0.所有的写时隙必须有最少60us的持续时间,相邻两个写时隙必须要有最少1us的恢复时间。两种写时隙都通过主机拉低总线产生(见下图)。
为了产生写1时隙,在拉低总线后主机必须在15μs内释放总线。在总线被释放后,由于4.7kΩ上拉电阻将总线恢复为高电平。为了产生写0时隙,在拉低总线后主机必须继续拉低总线以满足时隙持续时间的要求(至少60μs)。
在主机产生写时隙后,DS18B20会在其后的15到60us的一个时间窗口内采样单总线。在采样的时间窗口内,如果总线为高电平,主机会向DS18B20写入1;如果总线为低电平,主机会向DS18B20写入0。
如上所述,所有的写时隙必须至少有60us的持续时间。相邻两个写时隙必须要有最少1us的恢复时间。所有的写时隙(写0和写1)都由拉低总线产生。
写函数为:? ? /*? ? ************************************? ? 函数:W
文档评论(0)