现场总线 第2章 CAN总线的概念及其相关的协议_第1页
现场总线 第2章 CAN总线的概念及其相关的协议_第2页
现场总线 第2章 CAN总线的概念及其相关的协议_第3页
现场总线 第2章 CAN总线的概念及其相关的协议_第4页
现场总线 第2章 CAN总线的概念及其相关的协议_第5页
已阅读5页,还剩48页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第2章CAN总线的概念及其相关的协议2.1CAN总线的概念

CAN(ControllerAreaNetwork)即控制器局域网。由于具有高性能、高可靠性以及独特的设计,CAN总线越来越受到人们的重视。德国的Bosch公司最初为了汽车监控和控制系统设计了CAN总线,现在,世界上许多的著名汽车制造厂商都已经开始采用CAN总线来实现汽车内部控制系统与各检测和执行机构间的数据通信。由于CAN总线本身的特点,其应用范围目前已经不再局限于汽车行业,而向过程工业、机械工业、纺织工业、农用机械、机器人、数控机床、医疗器械及传感器等领域发展。CAN已经形成国际标准。并已经被公认为几种最有前途的现场总线之一。随着CAN在各种领域的应用和推广,对其通信格式标准化的要求日益增长。1991年9月philipsSemiconductots制定并发布了CAN技术规范。该技术规范包括A和B两部分。CAN2.0A给出了CAN报文标准格式,而CAN2.0B给出了标准和扩展的两种格式。此后,1993年11月ISO正式颁布了道路交通运输工具——数据信息交换——高速通信控制器局域网(CAN)国际标准IS011898,为控制器局域网的标准化、规范化铺平了道路。

下面我们首先介绍一下CAN中的一些基本概念。①报文总线上的信息以不同格式的报文发送,但长度有限。当总线开放时,任何连接的单元均可开始发送一个新报文。②信息路由在CAN系统中,一个CAN节点不使用有关系统结构的任何信息。这里包含一些重要的概念:系统灵活性——节点可在不要求所有节点及其应用层改变任何软件或硬件的情况下,被接于CAN网络。报文通信——一个报文的内容由其标识符ID命名。ID并不指出报文的目的,但描述数据的含义,以便网络中的所有节点有可能借助报文滤波决定该数据是否使它们激活。成组——由于采用了报文滤波,所有节点均可接收报文,并同时被相同的报文激活。数据相容性——在CAN网络内,可以确保报文同时被所有节点或者没有节点接收,因此,系统的数据相容性是借助于成组和出错处理达到的。③位速率CAN的数据传输率在不同的系统中是不同的,而在一个给定的系统中,此速度是惟一的,并且是固定的。④优先权在总线访问期间,标识符定义了一个报文静态的优先权。⑤远程数据请求通过发送一个远程帧,需要数据的节点可以请求另一个节点发送一个相应的数据帧,该数据帧与对应的远程帧以相同标识符ID命名。⑥多主站当总线开放时,任何单元均可开始发送报文,发送具有最高优先权报文的单元会赢得总线的访问权。⑦仲裁当总线开放时,任何单元均可开始发送报文,若同时有两个或更多的单元开始发送,总线访问冲突运甩逐位仲裁规则,借助标识符ID解决。这种仲裁规则可以使信息和时间均无损失。若具有相同标识符的一个数据帧和一个远程帧同时发送,数据帧优先于远程帧。仲裁期间,每一个发送器都对发送位电平与总线上检测到的电平进行比较,若相同则该单元可继续发送。当发送一个“隐陛”电平,而在总线上检测为“显性”电平时,该单元退出仲裁,并不再传送后继位。⑧安全性为了获得尽可能高的数据传输安全性,在每个CAN节点中均设有错误检测、标定和自检的强有力措施。检测错误的措施包括:发送自检、循环冗余校验、位填充和报文格式检查。⑨出错标注和恢复时间己损报文由检验出错误的节点进行标注。这样的报文将失效,并自动进行重发送。如果不存在新的错误,从检出错误到下一个报文开始发送的恢复时间最多为29个位时间。⑩故障界定CAN节点有能力识别永久性故障和暂时扰动,可自动关闭故障节点。⑾连接CAN串行通信链路是一条众多单元均可以被连接的总线:理论上,单元数目是无限的,实际上单元总数受限于延迟时间和总线的电器负载。⑿应答所有接收器均对接收报文的相容性进行检查,回答一个相容报文,并标注一个不相容报文。2.2CAN的特点

