【AUTOSAR】--01 AUTOSAR网络管理基础

发布时间:2024年01月14日

AUTOSAR网络管理做了几个项目了,但发现还是有些理解不够深入的地方,最近趁着有个新项目也要做AUTOSAR网络管理,再从头梳理一下AUTOSAR网络管理,预计用2-3篇文章,把AUTOSAR网络重新梳理完成。

这是第一篇,主要从如下三部分展开描述:

1)AUTOSAR网络管理的基础知识;

2)AUTOSAR网络管理主要涉及的软件模块及相关技术文档;

3)AUTOSAR网络管理的工作状态机;

1、网络管理基础知识介绍

车载网络管理常见的有如下两种:

1)?OSEK网络管理几年前基本都是用OSEK网络管理。但它相对AUTOSAR网络管理来讲比较复杂,要建环啥的,所以现在慢慢用得少了。

2)?AUTOSAR网络管理目前新开发的项目,大部分用的是AUTOSAR 网络管理。

本文主要介绍AUTOSAR网络管理。

网络管理主要是为了协调整车的各ECU的CAN网络同醒同睡。

即:

1、当网络上没有信息交互时,CAN网络将进入睡眠模式,之后本身的系统才允许进行休眠。

2、当ECU要需要获取CAN上的信息时,则该ECU唤醒CAN网络。

总结一句话,网络管理主要负责CAN网络的休眠唤醒,以达到本ECU以及整车的休眠唤醒

AUTOSAR网络管理可以适用于多种网络,如CAN/LIN/Eth/FlexRay等。

本文主要针对CAN部分展开描述,也是目前市场上使用得最多的,最实用的。

2、主要涉及模块及相关文档

从AUTOSAR规范上来看,主要涉及两个模块CanNM,NM模块

从源码层面来看,主要涉及如下源代码:

Nm.c (src\components\nm\implementation

Nm.h (src\components\nm\implementation)

CanNm.c (src\components\cannm\implementation)

CanNm.h(src\components\cannm\implementation)

ComM_Nm.h (src\components\comm\implementation)

Nm_Cbk.h (src\components\nm\implementation)

NmStack_Types.h (src\components\nm\implementation

BswM_Nm.h (src\components\bswm\implementation)

CanNm_Cbk.h (src\components\cannm\implementation

Nm_Cfg.c(src\gendata)

Nm_Cfg.h (src\gendata)

Nm_Lcfg.c (src\gendata)

SchM_Nm.h(src\gendata)

CanNm_Cfg.c (src\gendata)

CanNm_Cfg.h(src\gendata)

CanNm_Lcfg.c (src\gendata)

CanNm_PBcfg.c(src\gendata)

SchM_CanNm.h (src\gendata)

SchM_Nm_Type.h(src\gendata)

SchM_CanNm_Type.h(src\gendata)

对应相关的AUTOSAR标准为:

1)?AUTOSAR_SWS_CANNetworkManagement.pdf

2)?AUTOSAR_SRS_NetworkManagement.pdf

3)?AUTOSAR_SWS_CANStateManager.pdf

对应相关的Vector开发技术规范为:

1)?TechnicalReference_CanNm.pdf

2)?TechnicalReference_Nm.pdf

3、AUTOSAR CAN Nm状态机

3.1?网络管理三大模式介绍

AUTOSAR网络管理主要分为三大模式:

1)?网络模式(Network Mode)

2) 预睡眠模式(Prepare Bus-Sleep Mode)

3) 睡眠模式(Bus-Sleep Mode)

其中网络模式有三个状态:

1)?帧重复状态(Repeat Message State)

2) 正常运行状态(Normal Operation State)

3) 准备睡眠状态(Ready Sleep State)

其中帧重复状态又有两个子状态:

1) 快速发送子状态(Normal immediate State)

2) 正常发送子状态(Normal transmit State)

上面每个模式/状态,对网络管理报文、应用报文、诊断报文的发送/接收要求不一样。

具体如下:

1) 网络模式(Network Mode):

允许所有报文的发送与接收(除了处于准备睡眠状态Ready Sleep State时,不能发送网络管理报文)

2) 预睡眠模式(Prepare Bus-Sleep Mode):

不允许发送网络管理报文,

不允许发送、接收应用报文/诊断报文等(已经存储在Tx缓存器的应用报文/诊断报文,仍然可以发送)

仅可接收网络管理报文;

可以对总线上的报文进行ACK响应

3) 睡眠模式(Bus-Sleep Mode)

允许发送网络管理报文,

允许发送、接收应用报文/诊断报文等

仅可接收网络管理报文;

不可对总线上的报文进行ACK响应

上面所有模式/状态,可整理成如下表:

具体这三个模式、三个状态、两个子状态,是怎么互相切换的?下面重点讲解下网络管理的状态机。

