51单片机与DS18B20.ppt

上传人:p** 文档编号:166379 上传时间:2023-03-10 格式:PPT 页数:27 大小:593.50KB
下载 相关 举报
51单片机与DS18B20.ppt_第1页
第1页 / 共27页
51单片机与DS18B20.ppt_第2页
第2页 / 共27页
51单片机与DS18B20.ppt_第3页
第3页 / 共27页
51单片机与DS18B20.ppt_第4页
第4页 / 共27页
51单片机与DS18B20.ppt_第5页
第5页 / 共27页
51单片机与DS18B20.ppt_第6页
第6页 / 共27页
51单片机与DS18B20.ppt_第7页
第7页 / 共27页
51单片机与DS18B20.ppt_第8页
第8页 / 共27页
51单片机与DS18B20.ppt_第9页
第9页 / 共27页
51单片机与DS18B20.ppt_第10页
第10页 / 共27页
亲,该文档总共27页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《51单片机与DS18B20.ppt》由会员分享,可在线阅读,更多相关《51单片机与DS18B20.ppt(27页珍藏版)》请在第壹文秘上搜索。

1、DS18B20的管脚排列的管脚排列1. GND为电源为电源 地;地;2. DQ为数字信号输入输出端;为数字信号输入输出端;3. VDD为外接供电电源输入端为外接供电电源输入端(在寄生电源接线方式时接地,(在寄生电源接线方式时接地, 寄生电源工作方式寄生电源工作方式 (电源从(电源从IO口上获得)口上获得)注意:当温度高于注意:当温度高于 时,不能使用寄生电源,因为此时时,不能使用寄生电源,因为此时器件中较大的漏电流会使总线不能可靠检测高低电平,从而导致器件中较大的漏电流会使总线不能可靠检测高低电平,从而导致数据传输误码率的增大。数据传输误码率的增大。 外接电源工作方式外接电源工作方式 (因为我

2、们开发板上P0P3口均有上拉电阻 所以此处没有画出)配置寄存器与分辨率关系表温度的低八位数据 0温度的高八位数据 1高温阀值2低温阀值3保留4保留5计数剩余值6每度计数值7CRC校验8主机首先发出一个主机首先发出一个480960微秒的低电平脉冲,然后释放总线变为高电平,并在随后微秒的低电平脉冲,然后释放总线变为高电平,并在随后的的480微秒时间内对总线进行检测,如果有低电平出现说明总线上有器件已做出应答。微秒时间内对总线进行检测,如果有低电平出现说明总线上有器件已做出应答。若无低电平出现一直都是高电平说明总线上无器件应答。若无低电平出现一直都是高电平说明总线上无器件应答。做为从器件的做为从器件

3、的DS18B20在一上电后就一直在检测总线上是否有在一上电后就一直在检测总线上是否有480960微秒的低微秒的低电平出现,如果有,在总线转为高电平后等待电平出现,如果有,在总线转为高电平后等待1560微秒后将总线电平拉低微秒后将总线电平拉低60240微微秒做出响应存在脉冲,告诉主机本器件已做好准备。若没有检测到就一直在检测等待。秒做出响应存在脉冲,告诉主机本器件已做好准备。若没有检测到就一直在检测等待。 DS18B20 单线通信功能是分时完成的,他有严格的时隙概念,如果出现序列混乱,单线通信功能是分时完成的,他有严格的时隙概念,如果出现序列混乱, 1-WIRE 器件将不响应主机,因此读写时序很

4、重要。系统对器件将不响应主机,因此读写时序很重要。系统对 DS18B20 的各种操作必的各种操作必须按协议进行。根据须按协议进行。根据 DS18B20 的协议规定,微控制器控制的协议规定,微控制器控制 DS18B20 完成温度的转换完成温度的转换必须经过以下必须经过以下 4 个步骤个步骤 :()每次读写前对()每次读写前对 DS18B20 进行复位初始化。复位要求主进行复位初始化。复位要求主 CPU 将数据线将数据线下拉下拉 500us ,然后释放,然后释放, DS18B20 收到信号后等待收到信号后等待 16us60us 左右,然后发出左右,然后发出 60us240us 的存在低脉冲,主的存

5、在低脉冲,主 CPU 收到此信号后表示复位成功。收到此信号后表示复位成功。()发送一条()发送一条 ROM 指令指令DS18B20 的存储器指令集的存储器指令集 数据数据876543210含义CRC保留保留保留配置寄存器低温报警值高温报警值温度高位温度低位在这里说明一下,第二步跳过对在这里说明一下,第二步跳过对ROM操作的命令是在总线上只有一个器件时,操作的命令是在总线上只有一个器件时,为节省时间而简化的操作,若总线上不止一个器件,那么跳过为节省时间而简化的操作,若总线上不止一个器件,那么跳过ROM操作命令将操作命令将会使几器件同时响应,这样就会出现数据冲突。会使几器件同时响应,这样就会出现数

6、据冲突。bit Init_DS18B20(void) bit flag; /储存储存DS18B20是否存在的标志,是否存在的标志,flag=0,存在;,存在;flag=1,不存在,不存在 DQ = 1; /先将数据线拉高先将数据线拉高 for(time=0;time2;time+) ;/略微延时约略微延时约6微秒微秒/再将数据线从高拉低,要求保持再将数据线从高拉低,要求保持480960usDQ = 0; for(time=0;time200;time+) ; /略微延时约略微延时约600微秒微秒/以向以向DS18B20发出一持续发出一持续480960us的低电平复位脉冲的低电平复位脉冲 DQ

7、= 1; /释放数据线(将数据线拉高)释放数据线(将数据线拉高) for(time=0;time10;time+) ; /延时约延时约30us(释放总线后需等待(释放总线后需等待1560us让让DS18B20输输出存在脉冲)出存在脉冲)flag=DQ; /让单片机检测是否输出了存在脉冲(让单片机检测是否输出了存在脉冲(DQ=0表示存在)表示存在) for(time=0;time200;time+) ; /延时足够长时间,等待存在脉冲输出完毕延时足够长时间,等待存在脉冲输出完毕return (flag); /返回检测成功标志返回检测成功标志 unsigned char ReadOneChar(v

8、oid) unsigned char i=0;unsigned char dat; /储存读出的一个字节数据储存读出的一个字节数据for (i=0;i8;i+) DQ =1; / 先将数据线拉高先将数据线拉高 _nop_(); /等待一个机器周期等待一个机器周期 DQ = 0; /单片机从单片机从DS18B20读书据时读书据时,将数据线从高拉低即启动读时序将数据线从高拉低即启动读时序 _nop_(); /等待一个机器周期等待一个机器周期 DQ = 1; /将数据线将数据线人为人为拉高拉高,为单片机检测为单片机检测DS18B20的输出电平作准备的输出电平作准备 for(time=0;time=1

9、; if(DQ=1) dat|=0 x80; /如果读到的数据是如果读到的数据是1,则将,则将1存入存入datelsedat|=0 x00;/如果读到的数据是如果读到的数据是0,则将,则将0存入存入dat for(time=0;time8;time+); /延时延时3us,两个读时序之间必须有大于两个读时序之间必须有大于1us的恢复期的恢复期 return(dat); /返回读出的十六进制数据返回读出的十六进制数据unsigned char ReadOneChar(void) unsigned char i=0;unsigned char dat; /储存读出的一个字节数据储存读出的一个字节数

10、据for (i=0;i8;i+) DQ =1; / 先将数据线拉高先将数据线拉高 _nop_(); /等待一个机器周期等待一个机器周期 DQ = 0; /单片机从单片机从DS18B20读书据时读书据时,将数据线从高拉低即启动读时序将数据线从高拉低即启动读时序 _nop_(); /等待一个机器周期等待一个机器周期 DQ = 1; /将数据线将数据线人为人为拉高拉高,为单片机检测为单片机检测DS18B20的输出电平作准备的输出电平作准备 for(time=0;time=1; if(DQ=1) dat|=0 x80; /如果读到的数据是如果读到的数据是1,则将,则将1存入存入datelsedat|=

11、0 x00;/如果读到的数据是如果读到的数据是0,则将,则将0存入存入dat for(time=0;time8;time+); /延时延时3us,两个读时序之间必须有大于两个读时序之间必须有大于1us的恢复期的恢复期 return(dat); /返回读出的十六进制数据返回读出的十六进制数据WriteOneChar(unsigned char dat) unsigned char i=0;for (i=0; i8; i+) DQ =1; / 先将数据线拉高先将数据线拉高 _nop_(); /等待一个机器周期等待一个机器周期 DQ=0; /将数据线从高拉低时即启动写时序将数据线从高拉低时即启动写时序 DQ=dat&0 x01; /利用与运算取出要写的某位二进制数据利用与运算取出要写的某位二进制数据, /并将其送到数据线上等待并将其送到数据线上等待DS18B20采样采样 for(time=0;time10;time+) ;/延时约延时约30us,DS18B20在拉低后的约在拉低后的约1560us期间从数据线上采样期间从数据线上采样 DQ=1; /释放数据线释放数据线 for(time=0;time=1; /将将dat中的各二进制位数据右移中的各二进制位数据右移1位位 for(time=0;time4;time+) ; /稍作延时稍作延时,给硬件一点反应时间给硬件一点反应时间

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

当前位置:首页 > 通信/电子 > 电子设计

copyright@ 2008-2023 1wenmi网站版权所有

经营许可证编号:宁ICP备2022001189号-1

本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。第壹文秘仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知第壹文秘网,我们立即给予删除!