CAN属于总线式串行通信网络,由于采用了许多新技术以及独特的设计,与一般的通信总线相比,CAN总线的数据通信具有突出的性能、可靠性、实时性和灵活性。其特点可以概括如下:①通信方式灵活。CAN为多主方式工作,网络上任一节点均可在任意时刻主动的向网络上其他节点发送信息,而不分主从,且无需站地址等节点信息。利用这一特点可方便的构成多机备份系统。②CAN网络上的节点信息分成不同的优先级,可满足不同的实时要求。③CAN采用非破坏性总线仲裁技术,当多个节点同时向总线发送信息时,优先级较低的节点会主动的退出发送,而最高优先级的节点可不受影响的继续传输数据,从而大大节省了总线冲突仲裁时间,尤其是在网络负载很重的情况下也不会出现网络瘫痪情况。④CAN只需通过报文滤波即可实现点对点、一点对多点及全局广播等几种方式传送接收数据,无需专门的“调度”。⑤CAN的直接通信距离最远可达10km(传输速率5Kb/s以下):通信速率最高可达1Mb/s(此时通信距离最长为40m)。⑥CAN上的节点数主要取决于总线驱动电路,目前可达110个;报文标识符可达2032种(CAN2.0A),而扩展标准(CAN2.0B)的报文标识符几乎不受限制。⑦CAN总线通信格式采用短帧格式,传输时间短,受干扰概率低。具有极好的检错效果。每帧字节数最多为8个,可满足通常工业领域中控制命令、工作状态及测试数据的一般要求。同时,8B也不会占用过长的总线时间,从而保证了通信的实时陛。⑧CAN的每帧信息都有CRC校验及其他检错措施,保证了数据通信的可靠性。⑨CAN总线通信接口中集成了CAN协议的物理层和数据链路层功能,可完成对通信数据的成帧处理,包括位填充、数据块编码、循环冗余检验、优先级判别等多项工作。⑩CAN的通信介质可为双绞线、同轴电缆或光纤,选择灵活。

⑾CAN节点在错误严重的情况下具有自动关闭输出功能,以使总线上其他节点的操作不受影响。2.3CAN的分层结构和通信协议

2.3.1CAN的分层结构

为使设计透明和执行灵活,遵循ISO/OSI标准模型,CAN分为数据链路层和物层,其中数据链路层又包括逻辑链路控制子层LLC和媒体访问子层MAC。而在CAN技术规范2.0A中,数据链路层的LLC和MAC子层的服务和功能被描述为目标层和传输层。图2.1解释了CAN的分层结构和功能。

CAN技术规范2.0B定义了数据链路层中的MAC:子层和LLC子层的一部分,并描述了与CAN有关的外层接口。物理层定义信号怎样进行发送,因而,涉及位定时、位编码和同步的描述,在这部分技术规范中,未定义物理层中的驱动器,接收器特性,以便允许跟据具体应用,对发送媒体和信号电平进行优化。MAC子层是CAN协议的核心,它描述由LLC子层接收到的报文和对LLC子层发送的认可报文。MAC子层可响应报文帧、仲裁、应答、错误检测和标定。MAC子层由称为故障界定的一个管理实体监控,它具有识别永久故障或短暂扰动的自检机制。LLC子层的主要功能是报文滤波、超载通知和恢复管理。

2.3.2CAN的通信协议

首先我们对CAN总线自身的通信规则和帧格式的定义进行简单的介绍。CAN总线是一种种有效支持分布式控制或实时控制的串行通信网络,可实现全分布式多机系统;可以用点对点,一点对多点以及全局广播几种方式传送和接受数据;CAN总线直接通信距离最远可达10km(此时传输速率只能达到5Kb/s),通信速率最高可达1Mb/s(此时传输距离只能达到40m):且理论上CAN总线通信网络的节点数不受限制(实际上受CAN收发器芯片驱动能力的限制)。CAN总线总是基于下列5条基本规则进行通信协调:①总线访问:

