[AutoSar]BSW_Memory_Stack_007 FEE 模块介绍

2024-04-14 06:04

本文主要是介绍[AutoSar]BSW_Memory_Stack_007 FEE 模块介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 关键词
  • 平台说明
  • 一、FEE所处架构位置
  • 二、FEE 功能描述
    • 2.1 Initialization
    • 2.2 Flash organization
      • 2.2.1 (User) Blocks
      • 2.2.2 FEE block
      • 2.2.3 Partitions
      • 2.2.4 Chunks

  

关键词

嵌入式、C语言、autosar、OS、BSW

平台说明

项目Value
OSautosar OS
autosar厂商vector , EB
芯片厂商TI 英飞凌
编程语言C,C++
编译器HighTec (GCC)
autosar版本4.3.1
参考文档TechnicalReference_Fee.pdf AUTOSAR_SWS_FlashEEPROMEmulation.pdf

在这里插入图片描述
  
  
>>>>>>>>>>>>>>>>>>>>>>>>>回到总目录<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

  
  

缩写描述
EEPROMElectrically Erasable Programmable read only memory
NVMNVRAM Manager
MEMIFMemory Abstraction Interface
EAEEPROM Abstraction
EEPinternal/external EEPROM DRIVER
FEEFlash EEPROM Emulation
FLSinternal/external Flash Driver
FCFSFirst come first served
LUTLook Up Table

一、FEE所处架构位置

  FEE 处于ECU 抽象层。
在这里插入图片描述
在这里插入图片描述

二、FEE 功能描述

   由于EEPROM 太贵,出于成本考虑,于是有了FEE (Flash EEPROM Emulation)。虽然用DFLASH Emulation 的EEPROM 擦除次数远不及真实的EEPROM ,但是我们可以通过顺序写入和换页的机制来平衡整个DFALSH 的寿命。下述为vector为FEE做的实现的功能:

  • 1.为NVM 提供操作。
  • 2.硬件限制,如周期擦除或扇区大小是抽象的,对上层是不可见的。
  • 3.检查未完成的写入操作。
  • 4.提供虚拟扇区使用wrap-around的概念,备份最近的数据块。
  • 5.检索逻辑扇区的擦除周期数的可行性(通过API服务完成)Fee_GetEraseCycle())
  • 6.检索块的写周期数的可行性(通过API服务完成)Fee_GetWriteCycle)
  • 7.强制扇区切换的可行性(通过API服务完成)Fee_ForceSectorSwitch())。
  • 8.在配置更新后执行数据转换的API,即有效载荷发生变化的块可以根据新的配置进行转换,而不会丢失数据。
  • 9.Fee支持高达2gb字节的Flash地址空间(由Fls提供),即Fee使用的扇区可能在0x00000000到0x7FFFFFFF范围内。
  • 10.Fee_MainFunction触发:可以在循环任务或后台任务中调用Fee_MainFunction。
  • 11.将多个logical sector 合并为一个physical sector,FEE 一般同时操作两个logical sector
  • 12.冗余内部信息关联,增强其鲁棒性。
  • 13.在FBL 和APP 间共享 配置信息。

2.1 Initialization

  FEE通过调用Fee_Init() 或者 Fee_InitEx()完成初始化。
  FEE初始化只是让FEE准备好接受和处理请求。当分区上启动第一个请求后,扇区再初始化(检查它们的头并确定用新的还是旧的section)。
  不建议在ECU 的启动阶段过早的对NV block 进行操作。
在这里插入图片描述

2.2 Flash organization

   在这里我们要弄懂这几个概念:(User) Blocks,FEE block 、Partitions 、Logical Sectors、Physical Sector和Block chunk 的概念。
下图为他们的大概关联。
在这里插入图片描述

2.2.1 (User) Blocks

  指在NVM 模块中使用到的NVRAM block,具体参照[AutoSar]NVM模块介绍和使用说明,其中的NV block 由CRC+Data 组成。

2.2.2 FEE block

  映射自NVRAM blcok,指需要在抽象层中需要指定多大的FLASH 。
在这里插入图片描述

2.2.3 Partitions

在这里插入图片描述
  Partitions,翻译为分区,是FEE 中的概念,与ECUC 中的 的partitons 配合使用,见第二节和[AutoSar]BSW_ OS CORE, Physical core,EcuC core,EcuC partition,OSApplication的关系。
  FEE Partitions 作为一个单独的虚拟内存分区,与其他虚拟内存分区独立。一个工程中可以包含多个Partitions ,具体设计后续单独讲。 链接预留Partitions 有如下特性:

    1. Partitions 中产生的 Errors 不会影响到其他的Partitions 。
    1. 每个Partitions 至少拥有两个logical sectors,同理,每个logical sectors 都必须assign到 一个partitions。
    1. 在同一时刻只能允许一个Partitions 进行 sector switch (翻页操作)。
    1. 如果FBL 和APP 想要共享分区必须引用相同的Fls配置(FlsConfigSet容器),并且它们必须在地址和大小以及对齐设置上匹配。
    1. 分区设计必须考虑数据的使用频率和整体性能(例如寻址时间和翻页时间长短),后续单独讲链接预留。

2.2.4 Chunks

在这里插入图片描述

  

待更新
  
  
>>>>>>>>>>>>>>>>>>>>>>>>>回到总目录<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

这篇关于[AutoSar]BSW_Memory_Stack_007 FEE 模块介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/902257

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现

Mysql BLOB类型介绍

BLOB类型的字段用于存储二进制数据 在MySQL中,BLOB类型,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储的大小不同。 TinyBlob 最大 255 Blob 最大 65K MediumBlob 最大 16M LongBlob 最大 4G

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数