TSMaster采样点配置方法与消除错误帧流程

描述

 

当通讯节点间采样点参数和波特率参数不匹配造成一些错误帧时,我们如何在TSMaster中设置以及调整波特率参数和采样点参数,来减少以及消除总线上出现的错误帧,进一步提高通信质量。本文着重讲解讲解如何借用TSmaster更加便捷地获取相应的采样点参数以及波特率参数并通过API设置到用户程序中。

 

本文关键字:采样点、波特率、错误帧、tsapp_configure_canfd_regs

 

 

目录

 

 采样点定义

 

 采样点导致的通信问题

 

● 如何在TSMaster中调整采样点参数

 

● tsapp_configure_canfd_regs参数配置

Catalog

 

采样点定义

采样点是CAN控制器读取总线电平,并解释各个比特的逻辑值的时间点。在我们了解采样点之前,我们需要先了解CAN报文中位时间的概念以及位时间的组成部分,位时间指的是每传输一位数据所需要的时间,而CAN控制器的最小时间周期称作时间份额(Time Quantum,简称TQ),它是通过对芯片晶振周期进行分频而得来的。一个位时间由若干个TQ组成(通常为8到25个),同时根据功能的不同,可以分为4个阶段:同步段、传播段、相位缓冲段1和相位缓冲段2。

MASTER

△ 图1:某个位时间的组成

 

四个阶段的功能如下

●  同步段:用于实现时序调整,总线上各个节点的跳变沿产生在同步段内,通常为1个TQ。
 

●  传播段:用于补偿网络上的物理延迟时间,这些延迟时间包含信号在总线上的传输延迟和CAN节点内部的处理延迟。

● 相位缓冲段1(Phase_Seg1)和相位缓冲段2(Phase_Seg2):用于补偿跳变沿的相位误差,其长度会在重同步的实现过程中延长或缩短。

 

CAN通信中不同得分波特率时间对应的采样点以及位时间的份额不尽相同。常见的采样点以及相关的参数如下表所示。以波特率为500K为例,一个位时间被分配成16个时间份额,而采样点在第14个时间份额。

MASTER

△ 图2:CAN通信中常见采样参数

 

合适的采样点位置是CAN控制器正常通信的保证,其重要性主要有以下三点:

●  对于CAN网络这个整体而言,各个节点应该尽量使用相同的采样点位置,否则容易出现采样错误,进而使整个网络的通信出现故障;

●  对于单个节点而言,过早的采样使得节点易受位时间初期的电平波动影响,进而导致采样错误;

●  受限于重同步的要求和相位缓冲段的宽度,CAN控制器无法过晚采样。

 

采样点导致的通信问题

CAN网络采用异步通信的方式,因此需要根据波特率进行采样,采样原理如下图所示。红色箭头则表示采样点的位置,采样得到的数据为“1010 1010”。

MASTER

△ 图3:CAN通信采样原理示意图

 

若采样点设置提前20%,则采样后得到的数据为“0101 1010”,与图1中数据相比较,图4中采样得到的第五位数据就不相同。因此,在CAN通信网络中,如果传输节点之间的采样点差异不同,则会造成数据传输传输错误,并且随着传输的数据越多,累计的错误数据位就越多。所以在进行CAN网络通信时,需要将各个节点的波特率和采样点设置位相同的。

MASTER

△ 图4:采样点提前20%的采样示意图

 

在CAN通信网络中,节点之间波特率和采样点设置不匹配导致的问题主要表现是出现错误帧。以波特率500k、采样点80%(相位缓冲段1为63、相位缓冲段2为16)与波特率250k、采样点50%(相位缓冲段1为3、相位缓冲段2为4)为例,使用同星硬件TC1016和TSmaster进行测试,分别将以上波特率和采样点参数部署至短接的CAN1与CAN2通道。

MASTER

△ 图5:CAN1通道波特率和采样点参数配置

MASTER

△ 图6:CAN2通道波特率和采样点参数配置

 

在此参数配置条件下,在TSMaster的报文发送窗口发送报文,然后可以在报文信息窗口下看到报文数据在总线上传输的状态。如下图所示,在通信节点之间的波特率和采样点参数配置不相同的情况下,报文信息窗口会出现错误帧。

MASTER

△ 图7:节点间采样点参数不同导致的错误帧

 