3.2?网络管理状态机

?

  • NM_01: 上电后,软件通过调用CanNm_Init() 完成CAN网络管理的初始化之后进入网络休眠模式Bus-Sleep Mode(BSM)。

  • NM_02: 在网络休眠模式Bus-Sleep Mode(BSM)下,

    若收到其他节点的NM PDU,则软件调用CanNm_PassiveStartup()将状态机切换至网络模式的重复报文状态Repeat Message State(RMS),并进入其中的正常发送子状态。

  • NM_03: 在网络休眠模式Bus-Sleep Mode(BSM)下,

    若本模块存在本地唤醒请求,则软件调用CanNm_NetworkRequest()将状态机切换至网络模式的重复报文状态Repeat Message State(RMS),并进入其中的快速发送子状态。

  • NM_04: 在网络模式下的重复报文状态Repeat Message State(RMS)或正常运行状态Normal Opeartion State(NOS)时,若NM-Timeout Timer超时,则重启NM-Timeout 定时器;

    该步骤正常运行时,是不会触发的分析如下:

    当处于Repeat Message Stat状态时,正常情况下,在NM-Timeout Timer超时前,肯定会接收到其他NM PDU或本NM PDU发送完成,则会如NM17步骤,软件会重启NM-Timeout Timer。

  • NM_05: 当Repeat Message Timer超时,若此时本ECU仍需要请求网络,则进入正常运行状态Normal Operation State。

  • NM_06: 满足如下任一条件时,则从正常运行状态Normal Opeartion State(NOS)进入重复报文状态Repeat Message State;

    1、接收到Repeat Message Bit置1的网络管理报文

    2、ECU需要置上Repeat Message Bit时,则软件调用CanNm_RepeatMessageRequest();

  • NM_07: 当Repeat Message Timer超时,若此时本ECU不再需要网络,则进入准备睡眠状态Ready Sleep State(RSS)。

  • NM_08: 满足如下任一条件时,则从准备休眠状态Ready Sleep State(RSS)进入重复报文状态Repeat Message State;

    1、接收到Repeat Message Bit置1的网络管理报文

    2、ECU需要请求网络且需置上Repeat Message Bit时,则软件调用CanNm_RepeatMessageRequest();

  • NM_9: 当本ECU需要请求网络时,则软件调用CanNm_NetworkRequest(() ,请求进入Normal Operation State。

  • NM_10: 当本ECU不需要网络时,则软件调用CanNm_NetworkRelease() ,请求进入准备休眠状态Ready Sleep State(RSS):

  • NM_11: 当快速发送次数到达,但Repeat Message Timer计时未到达时, 则从Normal immediate State切换至Normal transmit State

  • NM_12: 在网络模式下的Ready Sleep State时,NM-Timeout Timer超时,则软件调用CanNm_NetworkRequest((),进入 预休眠状态Prepare Bus-Sleep Mode (PBSM);

  • NM_13: 在预休眠模式Prepare Bus-Sleep Mode(PBSM)下,

    若本模块存在本地唤醒请求,则软件调用CanNm_NetworkRequest()将状态机切换至网络模式的重复报文状态Repeat Message State(RMS),并进入其中的快速发送子状态。

  • NM_14: 在预休眠模式Prepare Bus-Sleep Mode(BSM)下,

    若收到其他节点的NM PDU,则软件调用CanNm_PassiveStartup(),将状态机切换至网络模式的重复报文状态Repeat Message State(RMS),并进入其中的正常发送子状态。

  • NM_15: Bus-Sleep Timer超时,则进入Bus-Sleep Mode,MCU进入休眠。

  • NM_16: 电源下电,退出网络管理。

  • NM_17: 在网络模式,若成功接收到一帧网络管理报文后,则重启NM-Timeout Timer定时器。

  • NM_18: 在网络模式,若成功发送一帧网络管理报文后,重启NM-Timeout Timer定时器。

  • NM_19: 在网络模式的Repeat Message State(RMS)或Normal Opeartion State(NOS),若持续Tx Timeout Timer未成功发送网络管理报文,则表示当前存在异常,需调用Nm_TxTimeoutException()进行异常处理。

  • NM_20:?若接收到非网络管理报文,则应该保持在Bus-Sleep状态

4、总结

1)网络管理主要负责CAN网络的休眠唤醒,以达到本ECU以及整车的休眠唤醒

2)从AUTOSAR规范上来看,主要涉及两个软件模块CanNM,NM模块

3)AUTOSAR网络管理总共有三个模式(网络模式/预休眠模式/休眠模式),其中网络模式里又有三个状态(重复报文状态/正常发送状态/准备休眠状态),另外重复报文状态里又有两个子状态(正常发送子状态/快速发送子状态)。具体详见下表:

文章来源:https://blog.csdn.net/zzx3111/article/details/135587926
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。