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

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

相关推荐

  1. Autosar PNC网络管理配置(1)-基于ETAS软件

    2024-01-18 03:52:01       58 阅读
  2. AutoSAR基础入门篇)4.9-Autoar_BSW小结

    2024-01-18 03:52:01       55 阅读
  3. AutoSAR基础入门篇)10.6-模式管理进阶

    2024-01-18 03:52:01       50 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-18 03:52:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-18 03:52:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-18 03:52:01       82 阅读
  4. Python语言-面向对象

    2024-01-18 03:52:01       91 阅读

热门阅读

  1. VCG 网格清洗之移除小组件

    2024-01-18 03:52:01       54 阅读
  2. 3、python布尔类型和条件表达式

    2024-01-18 03:52:01       50 阅读
  3. Ubuntu 从零开始配置环境

    2024-01-18 03:52:01       51 阅读
  4. [网络安全]DHCP 部署与安全

    2024-01-18 03:52:01       46 阅读
  5. CSS 高频面试题

    2024-01-18 03:52:01       50 阅读
  6. MetaGPT-打卡day01

    2024-01-18 03:52:01       47 阅读
  7. redis内存淘汰机制

    2024-01-18 03:52:01       52 阅读
  8. LeetCode 36. 有效的数独

    2024-01-18 03:52:01       52 阅读