因此,在TSMaster报文信息窗口出现错误帧的时候,检查节点之间的波特率和采样点参数配置是一个重点排查的方向。除此之外,不仅仅是上图所展示的错误帧类型,当报文信息窗口出现其他错误帧类型,诸如bit error、form error等(如图8和图9所示),都需要检查波特率和采样点采样点参数配置。

MASTER

△ 图8:错误帧

MASTER

△ 图9:错误帧

 

如何在TSMaster中调整采样点

当因为采样点设置不当,导致在TSMaster的报文信息窗口观测到错误帧时,此时需要重新调整TSMaster中的参数配置,以实现节点之间的正常通信。因此,如何在TSMaster中调整采样点和波特率参数以消除错误帧,提高通信质量尤为重要。但在此之前,需要知道如何计算采样点。

MASTER

其中,TSEG1和TSEG2在TSmaster中分别表示为相位缓冲段1和相位缓冲段2。在知道采样点的计算公式后,可以根据被测件的通信参数准确计算出相应的采样点参数,然后可进一步在TSMaster的总线硬件界面中配置好相应参数,以实现节点间的正常通讯。

 

调整采样点和波特率参数的步骤

● 步骤一:首先需要在通道需选择界面选择相应的硬件通道,并点击确认。

MASTER

△ 图10:选择通道

 

● 步骤二:确定通道后,在总线硬件界面配置波特率参数。

MASTER

△ 图11:配置波特率和采样点参数

 

以CAN通信网络为例,波特率的选择范围由125kbps至1000kbps,波特率的选择要参考被测件的通信参数,并且在TSmaster中波特率参数设置应与之对应,若在不清楚被测件波特率参数的情况下,可以询问厂商或者换用其他波特率参数进行通信,看看在其他波特率参数下可否改善出现错误帧的情况。

MASTER

△ 图12:波特率参数选项

 

● 步骤三:配置采样点参数(即仲裁段位时间)


 

TSMaster提供诸多采样点参数,以供配置使用。参考总线硬件界面中的仲裁段位时间选项,同一个采样点可能对应的相位缓冲段1参数和相位缓冲段2参数不尽相同,因此,在选择采样点时需要用到采样点公式进行计算,根据被测件的的通信参数,选择与之对应的相位缓冲段1参数和相位缓冲段2参数进而计算出采样点参数。

MASTER

△ 图13:采样点参数选项

 

此外,当根据被测件计算出来的采样点参数或者相位缓冲段1参数和相位缓冲段2参数在仲裁段位时间参数选项列表中无法找到时,可以在选项列表中选择与之相近的参数进行配置即可。若使用者在不知道被测件的通信参数下,推荐使用TSMaster中默认采样点参数即可。

MASTER

△ 图14:TSMaster默认采样点参数

 

tsapp_configure_canfd_regs参数配置

TSMaster提供众多的API函数给用户进行二次开发,通过API函数编写更加符合自己需求的用户程序实现各项功能。当使用二次开发的程序出现通信错误时,可以使用上述方法在TSMaster界面中不断调整采样点和波特率等参数的配置,以改善总线中出现错误帧的情况,进而获取更加符合与被测件之间进行通信的采样点和波特率等参数。

 

tsapp_configure_canfd_regs函数作用是配置 CANFD 控制器内部寄存器,让控制器的采样点,同步跳变宽度等参数更加精确。函数如图15所示:

MASTER

△ 图15: tsapp_configure_canfd_regs函数

MASTER

表格:tsapp_configure_canfd_regs函数输入参数表

 

上面这些参数看起来很繁琐,但是可以通过 TSMaster 的配置器直接查看到对应的参数值。以仲裁场 500k,仲裁采样点 80%,数据场 2000k,数据场采样点 80%为例。进入TSMaster,打开总线硬件配置,如图16所示。

MASTER

△ 图16: 总线硬件配置

 

展开仲裁段位时间选项,精确选择 80%的采样点,如图17所示:

MASTER

△ 图17: 仲裁段位时间

 

因此,可以看到 AArbSEG1 = 31,AArbSEG2 = 8, AArbPrescaler = 2;AArbSJW= 6(<= AArbSEG2 即可),AArbBaudrate = 500。

 

同理,可以获得数据场的参数配置,如图18所示:

MASTER

△ 图18: 数据段位时间

 

因此采样点和波特率等参数的获取和调整都可以在TSMaster中完成,通过这样的调试方式可以让TSMaster的功能充分发挥出来,更加便捷地帮助使用者完成开发所需。

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分