当前位置:首页 > 智能硬件 > 智能硬件
[导读]CAN通信中,波特率、位周期内取样点数和位置可以编程设置,这些设置为用户根据其应用优化网络通信性能提供了方便。

摘要:CAN通信中,波特率、位周期内取样点数和位置可以编程设置,这些设置为用户根据其应用优化网络通信性能提供了方便。优化位定时参数,能够保证信息同步,保证传输延迟和时钟误差在极端条件下进行恰当的错误检测。本文说明位定时参数的确定方法。

    关键词:CAN总线 位定时 同步 延迟

引言

CAN总线是一种有效支持分布式控制和实时控制的、多主的异步串行通信网络。由于CAN总线具有较强的纠错能力,支持差分收发,适合高噪声环境,具有较远的传输距离,并且Philips和Intel等半导体公司都有支持CAN通信协议的集成器件。CAN总线已经在各个领域中得到了广泛应用。

在CAN通信协议中规定,通信波特率、每个位周期的取样位置和个数,都可以自行设定。这样的设计理念,为用户在自己的应用中,优化网络通讯性能提供了空间。为了通过设定位定时参数来优化网络通信性能,必须清楚位定时参数与参考时钟误差和系统内信号延迟的关系。如果位周期内的取样位置偏后,将能够容忍较大的信号传输延迟,相应的,总线传输距离可以延长;而如果周期内的取样位置接近中间,则可以容忍系统的节点间的参考时钟误差。但这显然是矛盾的,为了协调这种矛盾,必须对位定时参数进行优化位置。

图1 位周期结构图

    通过对CAN总线位定时参数进行研究,找到矛盾的关键所在,就能够对其进行优化,从而提高通信系统的整体性能。下面以Philips公司的独立通信控制器SJA1000为例,进行研究。

1 相关定义

1.1 位周期的组成

波特率(fbit)是指单位时间内所传输的数据位的数量,一般取单位时间为1s。波特率由通信线上传输的一个数据位周期的长度(Tbit)决定,如下式所示。

Fbit=1/Tbit    (1)

根据Philips公司的独立通信控制器,一个位周期由3个部分组成:同步段(tSYNC_SEG)、相位缓冲段1(tTSEG1)和相位缓冲段2(tTSEG2)。

Tbit=tSYNC_SEG+tTSEG1+tTSEG2     (2)

所有这些时间段,都有一个共同的时间单元——系统时钟周期(TSCL)。具体到SJA1000,TSCL由总线时序寄存器的值来确定。SJA1000有2个总线时序寄存器,即总线时序寄存器0(BTR0)和总线时序寄存器1(BTR1)。这2个寄存器有自己不同的功能定义,共同作用决定总线的通信波特率。