CAN是共享媒体的总线,它对媒体的访问机制类似于与以太网的媒体访问机制,即采用载波监听多路访问(CarrierSenseMultipleAccess,CSMA)的方式。CAN控制器只能在总线空闲时开始发送,并采用硬同步,所有CAN控制器划步都位于帧起始的前沿。为避免异步时钟因累计误差而错位,CAN总线中用硬同步后满足一定条件的跳变进行重同步。所谓总线空闲,就是网络上至少存在3个空闲位(隐性位)时网络的状态,也就是CAN节点在侦听到网络上出现至少3个隐性位时,才开始发送。②仲裁:当总线空闲时呈隐性电平,此时任何一个节点都可以向总线发送一个显性电平作为一个帧的开始。如果有两个或两个以上的节点同时发,就会产生总线冲突CAN总线解决总线冲突的方法比以太网的CSMA/CD方法有很大的改进。以太网是碰撞检测的方式,即一旦检测到两个或多个节点同时发送信息帧时,即所有发送节点都退出发送,待随机时间后再发送。而CAN是按位对标识符进行仲裁:各发送节点在向总线发送电平的同时,也对总线上的电平进行读取,并与自身发送的电平进行比较,如果电平相同则继续发送下一位,不同则说明网络上有更高优先级的信息帧正在发,即停止发送,退出总线竞争。剩余的节点则继续上述过程。直到总线上只剩下一个节点发送的电平,总线竞争结束,优先级最高的节点获得了总线的使用权,继续发送信息帧的剩余部分直至全部发送完毕。③编码,解码:帧起始域、仲裁域、控制域、数据域和CRC序列均使用位填充技术进行编码。在CAN总线中,每连续5个同状态的电平插入一位与它相补的电平,还原时每5个同状态的电平后的相补电平被删除,从而保证了数据的透明。④出错标注:当检测到位错误、填充错误、形式错误或应答错误时,检测出错条件的CAN控制器将发送一个出错标志。⑤超载标注:一些CAN控制器会发送一个或多个超载帧以延迟下一个数据帧或远程帧的发送。2.4CAN报文的帧结构

CAN通信协议2.0A规定了4种不同的帧格式:数据帧、远程帧、错误帧和超载帧。其中数据帧用于传送数据,远程帧用于请求数据,超载帧用于扩展帧序列的延迟时间,而当局部检测出错条件后产生一个全局信号出错帧。2.4.1CAN报文的帧类型

1.数据帧

数据帧由7个不同的位场组成,即帧起始标志位、仲裁场、控制场、数据场、CRC检查场、ACK应答场和帧结束标志位。数据场长度可为零。CAN2.0A数据帧的组成如图2.2所示。

在CAN2.0B中存在两种不同的帧格式,其主要区别在于标识符的长度,具有11位标识符的帧称为标准帧,而包括29位标识符的帧称为扩展帧,其格式如图2.3所示。①帧起始标志位(SOF)标志着数据帧和远程帧的起始,它以一个比特的显位出现,只有在总线处于空闲状态时,才允许站开始发送,这个状态将结束总线空闲状态(被动状态),表明有某个节点设备开始发送消息,并且所有站都必须同步于首先开始发进的那个站的帧起始前沿。②仲裁场(ArbiffafionField)由标识符(Identifier)和远程发送请求位(RTR)标志组成,如图2.4所示。对于CAN20A标准,标识符的长度为11位,这些位以从高位到低位的顺序发送,最低位为ID0,其中最高7位不能全为隐位。在数据帧中,RTR位总是设成0,而在远程帧中必须为1。对于CAN20B,标准格式和扩展格式的仲裁场的格式不同。在标准格式中,仲裁场由11位标识符和远程发送请求位RTR组成,标识符为ID.28~ID.l8,而在扩展格式中,仲裁场由29位标识符、替代远程请求SRR位、标识位和远程发送请求位组成。标识符位为ID.28~ID.0。IDE位对于扩展格式属于仲裁场,对于标准格式属于控制场。IDE在标准格式中以显性电平发送,而在扩展格式中以隐性电平发送。③控制场包括数据长度码和两个保留位,这两个保留位必须发送显性位。数据长度码(DLC)为4位,它指出了数据场的字节数目。控制场的组成如图2.5所示。④数据场由数据帧中被发送的数据组成,它可包括0~8个字节。⑤CRC场包括CRC序列,后随CRC界定符。

⑥应答场(ACK)位,包括应答间隙和应菩界定符。在应答场中,发送器送出两个隐位。一个正确的接收到有效报文的接收器,在应答间隙,将此信息通过发送一个显位报告给发送器。所有接收到匹配CRC序列的站,通过在应答间隙内把显位写入发送器的隐位来报告。应答界定符是应答场的第二位,并且必须是隐位,因此,应答间隙被两个隐位包围。⑦帧结束:每个数据帧和远程帧均由7个隐位组成的标志序列界定。2.远程帧

远程帧被用来请求总线上某个远程节点发送自己想要接收的某种数据,具有发出这种远地消息能力的节点收到这个远程帧后,就应尽力响应这个远地传送要求。所以对远程帧本身来说,是没有数据域的。早远程帧中,除了RTR位被置成1,表示被动状态外,其余部分与数据帧完全相同。远程帧的组成如图2.6所示。3.错误帧

