AUTOSAR NvM模块(五)

NvMRbCallbackSignatureAR45

改变回调函数的参数类型。

TRUE:根据AR44及之后版本,回调函数使用NvM_<Multi;Init>BlockRequestType参数类型。详细的函数调用参数请参考回调参数。

FALSE:根据AR43及之前版本,回调函数使用ServiceId参数类型。详细的函数调用参数请参考回调参数。

如果NvMRbCallbackSignatureAR45设置为TRUE,则NvM_Rb_GetActiveService函数不再可用,因为在使用多块和/或加密服务特性时会带来不利影响。详细信息请参阅NvM文档(NvM_EN_detailed_CDG.pdf).

NvMRbCommonCalcRamBlockCrc

定义参数 NvMCalcRamBlockCrc 和 NvMBlockUseCRCCompMechanism 的默认值。
如果该参数设置为true,则对于所有可以设置为true的NVRAM块,参数 NvMCalcRamBlockCrc 和 NvMBlockUseCRCCompMechanism 的默认值都为true。这包括所有具有永久RAM块或配置为使用显式同步机制的NVRAM块。
对于未配置CRC类型的NVRAM块,NvM将使用默认的16位CRC类型(NVM_CRC16)。

NvMRbCommonWriteCounter

定义块特定参数 NvMRbWriteCounter 的默认值。

true:所有NVRAM块的参数 NvMRbWriteCounter 默认为true。这意味着所有NVRAM块都启用写入计数器,只有当显式将 NvMRbWriteCounter 参数设置为false时才会禁用写入计数器。

false:所有NVRAM块的参数 NvMRbWriteCounter 默认为false。这意味着所有NVRAM块都禁用写入计数器,只有当显式将 NvMRbWriteCounter 参数设置为true时才会启用写入计数器。

NvMRbDynConfigLoadDefaultsForNonResistant

定义在动态配置中,对于非抗变块在布局更改时的处理方式。

TRUE:在布局更改时,NvM将为非抗变块加载默认值。换句话说,当布局更改时,将会重新写入这些块的默认值。

FALSE:在布局更改时,NvM将跳过对非抗变块的读取操作。换句话说,这些块将保持其当前的值,不会被修改。

此参数仅影响AUTOSAR定义的动态配置。如果启用了增强的动态配置(NvMRbRemoveNonResistantBlocks = TRUE),则此参数不会生效。

NvMRbErrorInfoDetail

定义是否可以调用 NvM_Rb_GetErrorInfoDetail 函数来获取额外的错误详情。

true:NvM_Rb_GetErrorInfoDetail 函数可用。可以在每个面向块的作业之后调用该函数以获取更多的错误详情。

false:NvM_Rb_GetErrorInfoDetail 函数不可用。无法获取额外的错误详情。

NvMRbExplcitSyncReadWithConst

定义读取回调函数参数 NvMBuffer 是否带有const限定符。

TRUE:读取回调函数参数 NvMBuffer 带有const限定符。这意味着在定义使用块参数 NvMReadRamBlockFromNvCallback 的读取回调函数时, NvMBuffer 参数是一个const指针,不能用于修改数据。

FALSE:读取回调函数参数 NvMBuffer 没有const限定符。这意味着 NvMBuffer 参数是一个非const指针,可以用于修改数据。

NvMRbInitAtLayoutChange

控制是否在检测到布局更改时对配置了 NvMRbInitBlockAtLayoutChange 参数为 “true” 的 NvM 块进行初始化。

TRUE:启用对配置了 NvMRbInitBlockAtLayoutChange 为 “true” 的 NvM 块的初始化。这意味着当检测到布局更改时,会对这些块进行初始化操作。

FALSE:禁用对配置了 NvMRbInitBlockAtLayoutChange 为 “true” 的 NvM 块的初始化。这意味着即使检测到布局更改,也不会对这些块进行初始化操作。

NvMRbInitBufferBeforeSyncWrite

控制在调用带有显式同步的写回调之前是否对 NvM 内部缓冲区进行初始化。

TRUE:启用在调用带有显式同步的写回调之前对 NvM 内部缓冲区的初始化。这意味着在执行写操作之前,会确保 NvM 内部缓冲区的数据是初始化过的。

