逸珺 · 2021年05月26日

长文图解工业HART总线协议

首发:嵌入式客栈
作者:逸珺

[导读] 在AIOT蓬勃发展的今天,也掀起传统工业设备IOT革新的浪潮。那么需要对工业设备进行IOT改造,除了直接开发具有IOT互联协议的新型设备,对原有总线设备的接入改造其实也是一块很大的蛋糕。因此,掌握传统工业现场设备通讯总线,也是很必要的,即便在现在或者将来传统的工业总线也不会被淘汰,这是由于这些现场总线是专为复杂的工业控制现场而设计的。今天,就来分享一下HART总线。

初始HART总线

基本信息

HART(Highway Addressable Remote Transducer)可寻址远程变送器高速通道协议,翻译起来有点绕口。HART协议是用于过程控制设备的面向事务的通信服务。HART通信设备旨在增强传统的4-20 mA模拟信号传输,可在工业环境中提供相对低带宽、适度的响应时间的通信协议。应用包括远程过程变量查询,参数设置和诊断。从名字上就可看出,这个协议是用于变送器(有的也翻译为传感器),名字不重要,重要的是理解这究竟是什么个内涵.所谓变送器就是指能将现场情况的物理参数进行采集(比如温度、压力、流量等)并以工业标准模拟信号输出的设备,所谓工业标准模拟信号是指国际电工委员会(International Electro technical Commission,简称_IEC_)定义的4-20mA或者1-5V信号。

那么HART协议究竟是怎样一个协议呢?

HART协议是混合模拟信号以及数字信号的工业自动化开放协议。HART被广泛用于过程和仪表系统,从小型自动化应用到高度复杂的工业应用。它最显着的优点是,可以通过传统的4–20 mA仪表电流回路进行通信,有线HART协议的物理层为一对导线:

  • 该导线可以为设备供电
  • 导线内为4-20mA电流环
  • 同时进行模拟以及数字通信

什么是模拟通信呢?也就是前面说的4-20mA输出物理量的概念,比如现场是一个温度变送器,当前测温范围为℃~℃,那么4mA就对应-200℃,而20mA就对应500℃,存在下面的关系:
image.png

其数字通信协议支持:

  • 访问仪表的参数及诊断信息,这不是简单的读取,而是有专用公共的命令规范,获取诊断数据。
  • 支持多变量设备,这是什么意思呢?比如一个变送器可以同时测量压力以及温度,则是双变量变送器。
  • 设备在线状态监测
  • 完全开放的事实标准
  • 标准通用命令及数据结构
  • DDL(Device Description Language)支持,这是啥意思,就是用这样一种规范的文本描述语言抽象设备的信息其他的组态软件可以直接导入,从而实现互联互通。这就是标准的力量,不同厂家做的设备为什么可以在一个系统里快速组网,实现过程控制系统。

其模拟通信特点:

  • 模拟4-20mA通信与数字通信同时进行
  • 兼容现有的4-20mA设备,即便某个4-20mA设备没有HART支持。
  • 模拟4-20mA本身就是一种通信,比如一个测量变动器可直接接入一个控制器的模拟4-20mA通道,将测量值实时传输给控制器,而控制器的4-20mA输出又可以接到执行器(比如阀门控制器)的4-20mA输入通道,从而控制阀门的开度,形成闭环控制。

本文主要介绍基于有线连接物理层的HART,HART的物理层还支持2.4GHz,基于802.15.4规范的无线物理层。

网络分层

从前面介绍,基本知道了大致信息,现在来看看该协议的分层情况
image.png