错误帧由两个场组成,如图27所示,第一个场由来自各站的错误标志叠加得,随后的第二个场是出错界定符。报文传输过程中,检测到任何一个节点出错,即于下一位开始发送错误帧,通知发送端停止发送。4.超载帧

超载帧和错误帧一样由两个场组成:超载标志和超载界定符,如图2.8所示。当某接收因内部原因要求缓发下一个数据帧或远程帧时,它向总线发出超载帧。超载帧还可以引发另一次超载帧,但以两次为限。5.帧间空间

数据帧和远程帧同前面的帧相同,不管是何种帧,均以称之为帧间空间的场位分开。相反,在超载帧和出错帧前面没有帧间空间,并且多个超载帧前面也不被帧间空间分隔。2.4.2CAN报文的帧格式

在这里,我们以CAN2.0B协议为代表,简单的介绍一下在常用的cAN控制器寄存器中,CAN数据帧的格式。1.CAN2.0B标准帧

CAN标准帧信息为11个字节.包括两部分:信息和数据部分。前3个字节为信息部分,如图2.9所示。

注:①字节1为帧信息。第7位(FF)表示帧格式,在标准帧中,FF=0;第6位(RTR)表示帧的类型,RTR=O~,RTR=1表示为远程帧:DLC表示在数据帧时实际即数据长度。②字节2、字节3为报文识别码,11位有效。③字节4~字节11为数据帧的实际数据,远程帧时无效。2.CAN2.0B扩展帧

CAN扩展帧信息为13B,包括两部分:信息和数据部分。前5个字节为信息部分,如图2.10所示。

注:①字节1为帧信息。第7位(FF)表示帧格式,在标准帧中,FF=1:第6位(RTR)表示帧的类型,RTR=0表示为数据帧,RTR=l表示为远程帧;DLC表示在数据帧时实际的数据长度。②字节2~字节5为报文识别码,29位有效。③字节6~字节13为数据帧的实际数据,远程帧时无效。至于数据帧对于不同的CAN上层协议,存在着不同的定义。例如,在HiLon协议A和HiLon协议B中,支持广播和点对点传送命令数据。命令数据包可长达256B。我们在后面介绍相关CAN应用层协议时,再做介绍。2.5位定时与位同步2.51位定时与位同步的概念臣原理简述CAN总线的数据传输速率最高可达IMb/s,通常用石英晶振作为时钟发生器,可以独立进行位定时的参数设置,这样即使网络中节点之间的时钟周期不一样仍可获得相同的位速率。但网络中晶振的频率不是绝对稳定的,温度、电压以及器件的异常都会导致微小的差别,但只要将其稳定在振荡器容差范围之内,总线上的节点会通过重同步进行弥补。

与CAN总线有关的位定时和位同步包括以下的一些基本概念。(1)正常位速率在非重同步情况下,借助理想发送器每秒发送的位数。(2)正常位时间正常位速率的倒数。也就是传送一位数据的时间,它可被分为几个互相没有重叠的时间段。其中包括同步段(SYNC-SEG)、传播时间段(PROP-SEG)、相位缓冲段1(PHASE—SEGI)和相位缓冲段2(PHASE-SEG2),具体结构如图2.11所示。(3)同步段同步段用于同步总线上的各个节点,在此段内期望有一个跳变沿出现。如果跳变沿出现在同步段之外,那么沿与同步段之间的长度叫做沿相位误差。采样点位于相位缓冲段1的末尾和相位缓冲段2开始处。传播时间段用于补偿总线上信号传播时间和电子控制设备内部的延迟时间。因此,要实现与位流发送节点的同步,接收节点必须移相。CAN总线非破坏性仲裁规定,发送位流的总线节点必须能够收到同步于位流的CAN总线节点发送的显性位。(4)传播时间段用于补偿网络内部的传输延迟时间,它是信号在总线上传播的时间、输入比较器延迟和驱动器延迟之和的两倍。(5)相位缓冲段1和相位缓冲段2

用于补偿沿的相位误差,通过重同步,这两个时间段可被延长或缩短。(6)采样点它是一个这样的时间点,在该点上,仲裁电平被读取,并被理解为各位的数值。它位于相位缓冲段1的终点。(7)信息处理时间由采样点开始,保留用于计算子序列位电平的时间。(8)时间份额由振荡器周期派生出的一个固定时间单元,存在一个可编程的分度值,其整体数值范围为1~32,以最小时间份额为起点。时间份额可表示为:时间份额=m×最小时间份额(其中m为分度值)

