CAN总线位定时和同步机制的分析

来源:互联网 发布:如何下载解压软件 编辑:程序博客网 时间:2024/05/21 11:00

摘要:CAN总线位定时参数可以由用户来编程设置,合理的设置位定时能够有效保证位流的同步,提高CAN总线的通讯性能。本文详细分析了CAN总线的位定时和同步机制,并给出了重同步时重同步跳转宽度与相位差补偿的关系。

关键词:CAN总线,位定时,同步。

1 引言

CAN(Controller Area Network)是有效支持分布式实时控制的串行通讯网络。从位定时的同步方式考虑,它实质上属于异步通讯协议,每传输一帧,以帧起始位开始,而以帧结束及随后的间歇场结束。这就要求收/发双方从帧起始位开始必须保持帧内信息代码中的每一位严格的同步。从位定时编码考虑,它采用的是非归零编码方式,位流传输不像差分码那样可以直接用电平的变化来代表同步信号,因此为保证同步质量,CAN协议定义了自己的位同步方式:硬同步和重同步。

目前相关文献12均缺乏对CAN总线位定时与同步机制的详细分析。本文深入分析了CAN总线位周期的结构以及CAN的两种位同步方式3 (硬同步和重同步),并明确给出了重同步时重同步跳转宽度和相位差补偿的关系,对于指导位定时参数的设置有较好的参考价值。

2 位周期的结构



3 同步机制

CAN总线的位同步只有在节点检测到“隐性位”(逻辑1)到“显性位”(逻辑0)的跳变时才会产生,当跳变沿不位于位周期的同步段之内时将会产生相位误差。该相位误差就是跳变沿与同步段结束位置之间的距离。如果跳变沿发生在同步段之后采样点之前为正的相位误差;如果跳变沿位于同步段之前采样点之后为负的相位误差。相位误差源于节点的振荡器漂移,网络节点之间的传播延迟以及噪声干扰等。CAN协议规定了两种类型的同步:硬同步和重同步。

3.1硬同步

硬同步只在总线空闲时通过一个下降沿(帧起始)来完成,此时不管有没有相位误差,所有节点的位时间重新开始。强迫引起硬同步的跳变沿位于重新开始的位时间的同步段之内。

3.2重同步

在消息帧的随后位中,每当有隐性位到“显性位”的跳变,并且该跳变落在了同步段之外,就会引起一次重同步。重同步机制可以根据跳变沿增长或者缩短位时间以调整采样点的位置,



保证正确采样。

如图2,跳变沿落在了同步段之后采样点之前,为正的相位误差,接收器会认为这是一个慢速发送器发送的滞后边沿。此时节点为了匹配发送器的时间,会增长自己的相位缓冲段1(阴影部分)。增长的时间为相位差的绝对值,但是上限是重同步跳转宽度SJW

如图3,跳变沿落在了采样点之后同步段之前,为负的相位误差,接收器把它解释为一个快速发送器发送的下一个位周期的提前边沿。同样节点为了匹配发送器的时间,会缩短自己的相位缓冲段2(阴影部分),下一个位时间立即开始。缩短的时间也为相位差的绝对值,上限是重同步跳转宽度SJW

相位缓冲段只在当前位周期内被增长或者缩短,接下来的位周期,只要没有重同步,各段将恢复为位时间的编程预设值。

当相位差的绝对值小于或者等于重同步跳转宽度SJW时,重同步和硬同步的效果是相同的,能实现相位差的补偿;但是如果相位差的绝对值比重同步跳转宽度大,由于补偿的最大值是重同步跳转宽度,致使重同步不能完全补偿相位差。


CAN协议的位填充机制除实现仲裁场,控制场,数据场和CRC序列的数据的透明性外,还增加了从“隐性位”到“显性位”跳变的机会,也就是增多重同步的数量,提高同步质量。在没有出错影响的情况下,位填充原则保证了两次重同步跳转边沿之间不会多于10个位周期(即5个显性位,5个隐性位),而实际的系统会有错误发生,使得实际的两次重同步跳转边沿之间的间隔可能为1723个位时间(活动错误标志及其叠加612个位时间,错误界定符8个位时间,间歇场3个位时间)。

4 结论

在实际的系统设计中,用户可以根据振荡器时钟频率,总线波特率以及总线的最大传输距离等因素,对CAN控制器的位定时参数进行优化设置4,5,协调影响位定时设置的两个主要因素:振荡器容差和最大总线长度,合理安排位周期中采样点的位置和采样次数,保证总线上位流的有效同步的同时,优化系统的通讯性能,进一步推进CAN总线的广泛应用。

参考文献:

[1]阳宪惠,现场总线技术及其应用,北京:清华大学出版社,1996.

[2]饶运涛,现场总线CAN原理与应用技术,北京:北京航空航天大学出版社,2003.

[3]Wolfhard LawrenzCAN System Enginnering From Theory To Practical ApplicationSpring-VerlagNew York1997.

[4] Egon Jöhnk, Klaus Dietmayer, Determination of Bit Timing Parameters for the CAN Controller SJA 1000, Philips Semiconductor Application Note, 1997.

[5] Stuart Robb, CAN Bit Timing Requirements, Motorola Semiconductor Application Note, 1999.

0 0
原创粉丝点击