Board logo

标题: 基于LPC2214和μC/OS-II的iButton接口 02 [打印本页]

作者: samwalton    时间: 2013-7-10 09:48     标题: 基于LPC2214和μC/OS-II的iButton接口 02

3.1 初始化及应答
  1-Wire总线上所有的传输操作均由初始化序列开始。初始化序列由主机发出的复位脉冲(Reset Pulse)和从机发出的在线应答脉冲(Presence Pulse)组成。一个复位脉冲紧跟一个在线应答脉冲表明DS1990A就绪,可执行恰当的ROM命令进行数据收发。
  复位和在线应答脉冲时序如图2(a)所示,主机发送(Tx)一个复位脉冲(一个至少480 μs的低电平),然后释放信号线进入接收模式(Rx)。此时,1-Wire总线被5 kΩ上拉电阻拉至高电平,当检测到数据线上信号的上升沿后,DS1990A等待(tPDL,15~60 μs),然后发送在线应答脉冲(tPDL,15~60 μs)。
  3.2 读写操作
  一旦主机检测到应答脉冲,就可以发出ROM功能命令。所有ROM操作命令的长度为8位。Read ROM的命令为[33H]或[0FH],此命令允许总线主控器读取DS1990A的8位家族码、唯一的48位序列码和8位CRC校验码。此命令仅当总线上只有一个DS1990A设备时可以使用。若总线上的从机设备超过一个,当各设备同时发送时将会引发数据冲突。Search ROM的命令为[F0H],此命令允许总线主控器采用排除法来确认总线上所有设备的64位ROM码。
        读/写时隙的定义如图2(b)、(c)所示,主机将数据线置低初始化所有时隙。在数据线的下降沿,通过触发DS1990A中的延时电路使得DS1990A与主机同步;在写时隙期间,延时电路决定何时DS1990A对数据线进行采样。至于读数据的时隙,如果传输的是“0”,延时电路将继续被置低近15 μs,然后被置高;如果数据位是“1”,则iButton保持读数据的时隙不变。

图2复位和读/写时序

  3.3 关键代码及实现
  主机和iButton的通信是通过初始化、写数据时序、读数据时序完成的,命令和数据的各个字节均由最低有效位开始逐位传送。在程序中,先初始化LPC2214的Time1定时器,将其定时时间设定为10 μs,Delay子程序的作用是使其延迟time倍的10 μs。Reset、WriteByte、ReadByte分别是初始化、读、写1字节的子程序。在指针型函数*GetButtonID中,将iButton的64位序列码保存在ButtonID数组中,最后返回指向这个数组的指针。
  结语
  为避免设备的维修不足或检修过剩,当前电力设备管理正由定期检修和计划检修管理体制,向预知性设备状态检修体制转变,其根本目标是提高设备可靠性、经济性、降低生产成本,提高设备的利用率。Dallas公司推出的智能信息载体iButton与其他类型的智能卡相比,能更好地解决电力现场环境比较恶劣,油污、灰尘、振动、电磁等不利因素对它的干扰问题。本文提供的DS1990A与LPC2214在嵌入式实时操作系统μC/OSII中的接口的软硬件设计,已在智能点检机中推广应用。随着相关技术的发展,iButton信息识别技术在工业领域的应用会越来越广泛,其经济作用会越来越大.




欢迎光临 电子技术论坛_中国专业的电子工程师学习交流社区-中电网技术论坛 (http://bbs.eccn.com/) Powered by Discuz! 7.0.0