CAN的原理及应用

发布时间:2011-10-08 08:22:15

CAN的原理及应用

当前汽车应用开发人员正面临着众多设计挑战,由于现代汽车增加了更多电子功能,对低功耗和更小印刷电路板的需求也越来越强烈,所有这些都表明在诸如车身控制和传动系统等应用领域中这样的特性将曰益重要。 qT_ev__$t 0 L/ V W( i9 S6 @' R

如今汽车中的绝大多数电子控制单元互相之间都有连接,但汽车制造商对不同的应用使用了不同的总线系统。例如传动系统和制动系统多数通过控制器局域网络(CAN)来联系,而通讯不太密集的应用(如车窗升降电机和控制车镜的按键)则可能使用局域互联网络(LIN)协议。本文将论述怎样利用LIN总线来满足汽车业所需要的新增电子功能,并同时确保低功耗以及使用较小面积的PCB

1LIN在汽车上的典型应用领域。

LIN协议由欧洲汽车制造商协会设计,是一种低成本短距离低速网络。它旨在传送开关设置和传感器输入等状态的变化,并对这类变化做出响应,因此可用于传送发生时间约为几分之一秒的事件,并不适用于汽车应用中的高速事件(如引擎管理)LIN的另一个目的是利用该协议的简单性降低系统成本,以便能够方便地在质优价廉的8位单片机中实现。LIN总线协议的最新版本是V2.0,可以在LIN联盟的网站(www.lin-subbus.de)上得到。

LIN支持单线双向通讯,采用廉价的由RC振荡器驱动的单片机,可省掉晶体振荡器或陶瓷振荡器的费用。虽然LIN降低了系统总成本,但在时间和软件上却要付出代价,每条报文都必须经过一个自动确定波特率的过程。LIN协议支持最高20kbps传输速率,以及一个低功耗休眠模式,此时总线将被关闭,不再消耗汽车电池。采用8位单片机并结合外部或内部RC有助于降低系统成本,并减少PCB实际的面积。

1显示了LIN在汽车中的典型应用。总线上的地电位信号为显性状态,只要任何节点将总线电压拉低,就会出现这一状态。当总线处于电池电压且所有节点都使总线处于悬空状态时,会出现隐性状态。在空闲状态下,总线通过上拉电阻悬空为高电平。

LIN总线的工作电压范围为918V,但总线上所有部件都必须能够承受40V电压。通常,单片机通过线路驱动器/接收器与总线隔离,这种方案下总线每个节点都端接为VBAT电平,主节点通过1kΩ电阻端接,从节点则通过20-47kΩ的电阻端接。总线最大设计长度为40

每个字节都利用起始位和停止位作为头尾标志位。起始位与空闲状态相反,为0,而停止位则等同空闲状态(1)。在每个字节内,数据从最低位(LSB)开始传送。

2LIN网络在车镜控制上的应用。

主节点用于控制LIN总线,它通过对从节点进行查询,将数据发布到总线上。从节点仅在主节点的命令下发送数据,从而在无需仲裁的情况下实现双向通讯。报文的传送是在主节点发出一个同步间隔脉冲后开始的,然后跟随的是同步字段和报文字段。主节点通过在每个报文的开始处发送同步字段可设定整个总线时钟。

每条报文的第二字节是一个标识符字节,它告诉LIN总线随后将发送的是什么数据,并指明哪个节点应该应答及应答的长度是多少。对于给定的命令,只有一个从节点可以应答。

从节点仅在主节点的控制下在LIN总线上发送数据。一旦数据发布到总线上,任何节点都可以接收该数据。因此,一个从节点向其它从节点发送数据无需主节点干预。

由于LIN协议使用低成本RC振荡器,因此从节点必须检测主节点每次发送的波特率,并调整为当前速率,所以每次通讯都以同步字段开始,它是一个01交替出现的字节。

同步字段之后是标识符字段,它告诉LIN总线接着出现的内容。该字段进一步分为三个子字段:4(0-3)用于对总线上的设备进行寻址;2(4-5)指明此后报文的长度,最后2(6-7)用于奇偶校验。

除休眠命令之外,LIN协议没有定义任何报文的内容,其它命令是在具体应用中定义的。

错误检测;以下

错误必须在每一节点处进行检测和计数,一旦出现错误,该命令就要被丢弃,并记录这一错误事件。 !~rlb [[h~ . Q" h% M. C2 I- v' _

位错误——正在发送的节点应该对希望发送的数据与总线上实际出现的数据进行比较,控制器必须等待足够时间以确保总线对发出的数据做出反应,然后才可测试这一数据。假定总线响应信号的最小边沿变化速率为1V/μs,最大总线电压为18V,那么发送器应等待18μs后才可进行测试。 _bW!Q{L_K_

4 e. y$ f; |+ F2 c' }/ K( V校验和错误——每条报文的数据内容都受到校验和字节的保护,该字节是数据字节相加后取256模的余数再取反的结果。 \V _v!WHc8 4 |1 o; R9 i; f. S3 J* r

奇偶校验——命令字节使用2个奇偶位来保护其它6个数位,这两个数位在接收后要重新计算,再与接收结果进行比较。该协议没有定义直接错误报告机制,然而由于每个从节点都应自行追踪各自的错误,因此主节点可利用正常的报文协议来请求获得错误状态。那么LIN是如何满足对低功耗、低系统成本、功能增加甚至减少汽车总重量的要求呢?首先它可以方便地用软件实现LIN协议,该协议不需要单片机给予过多的硬件支持,通过使用一个简单的USART或增强型USART就可以实现。USART支持诸如自动波特率检测等功能,这意味着在LIN应用中可以使用一个简单的质优价廉的8位单片机。还有一个优点就是LIN在协议层不需要复杂的操作系统,不多的软件开销还使得设计人员能够选择存储器容量较小的单片机。 'ZmG1b_iNo

1 @# Z5 X" F0 `5 U如何运用像LIN这样的简单协议对汽车进行控制呢?以车镜控制为例,许多汽车的车镜相互之间仍是硬连接,或者在豪华型汽车中通过CAN这样的昂贵协议连接,其实利用LIN总线就可以方便地将左右车镜和四向仪(可以改变车镜位置的四方向开关)连接起来。在典型的LIN方案中,四向仪是主节点,两个车镜是从节点。四向仪读取按键的状态,将报文发送给相应的车镜。 0Rm_,_}YO}

! [0 i: ^& o; J& V那么使用LIN能够为诸如车镜控制等应用增加新功能吗?回答是不需要额外连线,就可以方便地添加其它功能,如集成式转向信号、集成式照地灯或车镜加热器。这里车镜只需要与地电位、VBATLIN总线连接,需要改动的只有主节点,它必须知道要实现哪些车镜功能。 )0EQ$)3'__

! A: R9 k' t# Q7 G- ]& Z2说明了用于车镜应用的LIN网络。为了更清楚地理解这个例子,让我们更深入地研究一下。该网络中的主节点是一个PIC18F4680 8位闪存单片机,它读取车镜选择开关和四向仪,还通过CAN总线接收报文。从CAN总线发送给主控LIN节点的报文包括左右转向信号和开门,接收到来自CAN总线的报文后,主节点通过LIN总线向从节点发出命令,如“左车镜上升或左车镜下降”。 [!dx4}**)_

- y+ N* d* Z: x" g5 }在此例中,从节点由PIC16F688 8位闪存单片机组成。PIC16F688具有一个集成的LIN收发器和一个增强型USART,其中USART能自动执行自动波特率检测。从节点收到报文并利用步进电机使车镜上升或下降。假设车镜模块没有集成式转向信号等其它功能,当从节点从LIN总线上接收到一条诸如“左转向信号”的报文时,它就会忽略这一报文或者触发I/O用于转向信号(这部分内容已超出本文讨论范围)。触发I/O的好处是无论车镜是否集成了转向信号都可应用相同的软件,只需要对硬件做适当更改即可运行,也就是说功能不同的各种车镜都可以使用同一软件。 J,___rO\[

7 T; M" z& J3 D! H: r F$ kLIN软件 +S_?,_`-_+

8 A" w9 m7 r+ M. }# O0 ULIN主节点有三个主要的软件进程,第一个进程接收CAN报文,并将其转变为LIN报文;第二个进程读取四向仪和车镜选择开关的状态;第三个进程向从节点发出报文。 ?][w___ _u

/ f3 d& q6 N: ^9 C( m* i5 j2 k如果主节点从CAN总线上接收到“左转向信号打开”的报文,它会将该报文转变成LIN协议,并发送给适当的LIN总线节点(在本例中为左车镜)。对PIC18F4680中的CAN控制器进行编程后,它可以只接收来自CAN总线的特定报文,而不会有任何其它软件开销,这一硬件过滤方式使CAN总线的通讯只有极少软件工作量。PIC18F4680也集成了一个可用于LIN总线通讯的USART,由于LIN总线主节点不必执行自动波特率检测,因此它能够通过USART发送整条报文。 c)bR_/sV|&

! N" }4 Y! ]& ^6 k0 u4 i车镜从节点有n+1个进程,其中n是车镜中集成的功能数目。如果只要控制车镜的上下左右,软件进程就只有2个,第一个是收发进程,第二个是车镜控制进程,主要驱动步进电机,其它可能的进程有“照地灯开”和“左转向信号开”。因为PIC16F688有一个增强型USART,可实现波特率检测,所以LIN通讯的软件开销非常少,这就为实现其它功能(包括检修)留出了很大余地。 XRx_/!

$ A4 M9 l% E+ [4 k3 J: L$ V本文小结 3xr _ ^*,G 9 P2 h$ P+ e' |9 ?; v

正如前面所述,LIN总线能够增加功能和降低成本,可以用软件编程实现各种特性,也可以通过软硬件功能增添新的特性,这样不同的模块就都可以用一个硬件或一个软件平台实现。LIN总线的灵活性有利于降低生产和软/硬件维护方面的成本。因为LIN总线非常简单,所以用质优价廉的8位单片机就可以实现,从而降低系统总成本。

! b$ k0 G& H6 I3 h6 ^+

本文来自: 中国汽车工程师之家( http://www.cartech8.com ) 详细出处:http://www.cartech8.com/thread-362794-1-2.html

23楼的朋友,如果你只是想修某一款车.你只要找到相关的修理手册,它就会告诉你一些网络控制基本原理.该车网络结构,怎么测量各节点参数值,怎么去根据诊断仪提示的故障代码(有的甚至直接从诊断电脑告知是什么故障),去查找故障点,该怎么排除故障.4 [! t6 { j% N ^+ Z

这就是因为由于现代汽车用了多路传输,控制系统共享信息量陡增,控制范围也就扩大了许多,使得车上的控制电脑跟普通的电脑一样,具备容错(比如:系统的降级安全模式),智能化(比如:模糊控制)功能.也由于用了电脑(ECU),很多信息可以用程序来处理(就是所谓的"软件"),这样使得在车辆控制系统中,在不增加任何装备的条件下,实现车主个性化设置.# X: C" r3 H' N' C) m

我们把前者叫诊断,后者叫配置,你只要搞懂某款车的控制系统诊断和配置方法,就可以做这款车的维修服务了。 ?( d& J- @# g3 U. Y/ I

但你如果真正想了解它的原理,那是要有一定的理论知识的,比如电子技术/控制技术/编码技术也就是数字技术,由于篇幅原因,也不是一下子能说清楚,这里有专家发表了篇比较好的文章,不知你是否曾看过,我想这对于你在这方面了解可能有些帮助。现摘录如下) w9 X8 A* S& g! H

CAN 通信协议简介% |. E3 @3 f8 T( i7 N( t; v! c

一、概述

: J4 j: `; n: E. y' f' T对于一般控制,设备间通信可以通过串行网络完成。因此,BOSCH 公司开发了CAN 总线6 J- E9 a8 A r. @% _ ^* i% K& v3 ?

(C ontroller Area Network),并已取得国际标准化组织认证(ISO11898),其总线结构5 X1 _, K8 }) h2 J7 t E

可参照I SO/OSI 参考模型。同时,国际上一些大的半导体厂商也积极开发出支持CAN

; y: \" x, Z8 T" S线的专用芯片。通过CAN 总线,传感器、控制器和执行器由串行数据线连接起来。它不1 X$ n; _- m& v# H/ k+ H5 b4 f

仅仅是将电缆按树形结构连接起来,其通信协议相当于ISO/OSI 参考模型中的数据链路

' v( z: J' b& l3 Q: T7 D4 B# h% f,网络可根据协议探测和纠正数据传输过程中因电磁干扰而产生的数据错误。CAN 网络. O% h; T% x2 ]+ |) p5 k- f

的配制比较容易,允许任何站之间直接进行通信,而无需将所有数据全部汇总到主计算

* q {" w3 A9 h/ a机后再行处理。

+ e$ M9 f( w, X8 C8 J; p二、CAN 在国外的发展" r5 X6 V% x- y( t e' [+ Q7 Y

对机动车辆总线和对现场总线的需求有许多相似之处,即较低的成本、较高的实时处% C8 D& `: `5 M1 Q& S

理能力和在恶劣的强电磁干扰环境下可靠的工作。奔驰S 型轿车上采用的就是CAN 总线6 V: O" o! L( q! b' M' g

系统;美国商用车辆制造商们也将注意力转向CAN 总线;美国一些企业已将CAN 作为内部1 T/ j; L B- h% X" T' \& m9 K

总线应用在生产线和机床上。同时,由于CAN 总线可以提供较高的安全性,因此在医疗领

: |' j( c- D, R9 G* ~域、纺织机械和电梯控制中也得到广泛应用。

& I6 g7 a5 W+ I$ X3 l, T5 C) T h三、CAN 的工作原理

) ?" t- a# n+ CCAN 总线上的一个节点()发送数据时,它以报文形式广播给网络中所有节点。对

% l5 W2 K x X6 v/ T' H每个节点来说,无论数据是否是发给自己的,都对其进行接收。每组报文开头的11 位字1 B+ N7 V5 Y- C+ t" r c9 W

符为标识符,定义了报文的优先级,这种报文格式称为面向内容的编址方案。在同一系统

4 T5 p# L% }" c0 A" o8 Q4 v中标识符是唯一的,不可能有两个站发送具有相同标识符的报文。当几个站同时竞争总

; a6 S7 B- O, e3 x线读取时,这种配置十分重要。

- q/ P7 B! i+ x* ^9 GCAN 总线的报文发送和接收参见图1。当一个站要向其它站发送数据时,该站的CPU 将要4 p# J f3 h) k! o& W

发送的数据和自己的标识符传送给本站的CAN 芯片,并处于准备状态;当它收到总线分配9 H$ U+ e4 K* v5 J0 U

, 转为发送报文状态。CAN 芯片将数据根据协议组织成一定的报文格式发出,这时网上

/ Z0 s4 ?5 b6 H的其它站处于接收状态。每个处于接收状态的站对接收到的报文进行检测,判断这些报8 |0 |# _- @8 L: }

文是否是发给自己的,以确定是否接收它。

" n1 ^ f$ D! B+ T# p; Q由于CAN总线是一种面向内容的编址方案,因此很容易建立高水准的控制系统并灵活" J3 k- ?+ \% Z0 G! i' g5 W

地进行配置。我们可以很容易地在CAN 总线中加进一些新站而无需在硬件或软件上进行$ k* \3 C3 u$ \7 d4 Z1 ]6 Y1 v. M

修改。当所提供的新站是纯数据接收设备时,数据传输协议不要求独立的部分有物理目 x# A8 w4 u% G

的地址。它允许分布过程同步化,即总线上控制器需要测量数据时,可由网上获得,而无

. z4 q# y9 }$ @: C/ w+ j- P须每个控制器都有自己独立的传感器。

( e6 {0 n8 p- s1 @2 u四、位仲裁

: u! y; B% B1 A6 t/ m; P7 O! F1 p要对数据进行实时处理,就必须将数据快速传送,这就要求数据的物理传输通路有较+ A1 o' K0 x# s

高的速度。在几个站同时需要发送数据时,要求快速地进行总线分配。实时处理通过网2 G/ G5 h; h9 Y, |0 Q+ n$ G6 c f) d6 q

络交换的紧急数据有较大的不同。一个快速变化的物理量,如汽车引擎负载,将比类似汽) o- ^( Z) F4 h3 X7 k P* `

车引擎温度这样相对变化较慢的物理量更频繁地传送数据并要求更短的延时。. P+ p+ }4 {' ~0 ~4 Q# n# h

CAN 总线以报文为单位进行数据传送,报文的优先级结合在11 位标识符中,具有最低

& g7 W; {+ V+ H二进制数的标识符有最高的优先级。这种优先级一旦在系统设计时被确立后就不能再被

: w1 D. Z3 ^& W5 y& Q9 v" Z+ r更改。总线读取中的冲突可通过位仲裁解决。如图2 所示,当几个站同时发送报文时,! \! i) d1 i W! R+ u0 B

1 的报文标识符为011111;2 的报文标识符为0100110;3 的报文标识符为0100111

. _ b0 m* Z6 l3 d所有标识符都有相同的两位01,直到第3 位进行比较时,1 的报文被丢掉,因为它的第# j' o' v1 M, o# {, Y3 ? k" ?" F

3 位为高,而其它两个站的报文第3 位为低。站2 和站3 报文的456 位相同,直到第

$ w5 T" o- v& a" Q2 h7 位时,3 的报文才被丢失。注意,总线中的信号持续跟踪最后获得总线读取权的站的

9 y) {7 _4 k! l8 f: a$ |4 {报文。在此例中,2 的报文被跟踪。这种非破坏性位仲裁方法的优点在于,在网络最终

$ L1 }6 Y4 g- z' p6 V0 b o确定哪一个站的报文被传送以前,报文的起始部分已经在网络上传送了。所有未获得总

% D" p) c% [6 | R8 P线读取权的站都成为具有最高优先权报文的接收站,并且不会在总线再次空闲前发送报# w. x0 U- o6 b! [* F

文。1 L8 c7 P7 g( y+ ~9 x. P0 q( r

CAN 具有较高的效率是因为总线仅仅被那些请求总线悬而未决的站利用,这些请求是) s4 O0 Z- }% \7 ~% q* K% A

根据报文在整个系统中的重要性按顺序处理的。这种方法在网络负载较重时有很多优点,% [9 s5 M/ |5 m/ u

因为总线读取的优先级已被按顺序放在每个报文中了,这可以保证在实时系统中较低的

, S! s) w/ `! _# t' o" y个体隐伏时间。

2 H; Y9 A% \8 L3 }) m! O$ x3 b1 B对于主站的可靠性,由于CAN 协议执行非集中化总线控制,所有主要通信,包括总线读. O, I5 l+ o n# ?4 I4 V

(许可)控制,在系统中分几次完成。这是实现有较高可靠性的通信系统的唯一方法。

- T) s' X# U$ Y8 \, J五、CAN 与其它通信方案的比较

5 N5 e: b# M: G在实践中,有两种重要的总线分配方法:按时间表分配和按需要分配。在第一种方法$ x9 L0 ~7 L) v3 R1 s( d" L

,不管每个节点是否申请总线,都对每个节点按最大期间分配。由此,总线可被分配给

9 o8 j, c& n H4 u8 ]- O# q每个站并且是唯一的站,而不论其是立即进行总线存取或在一特定时间进行总线存取。) O \, V* A1 n/ S9 Z2 ]. v

这将保证在总线存取时有明确的总线分配。在第二种方法中,总线按传送数据的基本要

* f& A! N( _4 ?$ d' M) T求分配给一个站 ,总线系统按站希望的传送分配(:Ethernet CSMA/CD)。因此,当多个

, W1 b& Q- X( c' P* p6 u- q/ U- ~$ j站同时请求总线存取时,总线将终止所有站的请求,这时将不会有任何一个站获得总线

2 p) _& r) C, j8 a* F分配。为了分配总线,多于一个总线存取是必要的。

- e2 F0 a4 b# x( N- g' VCAN 实现总线分配的方法,可保证当不同的站申请总线存取时,明确地进行总线分配。这7 `$ f. W: `1 W( a" d# d! U6 f1 b

种位仲裁的方法可以解决当两个站同时发送数据时产生的碰撞问题。不同于Ethernet4 {) w3 D# J) }6 m

网络的消息仲裁,CAN 的非破坏性解决总线存取冲突的方法,确保在不传送有用消息时总

/ s# O i+ s6 c5 i- o$ c线不被占用。甚至当总线在重负载情况下,以消息内容为优先的总线存取也被证明是一/ M. H) c9 ~8 P5 V

种有效的系统。虽然总线的传输能力不足,所有未解决的传输请求都按重要性顺序来处! |7 o) L" h# _6 X2 h9 [

理。在CSMA/CD 这样的网络中,Ethernet,系统往往由于过载而崩溃,而这种情况在CAN

* ]8 u( E ?* M6 z: p: ^5 Y中不会发生。

/ ]# g* M9 ]* _6 D; U5 b* u六、CAN 的报文格式

! v/ u, {3 c9 e$ e6 j9 C; f在总线中传送的报文,每帧由7 部分组成,见图3CAN 协议支持两种报文格式,其唯. y# @9 U/ m4 ~$ ]6 ~& @4 L

一的不同是标识符(ID) 长度不同, 标准格式为11 , 扩展格式为29

1 i% F. G7 l- j* F$ W% M位。 @@TB17125002.GIF;% V: b' I0 r% g5 v4 R) L2 c- G* f

在标准格式中,报文的起始位称为帧起始(SOF),然后是由11 位标识符和远程发送请

: w1 T5 x' A* j求位 (RTR)组成的仲裁场。RTR 位标明是数据帧还是请求帧,在请求帧中没有数据字节。- A- K' s2 i. F7 n) Q0 f

控制场包括标识符扩展位(IDE),指出是标准格式还是扩展格式。它还包括一个保留. j7 k: @/ t7 w, ^9 f8 m, ?

(ro),为将来扩展使用。它的最后四个字节用来指明数据场中数据的长度(DLC)。数' Y2 [; }$ P% P6 @/ l( q/ Y

据场范围为08 个字节,其后有一个检测数据错误的循环冗余检查(CRC)

! Q4 \" U; l! I" c3 K. b4 e4 R+ C应答场(ACK)包括应答位和应答分隔符。发送站发送的这两位均为隐性电平(逻辑1),- |" y! D. B X) C! |, w6 Y

这时正确接收报文的接收站发送主控电平(逻辑0)覆盖它。用这种方法,发送站可以保证6 T# ]6 \7 e$ w# g8 h2 i

网络中至少有一个站能正确接收到报文。

' s3 r) s' y7 q, }; E8 t报文的尾部由帧结束标出。在相邻的两条报文间有一很短的间隔位,如果这时没有站% o3 a8 r- S/ w' ^/ J$ }

进行总线存取,总线将处于空闲状态。5 T. m0 a* M0 ]% [+ o4 h

七、数据错误检测8 H+ h) [6 D: Y% d0 W' ]' r- W

不同于其它总线,CAN 协议不能使用应答信息。事实上,它可以将发生的任何错误用信号9 g, [( S: O9 X

发出。CAN 协议可使用五种检查错误的方法,其中前三种为基于报文内容检查。

% b* J$ j) M6 [+ E$ B2 n& E1.循环冗余检查(CRC)2 _* I) } P1 b4 p! H0 C* i

在一帧报文中加入冗余检查位可保证报文正确。接收站通过CRC 可判断报文是否有

G( b5 D, M1 [$ k6 t错。

6 R7 e8 a$ B5 A+ k1 U# q2.帧检查

2 ^+ s6 T; p* j; L4 c+ Y这种方法通过位场检查帧的格式和大小来确定报文的正确性,用于检查格式上的错! g0 m) {5 |6 l% Z( h- j+ r

误。! n" }; U3 T1 l {2 r. k

3.应答错误( t3 x0 {* Z' W! J" w# ^

如前所述,被接收到的帧由接收站通过明确的应答来确认。如果发送站未收到应答,

$ H% A+ y9 T# y1 l那么表明接收站发现帧中有错误,也就是说,ACK 场已损坏或网络中的报文无站接收。CAN `3 s# E; t1 Z7 e4 b

协议也可通过位检查的方法探测错误。+ z1 t# |5 _# a4 p$ n. Y1 s

4.总线检测' d7 ^9 k# N2 v1 s+ U

有时,CAN 中的一个节点可监测自己发出的信号。因此,发送报文的站可以观测总线电

' U9 ?7 j7 [ ]! m7 b平并探测发送位和接收位的差异。

$ |7 T6 j" [% n5 M5.位填充& ~7 Y0 |% Y" v9 R9 F2 {

一帧报文中的每一位都由不归零码表示,可保证位编码的最大效率。然而,如果在一

: U3 k# P. i2 p1 \帧报文中有太多相同电平的位,就有可能失去同步。为保证同步,同步沿用位填充产生。/ t, g- i& ^! x, g+ j. a" r2 Q1 `8 \, r, A

在五个生。在五个连续相等位后,发送站自动插入一个与之互补的补码位;接收时,这个8 B( d% \* r. q3 {7 ^9 }

填充位被自动丢掉。例如,五个连续的低电平位后,CAN 自动插入一个高电平位。CAN 0 \" d7 T) l' C

过这种编码规则检查错误,如果在一帧报文中有6 个相同位,CAN 就知道发生了错误。

) `3 E h' z' p/ n如果至少有一个站通过以上方法探测到 一个或多个错误,它将发送出错标志终止当1 M$ n$ m8 \, m' y3 }3 O# A+ V

前的发送。这可以阻止其它站接收错误的报文,并保证网络上报文的一致性。当大量发

* [ u$ F# M6 O) [送数据被终止后,发送站会自动地重新发送数据。作为规则,在探测到错误后23 个位周7 \$ ^3 w2 t# p) b( n: \

期内重新开始发送。在特殊场合,系统的恢复时间为31 个位周期。0 X7 {( z' z2 R# m p2 G

但这种方法存在一个问题,即一个发生错误的站将导致所有数据被终止,其中也包括

4 k/ d* S }7 ^% A5 a7 a正确的数据。因此,如果不采取自监测措施,总线系统应采用模块化设计。为此,CAN 协议

& F" y0 r5 P6 A' N- B' v2 @提供一种将偶然错误从永久错误和局部站失败中区别出来的办法。这种方法可以通过对6 e+ h' p2 S [6 l9 Q& z! A+ G2 H0 \

出错站统计评估来确定一个站本身的错误并进入一种不会对其它站产生不良影响的运

; F7 i5 p8 m% O# C% O) k行方法来实现,即站可以通过关闭自己来阻止正常数据因被错误地当成不正确的数据而

8 s; B7 a' U; }% o被终止。

9 ?% B% U4 S- O八、CAN 的可靠性

6 E6 p) |2 v' @3 r- r. E1 h- t; h为防止汽车在使用寿命期内由于数据交换错误而对司机造成危险,汽车的安全系统

) E6 A0 g: A+ F ^. z9 S要求数据传输具有较高的安全性。如果数据传输的可靠性足够高,或者残留下来的数据9 O; y4 F5 i$ {" x% [9 I, G; {. O

错误足够低的话,这一目标不难实现。从总线系统数据的角度看,可靠性可以理解为,

! {/ s% m/ V! _7 u: U" {0 W# X传输过程产生的数据错误的识别能力。# ? b9 Y: `4 c8 ~

残余数据错误的概率可以通过对数据传输可靠性的统计测量获得。它描述了传送数8 ^" W5 J1 i, k% G" h

据被破坏和这种破坏不能被探测出来的概率。残余数据错误概率必须非常小,使其在系1 }# V B4 G1 m6 }& F$ y4 S$ K

统整个寿命周期内,按平均统计时几乎检测不到。计算残余错误概率要求能够对数据错

0 e. P3 g/ O3 r0 X f误进行分类 ,并且数据传输路径可由一模型描述。如果要确定CAN 的残余错误概率,

7 i; d1 r, O) c- T% R2 @们可将残留错误的概率作为具有8090 位的报文传送时位错误概率的函数,并假定这个

1 ^! D1 _+ D; }6 |; }/ }/ F系统中有510 个站,并且错误率为1/1000,那么最大位错误概率为10—13 数量级。例

# z% u; u1 }7 o+ S3 b$ w# l,CAN 网络的数据传输率最大为1Mbps,如果数据传输能力仅使用50%,那么对于一个工

. M% ^7 C' A! N w3 m) |作寿命4000 小时、平均报文长度为 80 位的系统,所传送的数据总量为9×1010。在系$ ?' ]6 H$ `( }6 @0 }

统运行寿命期内,不可检测的传输错误的统计平均小于10—2 量级。换句话说,一个系统- G2 H" K5 J1 w5 @$ J

按每年365 ,每天工作8 小时,每秒错误率为0. 7 计算,那么按统计平均,1000 年才 j: p/ i- y9 P9 r0 d- S! g

会发生一个不可检测的错误。

本文来自: 中国汽车工程师之家( http://www.cartech8.com ) 详细出处:http://www.cartech8.com/thread-362794-1-2.html

CAN的原理及应用

相关推荐