0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

为什么UART驱动1-Wire设备总是出现问题?

工程师 来源:记得诚 作者:记得诚 2020-10-23 17:13 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

麦叔是搞嵌入式的,最近项目delay,他和我说用UART驱动1-Wire设备总是出现问题,故写此文来拯救他。

作者之前写过UART(点我),也写过1-Wire(点我),本文介绍如何用主机的UART驱动1-Wire从机设备,建议先看看以上两篇文章,再阅读本文,效果更佳。

硬件电路

1-Wire结构简单,一根线就可以通信,常见的18B20用的就是1-Wire结构。单片机的串口UART(多是TTL电平),如何用单片机控制通用的1-Wire设备呢?如果MCU和从设备的电平不一致如何解决?软件协议又是如何控制的呢?本文主要解决这两个问题。

主机或从机将数据线拉低到GND表示数据0,将数据线释放为高表示数据1,高电平由上拉电阻(一般是4.7K)提供。

当MCU发送逻辑1时,经过反相器,总线呈现逻辑0,逻辑0经过1-WIRE器件的反相器,即会收到逻辑1;

当MCU发送逻辑0时,经过反向器,总线呈现逻辑1,逻辑1经过1-WIRE 器件的反相器,即会收到逻辑0;

当1WIRE 器件发送逻辑1时,Tx处有NMOS会导通,总线呈现逻辑0,经过MCU Rx 处的反相器,MCU会收到逻辑1;

当1WIRE器件发送逻辑0时,NMOS截止,总线呈现逻辑1,MCU会收到逻辑0;

主机端(BUS MASTER)多为MCU,因为MCU的TXD不是漏极开路,因此通常需要一个外部漏极开路缓冲电路,该电路可以由分立元件构成。

用两个NMOS管2N7002,原理很简单:

TXD输出高电平时,左边的2N7002导通,右边的截止,DQ被4.7K电阻上拉至Vpullup高电平;

TXD输出低电平时,左边的2N7002截止,右边的导通,DQ被拉低至低电平0;

用分立器件搭建的缓冲电路

也可以用集成芯片NC7WZ07,如下图所示,TXD输出高,DQ=Vpullup,TXD输出低,DQ=0;

用集成芯片搭建的缓冲电路

解决了硬件电路,我们再来看软件协议部分,1-Wire的协议可以分为复位/应答、写0/写1时隙、读0/读1时隙。

软件协议

复位/应答

如下图,上面部分是1-Wire的复位/应答时序,下面是UART的时序。

复位/应答信号时序

原理:

主机以9600的波特率发送数据0XF0,因为LSB在前,0XF0=00001111,加上最前面的Start Bit和最后面的Stop Bit,完整的数据为:0000011111,代表主机先发了5位的0,然后发了5位的1;9600波特率,一位传输时间是1/9600=104.2us,所以低电平持续时间为104.2*5=521us,满足480~960us复位总线的时序要求。

那主机收到什么数据代表从机应答呢?

首先主机如果发送F0后收到还是F0,说明从机没有应答,从机应答总线数据会改变,可以简单的判断收到的数据为非F0即代表从机应答。

根据1-Wire的时序波形,也可以进行推算,从上图看,Data0~Data3均为0,因为1-Wire时序是有一定时间范围,并不是固定的脉宽,如TPDH为15~60us,TPDL为60~240us,所以Data4~Data7是有一定的组合,返回0X10(00001000) to 0X90(00001001)都代表从机应答。

写0/写1时隙

主机写0就是0X00,也可以加入回读,回读值即为写的值。

写0时隙

写1就是0XFF,回读值即为写的值。

写1时隙图

读0/读1时隙

关于读时隙,可以先看主机读1时,主机先拉低总线,一般时间1us左右,UART的Start Bit会占1/115200=8.7us的脉宽(大于1us),所以从Data0开始,后面的数据都为1,即读到的数据为11111111(0XFF)代表读到的是1。

读1时隙图

那读0也就很简单,读到的数据不为0XFF即为0。

读0时隙图

小结一下