正常位时间中各时间段长度数值分别为:同步段为一个时间份额;传播时间段长度可编程为1个~8个时间份额;相位缓冲段1可编程为1个--8个时间份额;相位缓冲段2长度为相位缓冲段1和信息处理时间的最太值;信息处理时间长度小于或等于2个时间份额。在位时间中,时间份额的总数必须被编程为8个~25个。(9)硬同步硬同步后,内部位时间从同步段重新开始。因而,硬同步强迫由于硬同步引起的沿处于重新开始的位时间同步段之内。(10)重同步跳转宽度由于重同步的结果,相位缓冲段1可被延长或相位缓冲段2可被缩短。这两个相位缓冲段的延长或缩短的总和上限由重同步跳转宽度给定。重同步跳转宽度可编程为1个~4个。时钟信息可由一位数值到另一位数值的跳转获得。由于总线上出现连续相同位的位数的最大值是确定的,这提供了在帧期间重新将总线单元同步于位流的可能性。可被用于重同步的两次跳变之间的最大长度为29个位时间。(11)沿相位误差沿相位误差由沿相对于SYNC-SEG的位置给定,以时间份额度量。相位误差的符号定义如下:如果沿处于同步段之内,则e=0:如果沿处于采样点之前,则e>0;如果沿处于前一位的采样点之后,则e<0。(12)重同步当引起重同步沿的相位误差小于或等于重同步跳转宽度编程值时,重同步的作用与硬同步相同。当相位误差太于重同步跳转宽度且相位误差为正时,相位缓冲段1延长总数为重同步跳转宽度。当相位误差大于重同步跳转宽度且相位误差为负时,则相位缓冲段2缩短总数为重同步跳转宽度。(13)同步规则硬同步和重同步是同步的两种形式。它们遵从下列规则:①在一个位时间内仅允许一种同步。②只要在先前采样点上监测到的数值与总线数值不同,沿过后立即有一个沿用于同步。③在总线空闲期间,当存在一个隐位至显位的跳变沿时,则执行一次硬同步。④所有履行以上规则①和②的其他隐位至显位的跳变沿都将被用于重同步。例外情况是,对于具有正相位误差的隐位至显位的跳变沿,只要隐位至显位的跳变沿被用于重同步,发送显位的节点将不执行重同步。位时间各组成部分的比较如表2.1所示。2.5.2位定时与位同步的作用

在CAN总线中,位定时有一点小的偏差就会导致总线性能严重下降。虽然在许多情况下,位同步会修补由于位定时设置不当而产生的错误,但不能完全避免出错情况.并且在遇到两个或多个CAN节点同时发送的情况时,错误的采样点会使节点启动错误认可标志,使节点不能赢得总线上的任何活动。传播时间段>=延迟A到B+延迟B到A

传播时间段>=2×(节点A的输出延迟+总线上的传输时间+节点口的输入延迟)

在这个例子里,节点A和节点丑都是发送节点,因此总线要对两个节点进行仲裁。节点A比节点丑提前发送不到1个位时间,当节点B收到延迟后的跳变沿时,B节点要同步于A节点,对位时间进行移相。移相后节点B发送的标识号有较高优先级,因此节点B赢得总线的使用权,如图2.12所示节点嚣发送的显性位经过延迟后到达节点A。

因为存在振荡器容差,节点A的采样点在相位缓冲段的位置是不能确定的,所以节点丑发送的位流必须在A节点的相位缓冲段1开始之前到达,因此传播时间段的长度将受到这个条件的限制。如果节点口发送一个隐性到显性的跳变沿,节点A在相位缓冲段l开始之后收到,那么节点A就有可能采样到一个隐性位,导致产生一个位错误。这样的错误只有当两个节点都参与总线仲裁,且总线比较长,节点的振荡器频率相差较大时才会出现。另外,CAN总线还提供一种采样方式,即采样3次,在相位缓冲段首尾以及相位缓冲段l、2的交界处各采样一次,并通过位定时逻辑确定位的正确值,这样就会要求额外的一个时间份额的延迟,因而需要更长的传播时间断。

同步跳转宽度规定了重同步发生时采样点在相位缓冲段内移动的距离。相位缓冲段和同步跳转宽度用来补偿振荡器容差,发生重同步时相位缓冲段会被加长或缩短。当总线发生从臆性到显性跳变时,会产生同步.其作用是控制沿与采样点之间的距离。总线节点在每个时间份额都会采样总线,并与前一次采样值进行比较,如果前一次采样值是隐性而当前的采样值是显性,那么总线节点就会发生一次同步。如果跳变沿出现在同步段的前面,沿相位错误就是负的,反之就是正的。在帧起始时,总线会进行一次硬同步。硬同步后,位时间由每个位定时逻辑单元在同步段之后重新启动.强迫引起硬同步的边沿处于重新启动位时间的同步段内。当引起重同步的铪相位错误幅值小于或等于同步跳转宽度的数值时,重同步导致位时间的延长或缩短,使采样点处于适当的位置。当沿相位误差幅值太于重同步跳转宽度时,如果相位误差为正,相位缓冲段1延长数值等于同步跳转宽度;如果相位误差为负,相位缓冲段2缩短数值等于同步跳转宽度。