FALSE:禁用在调用带有显式同步的写回调之前对 NvM 内部缓冲区的初始化。这意味着在执行写操作之前,不会对 NvM 内部缓冲区的数据进行初始化。

NvMRbMainFunctionScheduling

定义 NvM_MainFunction() 函数的调用方式。

Background-task via RTE:通过RTE在后台任务中调用 NvM_MainFunction()。这意味着 NvM_MainFunction() 在后台任务中周期性地由RTE调用。

Scheduled task via RTE:通过RTE在调度任务中调用 NvM_MainFunction()。这表示 NvM_MainFunction() 在由RTE调度的定时任务中周期性地被调用。

Not called via RTE, scheduled manually:不通过RTE调用,需要手动调度 NvM_MainFunction()。这意味着不会生成任何RTE事件或实体来调用 NvM_MainFunction(),而是由应用程序手动调度。

NvMRbMultiBlockStartCallback

定义一个公共回调函数的入口地址,用于在每次异步多块请求即将启动时被调用。

NULL_PTR:指定不调用任何这样的回调函数。
具体的回调函数名称:指定一个函数名作为回调函数的入口地址,该函数会在异步多块请求即将启动时被调用。

回调函数声明:
如果 NvMRbCallbackSignatureAR45 设置为 false:回调函数的声明应为 Std_ReturnType CallbackName(uint8 ServiceId)。
如果 NvMRbCallbackSignatureAR45 设置为 true:回调函数的声明应为 Std_ReturnType CallbackName(NvM_MultiBlockRequestType MultiBlockRequest)。

在该回调函数中不允许调用任何 NvM 或 DEM 模块的函数。

NvMRbNoInitCallbackRomBlockConfigured

控制是否在具有ROM块配置特性的情况下调用初始化回调函数。

TRUE:禁用初始化回调函数如果一个块配置了ROM块特性,则不会调用初始化回调函数。只有当块未配置ROM块时才会调用初始化回调函数。

FALSE:不启用该特性,即无论块是否配置了ROM块特性,均会调用初始化回调函数。

NvMRbNoSingleBlockBeforeReadAll

控制在执行完“ReadAll”服务之前禁止任何单块请求的处理。

TRUE:启用该特性。如果设置为 “true”,则在执行完“ReadAll”服务之前,任何单块访问请求都将被拒绝并返回错误码 E_NOT_OK。

FALSE:禁用该特性。即使在执行完“ReadAll”服务之前,仍允许处理单块访问请求。

NvMRbNvCrcEnable

全局启用或禁用对具有块特定参数 NvMBlockUseCrc 设置为TRUE的NVRAM块使用CRC。

TRUE:启用该功能。如果设置为TRUE,则根据块特定参数 NvMBlockUseCrc 的设置决定是否在NVM级别使用CRC。即使 NvMBlockUseCrc 设置为TRUE,也只有当 NvMRbNvCrcEnable 为TRUE时才会在NVM级别使用CRC。

FALSE:禁用该功能。即使 NvMBlockUseCrc 设置为TRUE,也不会在NVM级别使用CRC。
注意事项:

对于不使用完整MemStack的项目,建议将 NvMRbNvCrcEnable 设置为TRUE,以启用CRC使用。
对于使用完整MemStack的项目,建议将 NvMRbNvCrcEnable 设置为FALSE,因为较低的软件层已经应用了CRC完整性检查。

激活CRC使用时,NVM块的大小将变化,因为包括了CRC大小,这可能对向后兼容性产生影响。

NvMRbObserverCallback

定义在异步请求中,当一个块的作业处理结束时被调用的回调函数的名称。

NULL_PTR:指定不调用任何这样的回调函数。
具体的回调函数名称:指定一个函数名作为回调函数的名称,当一个块的作业处理结束时会调用该函数。

该回调函数与多块回调不同,它会在每个配置的块处理结束时被调用,包括配置ID块(当启用动态配置时),但不包括块#0。

从这个回调函数内部不允许调用任何NvM或DEM函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

美好生活丶

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

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

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

打赏作者

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

抵扣说明:

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

余额充值