实际代码里面的判断,可以简单处理,复位/应答:发送F0,返回不为F0,即代表从机应答;读0/读1时隙:主机读到0XFF即为1,读到非0XFF即为0;简单又可靠,麦叔还不会。

今天的文章到这里就结束了,希望对你有帮助,我们下一期见。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    462

    文章

    53534

    浏览量

    459109
  • 电路
    +关注

    关注

    173

    文章

    6063

    浏览量

    177475
  • 单片机
    +关注

    关注

    6074

    文章

    45340

    浏览量

    663548
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    分享1-Wire接口数字温度传感器IC型号

    如今,随着测温应用环境的升级和拓展,精准的温度测量与控制已成为各种环境数据采集的关键,传统模拟温度传感器已经无法满足市场的要求,而1-Wire接口数字温度传感器IC的出现,极大地简化了系统设计。为此
    的头像 发表于 12-02 16:34 377次阅读
    分享<b class='flag-5'>1-Wire</b>接口数字温度传感器IC型号

    DS28E01-100 1Kb、保护型1-Wire EEPROM,带有SHA-1引擎技术手册

    。DS28E01-100通过单触点1-Wire®串行接口进行通信,遵循1-Wire协议,在多个从器件的1-Wire网络中充当节点地址。
    的头像 发表于 05-14 14:36 1219次阅读
    DS28E01-100 <b class='flag-5'>1</b>Kb、保护型<b class='flag-5'>1-Wire</b> EEPROM,带有SHA-<b class='flag-5'>1</b>引擎技术手册

    DS28E10 1-Wire SHA-1认证器技术手册

    器件带有唯一的64位ROM注册码(ROM ID),由工厂刻入芯片。每次可向存储器写入4个字节,安全的低成本工厂编程服务可对器件数据进行预编程,这也包括SHA-1安全数据部分。器件通过单触点1-Wire®总线进行通信,遵循标准的1-Wir
    的头像 发表于 05-14 14:26 875次阅读
    DS28E10 <b class='flag-5'>1-Wire</b> SHA-<b class='flag-5'>1</b>认证器技术手册

    DS28E02 1-Wire SHA-1认证器,具有1Kb EEPROM,工作在1.8V技术手册

    。DS28E02通过单触点1-Wire®总线进行通信,遵循标准的1-Wire协议,注册码在多器件1-Wire网络中充当节点地址。
    的头像 发表于 05-14 14:17 799次阅读
    DS28E02 <b class='flag-5'>1-Wire</b> SHA-<b class='flag-5'>1</b>认证器,具有<b class='flag-5'>1</b>Kb EEPROM,工作在1.8V技术手册

    DS2465 DeepCover安全认证器具有SHA-256协处理器和1-Wire主机功能技术手册

    系统与1-Wire SHA-256从器件通信及操作所要求的SHA-256和存储器功能。此外,器件执行I²C主控制器与所连接的任何1-Wire SHA-256从器件之间的协议转换。对于1-Wire线
    的头像 发表于 05-14 14:09 767次阅读
    DS2465 DeepCover安全认证器具有SHA-256协处理器和<b class='flag-5'>1-Wire</b>主机功能技术手册

    DS24L65 DeepCover安全认证器,具有SHA-256协处理器和1-Wire主机功能技术手册

    转换。对于1-Wire线驱动器,芯片内部用户可调定时器将系统主处理器从繁琐的1-Wire波形时序控制中解放出来,支持标准和高速1-Wire通信。1-
    的头像 发表于 05-14 11:25 661次阅读
    DS24L65 DeepCover安全认证器,具有SHA-256协处理器和<b class='flag-5'>1-Wire</b>主机功能技术手册

    DS2475带1-Wire主机的DeepCover ECDSA协处理器技术手册

    DeepCover 嵌入式安全解决方案将敏感数据隐藏在多层先进的物理安全保护之下,从而提供非常安全的密钥存储。 具有内置1-Wire ^®^ 主机(DS2475)的DeepCover椭圆曲线
    的头像 发表于 05-14 11:17 690次阅读
    DS2475带<b class='flag-5'>1-Wire</b>主机的DeepCover ECDSA协处理器技术手册

    DS28E16 1-Wire SHA-3安全认证器技术手册

    计数器和唯一的64位ROM识别码(ROM ID)。唯一的ROM ID用作加密运算的基本输入参数,也作为应用中的电子序列号。器件通过单触点1-Wire®总线通信。通信采用1-Wire协议,ROM ID作为多器件1-Wire网络中的
    的头像 发表于 05-13 15:18 759次阅读
    DS28E16 <b class='flag-5'>1-Wire</b> SHA-3安全认证器技术手册

    DS2430A 256位1-Wire EEPROM技术手册

    DS2430A是一款256位1-Wire® EEPROM,用于识别和存储与产品相关的信息。这个标签或特殊产品信息可以通过最少的接口访问,例如微控制器的一个端口引脚。DS2430A带有一个由工厂刻度
    的头像 发表于 02-27 15:21 1016次阅读
    DS2430A 256位<b class='flag-5'>1-Wire</b> EEPROM技术手册

    DS2408系列1-Wire、8通道、可编程 1-Wire IC技术手册

    DS2408是一款8通道、可编程I/O 1-Wire® IC。PIO输出可配置为开漏结构,具有100Ω的最大导通电阻。稳固的PIO通道访问通信协议确保PIO输出设置变化没有误差。数据有效选通输出,可用来锁存PIO的逻辑状态,供给外部电路,如D/A转换器(DAC)或微控制器的数据总线。
    的头像 发表于 02-26 16:12 1068次阅读
    DS2408系列<b class='flag-5'>1-Wire</b>、8通道、可编程 <b class='flag-5'>1-Wire</b> IC技术手册

    DS2431 1024位1-Wire EEPROM技术手册

    DS2431是一款1024位1-Wire® EEPROM芯片,由四页存储区组成,每页256位。数据先被写入一个8字节暂存器中,经校验后复制到EEPROM存储器。该器件的特点是,四页存储区相互独立
    的头像 发表于 02-26 15:38 1691次阅读
    DS2431 1024位<b class='flag-5'>1-Wire</b> EEPROM技术手册

    DS28E04-100 4096位、可寻址、1-Wire EEPROM,带有PIO技术手册

    DS28E04-100是具有7个地址输入的4096位,1-Wire® EEPROM芯片。地址输入直接映射到1-Wire 64位器件ID号上,使主机系统能够在多器件1-Wire网络环境中直接识别
    的头像 发表于 02-26 15:29 894次阅读
    DS28E04-100 4096位、可寻址、<b class='flag-5'>1-Wire</b> EEPROM,带有PIO技术手册

    DS2413系列双通道可编程1-Wire芯片技术手册

    DS2413是双通道可编程I/O 1-Wire®芯片。PIO输出配置为开漏极,提供最高20mA的吸电流能力,截止状态工作电压可达28V。通过专门的器件级命令协议实现PIO引脚的控制与检测。为了在最终
    的头像 发表于 02-26 15:12 973次阅读
    DS2413系列双通道可编程<b class='flag-5'>1-Wire</b>芯片技术手册

    DS28EC20 20Kb 1-Wire EEPROM技术手册

    DS28EC20是一款20480位、1-Wire® EEPROM,分为80个256位的存储器页。器件提供一个额外的页用于控制功能。数据被写入一个32字节暂存器,经过校验后,复制到EEPROM存储器
    的头像 发表于 02-26 14:33 1176次阅读
    DS28EC20 20Kb <b class='flag-5'>1-Wire</b> EEPROM技术手册

    DS9490 USB至1-Wire/iButton适配器技术手册

    DS9490B是一个USB桥接器和支架,用于单个F5尺寸的iButton。iButton被安全地固定在带锁的门后。DS9490R是一个带有1-Wire RJ11接口的USB桥,可容纳1-Wire插座
    的头像 发表于 02-26 10:45 1080次阅读
    DS9490 USB至<b class='flag-5'>1-Wire</b>/iButton适配器技术手册