通过同步,总线可以有效地滤除长度小于传播时间段与相位缓冲段1长度之和的噪声。但在一个位时间里只允许一种同步发生。除了噪声以外,绝大多数的同步都是由仲裁引起的,总线上的所有节点都要同步于最先开始发送的节点,但是由于总线延迟,节点的同步不可能达到理想的要求。如果最先发送的节点没有赢得总线仲裁,那么所有的接收节点都要重新同步于获得总线仲裁的节点。应答场的情况也是如此,总线上的接收节点都要同步于最先发送显性位的节点。但是当发送节点与接收节点的时钟周期不同并经过多次同步累加起来,振荡器容差会导致同步在仲裁场之后出现。图2.13列举了沿相位误差为正、负的两种情况,中间的图作为参考,说明了相位缓冲段如何弥补沿相位错误。2.6CAN的位仲裁技术2.6.1位仲裁技术度其原理概述CAN总线使用的是一种叫做“载波监测,多主掌控肿突避免”(csMA/CA)的通信模式。这就允许在总线上的任一设各有一定的机会取得总线的控制权来向外发送信息。如果在同一时刻有两个以上的设备欲发送信息,就会发生数据冲突,CAN总线能够实时地检测这些冲突情况并做出相应的仲裁,而使得获得仲裁的信息帧不受任何损坏的继续传送。当总线空闹时呈隐性电平,此时任何一个节点都可以向总线发送一个显性电平作为一个帧的开始。如果有两个或两个以上的节点同时发送,就会产生竞争。CAN总线解决总线竞争的方法和以太网的CSMA,CD方法比较类似,并且CAN做了改进,是按位对标识符进行仲裁。各发送节点再向总线发送电平的同时,也对总线上的电平进行读取,并与自身发送的电平进行比较,如果电平相同则继续发送下一位,不同则停止发送,退出总线竞争。剩余的节点则继续上述过程.直到总线上只剩下一个节点发送的电平,总线竞争结束,优先级最高的节点获得了总线的使用权。

CAN总线以报文为单位进行数据传送,报文的优先级结合在11位标识符中(扩展帧是29位标识符),具有最低二进制数的标识符有最高的优先级。这种优先级一旦在系统设计时被确立后就不能再被更改。总线读取中的冲突可通过位仲裁解决。图2.14是3个CAN信息帧同时发送,在总线上的竞争情况。在前5位,它们都是相同的,因此3个节点侦听到的信息和它们发出去的相同。到第6位,节点2发送一个“l”,但是,从总线上接收到的却是“0”,说明有优先级比它高的信息帧在发送,这个节点即退出发送,而变成只听模式,余下的2个节点继续发送。到了第9位,节点1发送“1”,而接收到“0”,也退出发送状态,而转成只听模式。只有节点3成功的发送完全部仲裁域位,而获得总线的控制权,继而发送完它的全部信息。注意,总线中的信号持续跟踪最后获得总线读取权的站的报文。在此例中,节点3的报文被跟踪。这种非破坏性位仲裁方法的优点在于,在网络晟终确定哪一个站的报文被传送以前,报文的起始部分已经在网络上传送了。所有未获得总线读取权的站都成为具有最高优先权报文的接收站,并且不会在总线再次空闲前发送报文。CAN具有较高的效率是因为总线仅仅被那些请求总线悬而未决的节点利用,这些请求是根据报文在整个系统中的重要性按顺序处理的。这种方法在网络负载较重时有很多优点,因为总线读取的优先级已被按顺序放在每个报文中了,这可以保证在实时系统中较低的个体隐伏时间。对于主节点的可靠性,由于CAN协议执行非集中化总线控制,所有主要通信,包括总线读取(许可)控制,在系统中分几次完成。这是实现有较高可靠性的通信系统的惟一方法。2.6.2位仲裁的作用

