如何理解CAN通信中的UB?

本文解答一个问题:CAN通信中的更新位UB到底是如何起作用的?

对于AUTOSAR中CAN通信不了解的同学,可以回顾以往的文章:

汽车CAN总线详解

AUTOSAR通信篇—COM模块

AUTOSAR通信篇—PduR模块

AUTOSAR通信篇—IpduM模块

AUTOSAR通信篇—CANTP模块
AUTOSAR通信篇—CanIf模块

AUTOSAR之CAN网络管理

AUTOSAR通信之CAN状态管理CanSM

来,开始讨论今天的问题。

什么是更新位?

为了帮助信号或信号组的接收端来识别发送端是否在发送前更新了信号或信号组的数据,AUTOSAR COM模块整出了“更新位”(Update Bit),它表征的是发送端RTE在通过I-PDU传递给PDUR前,信号是否更新。

如果传输模式设置为“DIRECT”,那就没有更新位一说了。

通过配置发送端和接收端,每个信号或信号组都可以分配一个更新位,来表征其更新状态,配置参数为ComUpdateBitPosition,因此可以知道,信号和对应的更新位在相同I-PDU内,即在CAN总线上,位于相同以帧CAN报文中。当然,信号或信号组也可以不配置更新位。

拿发送端来看。

当RTE调用Com_SendSignal函数来更新信号值(或者调用Com_SendSignalGroup更新信号组)时,AUTOSAR COM模块将会将UB置为1。

当PduR_ComTransmit函数将I-PDU中的函数发送出去并反馈E_OK后,AUTOSAR COM模块将会把信号或信号组对应的UB清为0,此时需要将参数数ComTxIPduClearUpdateBit配置为传输(Transmit)。

当PduR_ComTransmit函数将I-PDU中的函数发送出去,反馈E_OK并成功确认后,AUTOSAR COM模块将会把信号或信号组对应的UB清为0,此时,参数ComTxIPduClearUpdateBit 需要配置为确认(Confirmation)。

当 Com_TriggerTransmit 函数成功请求I-PDU的信号后,AUTOSAR COM模块将会把信号或信号组对应的UB清为0,此时,参数ComTxIPduClearUpdateBit需要配置为触发传输(TriggerTransmit)。

当然,在通信矩阵的说明文档制作之时,就应该规定好信号或信号组合对应更新位的关系。比如,在制作dbc文件时,要标注报文消息中信号A和对应的更新位A _UB,以及信号组G和对应信号组的更新位G_UB。同时,信号和对应更新位一定要在相同消息中传递。如果dbc将一个信号的更新位单独拿出来,做成了两个信号,那么配置工具将无法进行更新位的配置。也正因为更新位是定义在相同一帧消息报文中,所以通信矩阵确认定义好,根据通信矩阵的定义配置即可。

对于更新位来说,0是未更新,1是已更新。

那么,使用UB有什么好处呢?

试想,车内各控制器节点通过CAN传递数据。假设PEPS节点通过一条报文消息将起动请求信号A传递给TCU节点,但并不想把点火开关信号B传递给TCU,从网络布置最大化来看,刚好A和B处在同一帧报文中,TCU在接收到报文消息后判断是否响应B。

有了UB以后,就可以轻松处理该场景了。TCU接收到B后先判断B_UB是否置1,PEPS显然不希望将B_UB置1,这时,PEPS就可以一直保持B_UB一直为0,TCU就无法更新接收到的B信号了。CAN矩阵不需要制作很多版本,即满足了归一化的需求,也实现了不同项目的个性化配置。

  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值