“AUTOSAR Nvm_WriteAll()掉电无法正常更新Nvm数据” 问题分析

2024-06-18 20:20

本文主要是介绍“AUTOSAR Nvm_WriteAll()掉电无法正常更新Nvm数据” 问题分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、问题现象

  • 再掉电时调用Nvm_WriteAll()函数后,再重新上电,发现下电前更新得NvmBlock数据未被正确更新到Nvm中。
  • 掉电时直接调用Nvm_WriteBlock()函数,可以正常更新指定得NvmBlock块。

2、排查

在这里插入图片描述

  • NvM_InterWriteAll()函数有被正常执行。
  • NvM_InterWriteAll()函数中调用得NvM_UpdateValidandChangeStatus(STD_ON,STD_ON)函数被屏蔽了,无法正常执行。
    • NvM_UpdateValidandChangeStatus(STD_ON,STD_ON)作用:Update Validand Change Status。
    • 当该函数不执行时,会直接跳过所有得NvmBlock块,更新标志直接被设置成OFF。
    • 在这里插入图片描述

3、NvM_UpdateValidandChangeStatus(STD_ON,STD_ON)作用

  • 该函数在写NvmBlock时用于更新对应得RAM状态,用于NVM识别是否需要更新NvmBlock。
  • 该函数通过宏NVM_SET_RAM_BLOCK_STATUS_API 决定是否使用。
    • NVM_SET_RAM_BLOCK_STATUS_API = FALSE:该函数可以被正常调用。
      • 影响:NvMSetRamBlockStatusApi = FALSE,则 NvM_WriteAll() 会将所有 NVRAM Block对应的RAM内容拷贝到 NV Block中。
    • NVM_SET_RAM_BLOCK_STATUS_API = TRUE :该函数被屏蔽。
      • 影响:
        • NVM_SET_RAM_BLOCK_STATUS_API = TRUE,只有 RAM Block的内容发生变化的RAM内容被写到 NV Memory中。
        • 此时需要注意:
          • 每当Nvm Block对应的 RAM内容发生变化时,用户必须调用 NvM_SetRamBlockStatus(BlockID, TRUE),告诉 NvM 模块在 NvM_WriteAll()时要处理该 Nvm Block。
          • 如果在Nvm Block对应的 RAM内容发生变化时,用户不调用 NvM_SetRamBlockStatus(BlockID, TRUE,那么在调用Nvm_WriteAll()时,该对应的Nvm Block将不会被更新。
        • 好处: 可以加快NvM_WriteAll()的速度。

4、提升NvM_WriteAll()速度的办法

  • NVM_SET_RAM_BLOCK_STATUS_API 配置为 TRUE,通过调用NvM_SetRamBlockStatus(NvMBlock_ID, TRUE)通知Nvm更新数据时,只更新数据发生改变的NvmBlock。
  • NvMBlockUseCRCCompMechanism配置为TRUE,通过比较上次写入数据的CRC与想要更新的数据的CRC进行对比,当CRC不变时,直接跳出写操作。
    • 该操作有一个弊端:当RAM数据发生变化,但是CRC不变的情况下,那么对应的RAM数据将不会被更新。

这篇关于“AUTOSAR Nvm_WriteAll()掉电无法正常更新Nvm数据” 问题分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对