载波监测的意思是指在总线上的每个节点在发送信息报文前都必须监测到总线上有一段时间的空闲状态。一旦此空闲状态被监测到,那么每个节点都有均等的机会来发送报文,这被称作多主掌握。冲突避免是指在两个以上节点同时发送信息时。节点本身首先会检测到出现冲突,然后采取相应的措施来解决这一冲突情况。此时优先级高的报文先发送,低优先级的报文发送会暂停。在CAN总线协议中是通过一种非破坏性的仲裁方式来实现冲突检测的。这也就意味着当总线出现发送冲突时,通过仲裁后原发送信息不会受到任何影响。所有的仲裁判别都不会破坏优先级高的报文信息内容,也不会对其发送产生任何的时延。为了达到这种“非破坏性的位仲裁方式”,CAN总线协议必须满足一些前提条件。首先,必须定义两种逻辑状态——我们在这里叫做显性位(Dominant)和隐性位(Recessive):然后,节点在发送过程中必须检测刚刚发出的状态是否就是信息中所描述的内容。在CAN总线的定义中,逻辑0为显性位,逻辑1为隐性位。显性位一定会在和隐性位的判别过程中获胜,从这个角度来看,CAN总线系统就相当于一个大的与门。换句话说,报文标记区(报文仲裁专用区域)的值越小,其优先级就越高。假定有两个节点在同一时刻发送一个报文,每个节点都会监测总线以便了解欲发送的信息状态是否确实出现在总线上。一个优先级较低的报文在某一时刻会发送一个“隐牲位”但是检测回来的却是“显性位”。此时这个节点被仲裁为发送权取消,立刻停止发送报文的工作。优先级较高的报文继续发送直到完整的报文发送完毕。在刚才冲突仲裁中被取消发送权的节点将等待总线的下一个空闲期并自动地再次尝试发送。

虽然上述的仲裁方式有着许多的优点,但是它也存在一些不足和局限性。显而易见,由于CAN总线采用的是固定的优先级,所以当总线上的数据量较大时,由前面介绍的仲裁方法我们可知:当所有的节点都随机的向总线上发送数据时,具有低优先级的节点总是比具有高优先级的节点有较大的发送失败的几率。也就是说,当具有高优先级的节点以足够高的频率向总线上发送数据时,如果考虑一种最坏的情况。那么具有较低优先级的节点可能每次要求向总线上发送数据的时候都有一个具有更高优先级的节点同时也要求发送,那么每次具有较低优先级的节点都会在总线竞争中失败,从而导致它一个数据都发送不出去,或者发送的数据都有较大的延时,对采样或控制来说,当延时超过某个预定值时,接收到的数据就已经失去了实际的意义。这种情况在实际的工业应用中是可能出现的,并且是不利于我们采集数据和控制过程的。在采样或控制过程中,我们希望各个节点无论是采样还是执行控制,都应该是平等的,也就是说它们发送的数据对控制而言具有同等的重要性,在许多的环境中实际情况都是这样。所以我们要找出一个合理的解决方案,使得所有的节点都能在它们发送的数据还有效的时候把数据发送出去,使所有的节点公平的享有总线的使用权。2.7CAN的报文滤波技术2.7.1报文滤波的原理及其用途

在CAN总线中,存在多种传送和接收暂据的方式,比如点对点、一点对多点及全局广播等几种方式。这几种方式的选择和转换就是通过CAN总线中的报文滤波技术实现的,而无需专门的调度。下面我们以SJAl000为例简单地介绍一下报文滤波的原理和用途。在SJAl000中,无论是何种模式,都是CAN的某一地址存在验收滤波器中。在验收滤波器的帮助下,CAN控制器能够允许RXFIFO只接收同识别码和验收滤波器中预设值相一致的信息。只有当接收信息中的识别位和验收滤波器预定义的值相等时,CAN控制器才允许将已接收信息存入RXFIFO。验收滤波器由验收代码寄存器(ACRn)和验收屏蔽寄存器(AMRn)定义。要接收的信息的位模式在验收代码寄存器中定义。相应的验收屏蔽寄存器允许定义某些位为“不影响”(即可为任意值)。有两种不同的过滤模式可在模式寄存器中选择:①单滤波器模式。②双滤波器模式。2.7.2单滤波技术

单滤波器配置可以定义一个长滤波器(4B)。滤波器字节和信息字节之间位的对应关系取决于当前接收帧的格式。标准帧:如果接收的是标准帧格式的信息,在验收滤波中只使用前两个数据字节来存放包括RTR位的完整的识别码。如果由于置位砌喂位而导致没有数据字节,使设置相应的数据长度代码没有或只有一个数据字节,信息也会被接收的。对于一个成功接收的信息,所有单个位的比较后都必须发出接受信号。接收标准结构信息时的单个滤波器配置如图2.15所示。