总线时序寄存器0 定义波特率预设值BRP(共6位,取值区间[1,64]和同步跳转宽度SJW(共2位,取值区间[1,4])的值。位功能说明如表1所列。

表1

bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0
SJW.1 SJW.0 BRP.5 BRP.4 BRP.3 BRP.2 BRP.1 BRP.0

CAN的系统时钟周期TSCL,可以由BRP的数值为决定,计算公式如下:

TSCL=2TCLK×BRP=2TCLK×(32BRP.5+16BRP.4+

8BRP.3+4BRP.2+2BRP.1+1BRP.0+1)    (3)

其中TCLK为参考时间的周期。

TCLK=1/fCLK    (4)

为了补偿不同总线控制器的时钟振荡器之间的相位偏移,任何总线控制器必须在当前传送的相关信号边沿重新同步。同步跳转宽度定义了每一位周期可以被重新同步缩短或延长的时钟周期的最大数目。

tSJW=TSCL×(2×SJW.1+1×SJW.0+1)  (5)

总线时序寄存器1 定义每个位周期长度采样点的位置和在每个采样点的采样数目。位功能说明如表2所列,其中SAM意义见表3。

表2

bit bit bit bit bit bit bit bit
SAM TSEG2.2 TSEG2.1 TSEG2.0 TSEG1.3 TSEG1.2 TSEG1.1 TSEG1.0

表3

功    能
SAM 0 三倍:总线采样三次:建议在中/低速总线(A和B级)使用,有处于过滤总线上毛刺
1 单倍:总线采样一次;建议使用在高速总线上(SAEC级)

TSEG1(共4位,取值区间[1,16])和TSEG2(共3位,取值区间[1,8])决定了每一位时钟数目和采样点的位置。这里

tSYNC_SEG=1×TSCL(此时间段固定) (6)

tTSEG1=TSCL×(8×TSEG1.3+4×TSEG1.2+2×TSEG1.1+1×TESG1.0+1)    (7)

tTSEG2=TSCL×(4×TSEG2.2+2×TSEG2.1+1×TESG2.0+1)    (8)

位周期的标量值(NBT)定义为,SYNC_SEG(同步段系统时钟周期数)、TSEG1(相位缓冲段1系统时钟周期数)、TSEG2(相位缓冲段2系统时钟周期数)之和。这决定了它的取值区间为[3,25],在1个取样点时,最小值一般取4;在3个取样点时,最小值一般取5。

NBT=Tbit/TSCL=SYNC_SEG+TSEG1+TSEG2    (9)

位周期的一般结构如图1所示。

1.2 参考时钟误差

在系统中,每一个节点都有自己独立的参考时钟。由于制造工艺、运行时间及环境温度的变化,这些时钟的实际频率往往偏离预期的频率值。我们称这种偏差为参考时钟误差(Δf)。FCLK,max/min表示参考时钟频率的最大值或最小值,fCLK,rat表示参考时钟频率的额定值。

相应的系统时钟周期也会有误差。TSCL,min表示系统时钟周期最小值,TSCL,max表示系统时钟周期最大值,TSCL,rat表示系统时钟周期额定值。由于Δf<<1,可以进行近似。

TSCL,min=(TSCL,rat)/(1+Δf)≈TSCL,rat×(1-Δf)    (11)

TSCL,max=(TSCL,rat)/(1-Δf)≈TSCL,rat×(1+Δf)     (12)

1.3 传输延迟

CAN总线采用无破坏性的基于优先权的仲裁机制。在这种机制下,传输延迟至关重要。如果传输延迟时间过长,将导致无效的访问仲裁。传输延迟时间由物理总线延时(tBUS)、总线驱动器延时(ttran)和其它设备传输延迟(toth)共同决定。其它设备包括通信控制器、隔离光耦等。

tprop=2×(tBUS+ttran+toth)

传输延迟的标量值(PROP)可以由公式(14)得到。

PROP=tprop/TSCL     (14)

1.4 同步

通过同步机制,可以消除由于相位误差带来的影响,保证信息正确解码。有两种同步方式:硬同步和重同步。

硬同步仅发生在报文开始时,在一个空闲期间,总线上的所有控制器在一个SYNC_SEG段从隐性位到显性位的跳变沿上,初始化自己的位周期定时,执行一次硬同步。

重同步发生在报文位流发送期间,每一个隐性位到显性位跳变沿后。重同步根据引起同步边沿的相位误差,要么增加tTSEG1,要么减少tTSEG2,使采样点处于恰当的位置。同步边沿的相位误e,由相对于同步边沿的位置而定,以系统时钟周期(TSCL)。其它定及重同步处理方式如下:

e=0,同步边沿发生在SYNC_SEG内;

e>0,同步边沿发生在TSEG1内;

e<0,同步边沿发生在TSEG2内。

如果引起重同步的边沿相位误差e的幅值小于或等于tSJW编程数值,则得同步导致位时间缩短或延长,与硬同步的作用一样;如果e为正值,且幅值大于tSJW,则增加tTSEG1值为tSJW;如果e为负值,且幅值大于tSJW,则减少值为tSJW。

2 参数计算规则

参数确定原则为:保证系统在极端恶劣条件的两节点间,能够正确接收并解码网络上的信息帧。极端恶劣条件是指这两个节点的钟振偏差在系统容忍偏差极限的两端,并且两节点间具有最大的传输延迟。在没有噪音干扰的正常通信情况下,相位误差累计的最坏情况是,重同步边沿之间间隔有10个位周期。这是定义SJW最小值的条件。

在实际的通信系统中,噪音干扰是不可避免的。由于噪音干扰,可能会导致重同步边沿之间的间隔超过10个位周期,可能进入错误处理模式。在这种情况下,由于同步边沿之间的时间比较长,所以保证每一位都能够确切地取样就更加重要。如果不能够确切地取样,将会导致检测到错误并进行错误处理。

考虑各方面的影响,位定时参数的设置公式如下:

①1取样点模式

②3取样点模式

    在计算SJWmin时,取大于计算数值的最小整数;在计算TSEG2max时,取小于计算数值的最大整数。由公式(15)~(18)可见,SJW和TSEG2由NBF、Δf、PROP分别决定。计算得到SJW和TSEG2后,由公式(9)可以得到TSEG1。根据SJA1000的寄存器说明,可以得到具体寄存器的设置数值。

3 参数计算步骤及举例

某CAN通信系统,采用1个取样点模式,其它参数指标如表4所列。

表4 

参  数 说    明 最小值 典型值 最大值
fBit/(kb·s-1) 通信波特率   250  
tbit/μs 位周期时间   4  
fCLK/MHz CAN控制器的时钟频率     24
Δf/% 时钟频率偏差     1.0
tran/ns 总线驱动器延时 30 75 157
toth/ns 其它设备延时 15   40
δ/(ns·m-1) 线路延时 5   6.5
L/m 节点间总线长度 3   95
tBUS/ns 计算得到线路延时tBUS=L·δ 15   618
fprop/ns 计算得到传输延时,公式(13) 120   1630

①确定可能的BRP、NBT和PROP。

由公式(1)、(3)、(4)及(9)得到

NBT=1/(fbit·TSCL)=fCLK/(2fbit·BRP)

所以有 NBT·BRP=fCLK/2fbit    (19)

将参数代入公式(19)得到NBT·BRP的值为48,而NBT取值为3~25,所以NBT和BRP所有可能的组合如表5所列。

表5

fCLK NBT BRP TSCL/ns PROPmax PROPmin 有效性
24MHz 4 12 1000 1.63 0.12
6 8 666.6 2.45 0.18
8 6 500 3.26 0.24
12 4 333.3 4.89 0.36
16 3 250 6.52 0.48
24 2 166.6 9.78 0.72

②计算NBTmin和NBTmax。由公式(15-1)、(18-1)、(19)、(14)及(3)推出

NBT≥

公式(22)

    代入数据,计算得到8.31≤NBT≤17.9。原则上选12和16都可以,为了方便取得样点,我们取较大的值16。

③根据公式(15-1)计算SJWmin,如表6所列。

④根据公式(17-1)计算TSEG2min,如表6所列。

⑤根据公式(18-1)计算TSEG2max,如表6所列。

⑥确定寄存器设置数值,如表7所列。

表6

最小值 最大值 确定值
SJW {3.23,3.67}max 4 4
TSEG2 {2,SJW}max {8,5.54,4.78}min 4
TSEG1 TSEG1=NBT-TSEG2-SYNC_SEG=16-4-1 11

表7

BTR0 SHW BRP BTR1 SAM TSEG2 TSEG1
C2 1 1 0 0 0 0 1 0 3A 0 0 1 1 1 0 1 0

4 结论

在不同的系统应用中,可以根据所使用的时钟频率、时钟信号的频率偏差、通信波特率及最大传输距离等因素,对通信控制器位定时参数进行优化确定。确定得到的参数可以提高通信系统整体性能,这使CAN总线优势更加明显,以适合更加广泛的应用。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