从上面的图可以看出,HART协议对应OSI模型,实现了其中的5层:

  • 有线物理层:

    这里有句题外话,协议的物理层负责地产BIT流的传输,其实你用其他的物理层来传HART报文是否可以呢?当然也是可以的,比如你就用SPI去传也能传能收,为什么不用?无法适应工业现场的噪声环境,也无法可能满足现场组网的需求,比如总线仲裁等。

  • FSK物理层:有线HART的物理层主要采用采用FSK(Frequency Shift Keying)频移键控将0/1调制在4-20mA电流环路上,稍后在对FSK进行介绍。
  • PSK物理层:实际上是C8PSK(Coherent 8-way Phase Shift Keying), 它实际上是一种数字通信调制技术,通过改变恒定频率参考信号(参考信号称为载波)的相位来传输数据。所谓相位就是通过精确地改变正弦或余弦输入时间来完成调制。
  • RS-485物理层:这个是比较常见的半双工差分串行总线,实际上此类设备不是HART协议的主流,使用并不广泛。
  • 无线物理层:无线HART则采用基于IEEE802.15.4的无线2.4GHz频段物理层。

    IEEE802.15.4是一项定义了低速无线个人局域网(low-rate wireless personal area networks简称LR-WPAN)操作的技术标准。它规范了LR-WPAN的物理层和媒体访问控制,并由IEEE 802.15工作组维护,该工作组在2003年定义了该标准。它是Zigbee,ISA100.11a,WirelessHART,MiWi,6LoWPAN,Thread和SNAP规范的基础,它们各自都通过开发IEEE 802.15.4中未定义的上层来进一步扩展了标准。6LoWPAN还定义了WPAN上的Internet协议(IP)的IPv6版本的绑定,并且本身被Thread等上层所使用。需要注意的是WIFI虽然也使用2.4GHz频段,但是它遵循802.11规范。

    所谓Mesh网络,看看下面这个网络拓扑图就很好理解了:

image.png

  • 链路层:
  • 数据链路层为数据传输提供可靠的、面向事务的通信路径。对于FSK/PSK HART通信是通过双绞线进行传输,双绞线可能同时传输4-20mA信号。数据链路层将通过使用错误检测信息和自动重复请求(Automatic Repeat Request 简称ARQ)协议来请求重新传输可能被线路噪声或其他干扰破坏的数据块,从而来纠正由于通信链路上的噪声引起的错误。
  • 对于无线HART,则通过基于时间同步的TDMA/CSMA机制进行链路管理、冲突检测。在检测到出错时自动重复请求的跳频技术。所谓跳频,就是在802.15.4规范的带宽里,将带宽划分为多个信道,主从直接约定好跳频机制,从而有效的利用空闲信道。
  • 网络层(仅无线HART):主要实现功率优化,mesh网络管理。网络时间同步,时间同步的精确性对于基于时分复用 (Time-division multiple access简称TDMA) 的网络至关重要,时间不同步,网络将瘫痪。
  • 传输层:HART的传输层主要对于大块数据进行拆分传输。
  • 应用层:应用层定义了协议支持的公共命令,响应,数据类型和状态报告。因此HART应用层确保不同公司的设备的互操作性中起着重要作用。所谓互操作性,是指互联互通的基础上,还定义了应用操作。比如温度变送器,接入控制系统可以很容易与另一个阀门控制器、加热控制器快速组成温控系统。

HART规范书

HART原来由HART基金会管理,现在由FieldComm Group进行管理,FieldComm Group由现场总线基金会(Fieldbus Foundation 简称FF)以及HART基金会合并而来,统一管理FF以及HART总线标准。有兴趣可以去https://www.fieldcommgroup.or...

那么HART协议标准文档基本由哪些组成呢?这里总结了一个思维导图供参考:

image.png

从上面这个导图,可以看到,HART还为不同类型的工业设备制定了相应的通信规范,比如温度变送器、压力变送器、阀门控制器、PID控制器、累加器、液位变送器、科里奥力流量变送器、涡街流量变送器、电磁流量变送器等。

而对于无线HART则由HCF\_SPEC\_290文档进行集中描述。有了这份图,如果你是从事相关开发工作,相信对HART标准文档会有一个比较清晰的认识。

HART协议GB对应GB/T 29910.1~6-2013 type 20,IEC61158于2017年将HART标准收录,对应其子类的type 20。

下面来对于其中比较重要的物理层、链路层以及应用层做进一步的介绍。

物理层

一般的,FSK/PSK物理层与数据链路层都按照下面的模型进行设计,本文仅介绍最为常用 的FSK物理层,对C8PSK有兴趣的,可以查阅HCF\_SPEC-60。

image.png

FSK物理层

HART采用二进制频移键控(Binary FSK简称BFSK),其工作原理为:

image.png
所谓BFSK就是将待传输的数据按照二进制BIT流变换成相应的频率信号叠加起来,简单的可以理解成下图这样一个收发过程:

image.png

调制器与解调器一起组成了调制解调器,对于设备间通信而言基本都有这样一个调制解调的过程。

发送端调制器:

image.png

在两种不同信号频率间信号按照一定的时间间隔根据输入的二进制位为0或者1,选择成频率1或者频率2,进而合成为一个信号输出。将该物理信号输出到物理介质。当然实际使用的FSK,由不同的实现参数以及细节,还分连续相位频移键控、高斯频移键控、最小频移键控、高斯最小频移键控、音频频移键控等。