为了和将来的产品兼容,AMR1和ACR1的低四位是不用的。这些位可通过设置AMR1.3、AMR1.2、AMR1.4和AMR1.0为1而定为“不影响”。

扩展帧:如果接收的信息是扩展帧格式的,包括RTR位的全部识别码将被接受过滤使用。为了成功接收信息,每个位的比较后都必须发出接受信号。接收扩展帧信息时的单滤波器配置如图2.16所示。

必须注意的是,为了和将来的产品兼容,AMR3的最低两位和ACR3是不用的。这些位应该通过置位AMR3.1和AMR3.0“不影响”。2.7.3双滤波技术

双滤波器的配置可以定义两个短滤波器,一条接收的信息要和两个滤波器比较来决定是否放入接收缓冲器中。至少有一个滤波器发出接受信号,接收的信息才有效。滤波器字节和信息字节之间位的对应关系取决于当前接收的帧格式。标准帧:如果接收的是标准帧信息,被定义的两个滤波器是不一样的。第一个滤波器比较包括RTR位的整个标准识别码和信息的第一个数据字节。第二个滤波器只比较包括RTR位的整个标准识别码,接收标准帧信息的双滤波器配置如图2.17所示。

为了成功接收信息,所有单个位的比较时应至少有一个滤波器表示接受。RTR位置位或数据长度代码是0时表示没有数据字节存在。无论怎样。只要从开始到RTR位的部分都被表示接收,信息就可以通过滤波器1。如果没有向滤波器请求数据字节过滤,AMR1和AMR3的低四位必须被置为1(不影响)。当使用包括RTR位的整个标准识别码时,两个滤波器都同样工作。

扩展帧:如果接收到扩展帧信息,定义的两个滤波器是相同的。两个滤波器都只比较扩展识别码的前两个字节。接收扩展帧信息的双滤波器配置如图2.18所示。

为了能成功接收信息,所有单个位的比较时至少有一个滤波器表示接收。2.8有关CAN总线的通信错误及其处理2.8.1CAN总线的通信错误成因及其状态描述

在CAN总线中存在5种错误类型,它们互相并不排斥,下面简单介绍一下它们的区别和成因。①位错误:向总线送出一位的某个节点同时也在监视总线.当监视到总线位数值与送出的位数值不同时,则在该位时刻检测到一个位错误。例外情况是,在仲裁场的填充位流期间或应答间隙送出隐位而检测到显位时,不视为位错误。送出认可错误标注的发送器,在检测到显位时,也不视为位错误。②填充错误:在应使用位填充方法进行编码的报文中,出现了第6个连续相同的位电平时,将检出一个位填充错误。③CRC错误:CRC序列是由发送器CRC计算的结果组成的。接收器以与发送器相同的方法计算CRC。如果计算结果与接收到的CRC序列不相同,则检出一个CRC错误。④形式错误:当固定形式的位场中出现一个或多个非法位时,则检出一个形式错误。⑤应答错误:在应答间隙,发送器未检测到显位时,则由它检出一个应答错误。

2.8.2错误检测及处理

检测到出错条件的站通过发送错误标志进行标定。当任何站检出位错误、填充错误、形式错误或应笞错误时,由该站在下一位开始发送出错标志。当检测到CRC错误时,出错标志在应答界定符后面那一位开始发送,除非其他出错条件的错误标志已经开始发送。在CAN总线中,任何一个单元可能处于下列3种故障状态之一:错误激活状态(ErrorActive)、错误认可状态(ErrorPassive)和总线关闭状态。检测到出错条件的站通过发送出错误标志进行标定。对于错误激活节点,该标志为活动错误标志;而对于错误认可节点,该标志为认可错误标志。错误激活单元可以照常参与总线通信,并且当检测到错误时,送出一个活动错误标志。错误认可节点可参与总线通信,但是不允许它送出活动错误标志,它当检测到错误时,只能送出认可错误标志,并且发送后仍为错误认可状态,直到下一次发送初始化。总线关闭状态不允许单元对总线有任何影响。

为了界定故障,在每个总线单元中都设有两种计数:发送出错计数和接收出错计数。这些计数按照下列规则进行:①接收器检出错误时,接收器出错计数器加1.除非所检测错误是发送活动错误标志或超载标志期间的位错误。②接收器在送出错误标志后的第一位检出一个显位时,接收器错误计数器加8。③发送器送出一个错误标志时,发送器错误计数器加8。其中有两个例外情况:一个是如果发送器为错误认可,由于未检测到显位应答或检测到一个应答错误,并且在送出其认可错误标志时,未检测到显

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论