【Memory协议栈】AUTOSAR架构下Fee详细分析

本文深入剖析AUTOSAR架构中的Fee模块,探讨其在Flash上的数据写入逻辑,包括Fee_Write过程、NvM_JobEndNotification与NvM_JobErrorNotification的调用时机。文章通过源码分析揭示了Fee如何通过垃圾回收(GC)机制实现DFlash的磨损均匀,确保存储系统的稳定性和持久性。
摘要由CSDN通过智能技术生成

目录

前言

正文

1.Fee功能概述

2.Fee模块配置表变量

3.Fee状态变量

4.Fee_Init模块初始化

5. Fee_Write过程分析

5.1 Fee_Write在DFlash上的直观表现

5.2 Fee_Write代码逻辑分析

6. Fee调用NvM_JobEndNotification

6.1 Fee在处理Write任务的时候调用

6.2 Fee在处理Read任务的时候调用

6.3 Fls在处理Fee任务是调用

7.Fee调用NvM_JobErrorNotification

7.1 Fee在处理Read任务时发现数据不一致

7.2 Fee识别到Block的写次数达到最大限制

7.3 Fee在处理Write任务时Compare缓存和写入数据不一致

7.4 Fls处理Fee任务时调用Fee_JobErrorNotification

8. 垃圾回收GC机制

8.1 垃圾回收机制介绍

8.2 垃圾回收机制源码分析

9. 总结


前言

对于存储协议栈的学习(或者是其他AUTOSA模块的学习)第一步是了解它的基本概念,第二步是根据实际需求完成配置,第三步是阅读源码深入了解其机制后能分析各种异常或问题,第四步是学习其优秀的架构和代码风格应用于自己模块当中。

当然,由于时间和精力的原因,很难做到所有的模块都能这么过一遍。虽不能至,心向往之!

存储协议栈中,NvM模块最主要的功能是通过队列机制缓存应用的读写请求,Fee模块最主要的功能是把虚拟地址转换为物理地址并实现DFLASH的磨损均匀,FLS模块则是完成对DLASH的真正读写。其实任何一个模块出问题,都可能导致NvM Block写不进去,或者读出异常值。通过前面的<<

Autosar (AUTomotive Open System ARchitecture) 是一种专门为汽车电子系统设计的标准架构,它定义了一系列的软件和服务层,包括FEE (Functional Electronic Equipment) 协议栈FEE 主要负责处理车辆内的分布式电子控制单元之间的通信。 FEE 协议栈主要包括以下几个关键部分: 1. **应用层**:这是最上层,包含用户应用程序,它们通过服务访问功能模块(SWIMs)进行交互,这些SWIMs封装了具体的硬件操作。 2. **数据网络层**:也称为OSI模型的第7层,在FEE中称为应用适配层(Application Adaptation Layer, AAL),主要提供安全的数据传输服务,比如基于CAN、FlexRay或Ethernet等技术。 3. **服务接口层**:定义了标准的服务接口,如诊断服务、消息交换服务等,使得各个ECU能相互通信。 4. **功能模块**(Function Blocks, FBs):是核心的组件,每个FB代表一种特定的功能,如发动机控制、空调管理等,它们可以被多个ECUs共享。 5. **运行时环境**(Runtime Environment, RTE):负责管理和协调FB的运行,保证通信可靠性和安全性。 6. **基础平台**(Base Platform):提供了底层硬件抽象,支持多种硬件平台的兼容。 FEE协议栈的主要优点在于标准化和互换性,降低了复杂性,并促进了汽车电子系统的模块化和复用。然而,它对于系统集成的要求较高,需要严格的软件和硬件一致性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汽车电子嵌入式

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值