接收端解调器:

image.png

接收端将从物理介质接收到的电信号,分两路进入两个带通滤波器,带通滤波器分别为调制器对应的0/1调制频率,将该有用信号检出,再送入到检波器电路将信号检出为数字信号,双路数字信号再由判决电路按照对应的波特率判决成二进制数据流,从而完成物理层的解调过程。显然,这两个带通滤波器的通带应是不相交的,才能检出各自有用频率信号。

基本明了FSK的大致原理后,那么HART的FSK又是怎么样的呢?

image.png

HART采用连续相位频移键控(Continuous Phase Frequency-Shift-Keying,也简称为CPFSK)技术,所谓连续相位可以观察0/1相邻的点,简单理解就是赋值是连续的。HART利用1200Hz正弦电流信号表征逻辑1,而由2200Hz正弦电流信号表征逻辑0。0/1调制的时间宽度是一样的,采用一周期1200Hz正弦时间。这些调制的信号再线性叠加到4-20mA上,因此在4-20mA上的波形大致就是这样:

image.png

有童鞋可能会说,这样岂不是污染了4-20mA环路吗?HART协议规定调制信号的频带基本须在500-10KHz内:
image.png

4-20mA变送通道的变化频率低于1200Hz,设备会做一个低通滤波,滤除掉这些调制信号,再进入被接入设备的I/V转换电路,进而采样环路电流。所以一般的,接入端会并接一个250欧的电阻,将4-20mA转换为1-5V,当然也可能是其他电阻值。工业测量的过程量,一般都是低频信号,所以这样设计是没有问题的。

此调制解调器器可以由专用芯片完成,比如 安森美的NCN5192,Maxim的DS8500等都可以,也可以自己设计调制电路实现。

链路层

链路层向上层提供稳定可靠的数据链路服务,以及对下层的物理层介质进行介质访问管理,同时定义了数据报文结构。

帧结构

首先来看看HART协议报文结构:

image.png

其定界符定义为:

image.png

校验码采用异或校验算法,包括自定界字节开始至所有有效字节的异或结果便生成校验码。

报文结构之前绘制过一个思维导图,这里附上:

image.png

由于地址类型有可能是1字节或者5字节两种类型,因此报文的帧长由下面示意图确定:

image.png

  1. 根据地址类型确定Byte Count字段的位置
  2. 根据Byte Count长度确定校验自己的位置

接收帧算法,主要由下面几个关键事件完成:

image.png

长地址格式:由主站地址类型、Burst 模式标志、设备类型字段、ID字段组成。
image.png

主站类型:

  • 主要主站
  • 辅助主站

设备类型,设备类型主要定义可参考下面思维导图:

image.png

介质管理服务

image.png

看这个图好像很复杂,其实这是一般标准的严谨表述方式,姑且称为协议原语,所谓协议原语就是某一确定的动作抽象,对于物理层的控制就包含这样一些操作管理:

  • RESET复位原语,比如你自己做的调制解调器或者现有的芯片,需要实现状态复位的操作,比如现成的芯片可能提供复位脚或者控制命令,那么编程就是控制物理层进行复位。
  • ENABLE使能原语,对物理层的使能控制操作,比如MODEM芯片的ENABLE引脚的控制
  • DATA传输/接受原语,将物理层数据进行收发控制,对于发,就是将上层数据发送给物理层发送到总线介质的意思,对于收而言就是物理层接收到的BIT流进行成帧,并上传给上层。

总的指导控制操作,按照上述建议交互图进行与物理层进行交互。

注:标准中以SAP(Service Access Point)进行描述,所谓SAP,就是对介质或上层服务的一种抽象说法,至于这个名词不必觉得不好理解。

链路管理服务

链路管理主要描述链路层对应用层的服务,主要分两种服务,报文服务,以及管理服务:

  • **报文服务:**发送消息和接收回复的基本功能。此外,还指定了SAP,以允许捕获未经请求的消息,比如捕获Burst报文。
  • 管理服务:管理服务指允许配置数据链路层本身参数的服务。

640.png

看这个图好像很复杂,其实就是描述了应用层对链路层三种基本操作:

  • TRANSMIT发送服务原语:应用层发送报文给链路层
  • RECEIVE接受服务原语:接收报文并传输给应用层
  • CYCLIC捕获服务原语:周期性接受总线Burst报文,所谓Burst就是某一个站点周期性向总线广播报文,一般会将测量值或控制信息周期性广播,接收设备可以捕获该数据实现相应的应用控制。

介质控制

无Buest设备:主要是完成介质冲突控制的,采用令牌传递方式进行介质冲突控制,当总线中没有Burst设备时,其控制状态机如下:

image.png

总线设备主要有可能有三类设备:主要主站、从设备、辅助主站。令牌在这三者间按照上述状态机进行切换控制。数据总是主站发起,从站应当。是一种主-从通信模式,唯一要考虑的时,总线中主要主设备发起通信,从设备应答,如果在从设备应答令牌周期没有应答或者完成应答,令牌将传递给辅助主站。

有Burst设备:如果总线中存在Burst模式设备,则总线设备角色就多了一个,其令牌传递状态机就变成这样了:

image.png

其实就是令牌多了一个角色可以获取,其机理还是与上面的一样。

应用层

应用层主要定义:

  • 通过协议传输应用数据的格式;
  • 所有现场设备的版本规则;
  • 定义通用命令编号,通用惯例,特定设备和设备系列命令使用;
  • 私有HART命令的构造要求;
  • 所有命令响应都需要返回的命令状态字节;
  • 设备使用状态和现场设备变量;
  • 主机用于识别现场设备和管理HART网络的过程

另外应用层还规定了12项基本原则:

  1. 所有设备都必须遵守HART现场通讯协议规范的有效兼容修订版;
  2. 48号的必须遵守通用操作命令规范中的要求;
  3. 任何时候都不得从任何设备上删除命令,兼容性考虑;
  4. 现场设备支持的命令中任何数据项的含义均不得更改
  5. 数据项可以添加到任何命令的末尾
  6. 不得从枚举表,位字段或响应代码中删除条目
  7. 设备变量的代码号不得更改
  8. 设备变量的设备系列必须保持固定。
  9. 设备变量的分类必须保持固定
  10. 遵循以下规则,现场设备可以从HART 4升级而无需更改设备类型:
  • 设备修订版所针对的HART现场通信协议规范的所有要求都必须遵守
  • 必须删除命令4和命令5
  • 除命令0外,所有命令都必须仅以长帧格式实现,命令0必须同时以短帧和长帧格式实现。
  • 必须为每个主机提供设备状态字节中单独的配置更改位(即一个用于主要主机,另一个用于辅助主机)。当接收到命令38时,必须仅复位与发出命令的主机相对应的位。根据HART 5的要求,这些位必须是非易失性的。所谓非易失性就是掉电保存
  • 必须为每个主机在设备状态字节中提供一个单独的冷启动位
  • 必须支持通用实践命令规范中指定的命令38和命令48
  1. 遵循以下规则,现场设备可以从HART 5升级而无需更改设备类型

  • 设备修订版所针对的HART现场通信协议规范的所有要求都必须遵守
  • 必须为每个主机提供设备状态字节中单独的配置更改位
  • 必须为每个主机在设备状态字节中提供一个单独的冷启动位
  • 必须支持通用实践命令规范中指定的命令38和命令48
  • 如果支持“Burst模式”,则必须添加2条其他“Burst消息”。且必须添加事件通知。
  1. 遵循以下规则,可以在不更改设备类型的情况下从HART 6升级现场设备

  • 必须遵守设备修订版所针对的HART现场通信协议规范的所有要求。
  • 必须按照“通用实践命令规范”中的说明来支持命令38和命令48。
  • 2字节命令格式:命令字段为0x1F,可在数据字段中找到WO字节扩展命令号。

总结一下

HART总线,是工业现场设备应用最为广泛的总线协议之一,除此之外还有常见的modbus协议、Profibus协议、FF基金会总线协议等。其实总线通信协议都有其相似的地方,这也是为什么有OSI七层模型这一说,就是我们日常生活息息相关的TCP/IP协议栈也脱离不了这些相似的地方。

本文旨在梳理一下比较重要的信息,方便对有兴趣的童鞋起到一个提纲携领的作用,主要参考HART标准,同时加入自己的理解。短短的一篇文章并不能完整的总结这样一个协议,还有很多细节没有囊括,比如变量管理、诊断定义等等,具体开发中请以HART标准为准。整理本文,也是对之前工作中所使用到的工业总线协议做个总结。

END—

推荐阅读

更多硬核嵌入式技术干货请关注嵌入式客栈专栏。
推荐阅读
关注数
2891
内容数
284
分享一些在嵌入式应用开发方面的浅见,广交朋友
目录
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息