0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

NvM在AUTOSAR中的層次結(jié)構(gòu)

嵌入式軟件實(shí)戰(zhàn)派 ? 來源:CSDN ? 作者:CSDN ? 2022-04-21 10:47 ? 次閱讀

AUTOSAR中的NvM看起來挺難的,特別是在配置的時(shí)候,一堆參數(shù),都不知道是干什么用的。想去研究它,卻不知如何下手。

其實(shí)吧,AUTOSAR的官方文檔講的挺詳細(xì)的,但是內(nèi)容很多,網(wǎng)上有很多文章對(duì)其進(jìn)行解讀,很多人沒時(shí)間也不想細(xì)讀它。

本文打算換個(gè)討論,不再累述其內(nèi)容細(xì)節(jié)了,而通過圖解的方式,將NvM重要特點(diǎn)提取出來講解,方便理解,也方便記憶。

1.NvM在AUTOSAR中的層次結(jié)構(gòu)

AUTOSAR中有個(gè)Memory的處理,在架構(gòu)中是這樣的20305a44-bfae-11ec-bce3-dac502259ad0.png分類三層,分別是Memory Service(NvM)、Memory Hardware Abstraction(Memory If和Fee/Ea)和Memory Driver(Fls/Eep驅(qū)動(dòng)),單獨(dú)拎出來就是這樣的2040c5be-bfae-11ec-bce3-dac502259ad0.png 這部分在架構(gòu)中有這樣的接口關(guān)系205145d8-bfae-11ec-bce3-dac502259ad0.png

回到Nvm,這個(gè)NVM即Non-VolatileRAM Manager (NVRAM Manager),用于管理存儲(chǔ)于各類non-volatile memory(如EEPROM/Flash等)的數(shù)據(jù)。

NVM在AUTOSAR中是獨(dú)立于硬件的,通過底層接口訪問外部EEPROM或模擬成EEPROM的DataFlash。為了適用于所有的車載系統(tǒng),其具有高度可擴(kuò)展性和可靠性。

2.Memory抽象層空間尋址策略

AUTOSAR中的Memory是怎么尋址的呢?

其實(shí),MemoryAbstraction Interface為底層EEPROM/FEE提供32位地址空間,像這樣

20652260-bfae-11ec-bce3-dac502259ad0.png

這個(gè)虛擬的邏輯地址是包含著一些信息的,如NV Block number和Dataset index,還有Block address offset等,他們的關(guān)系可以通過以下公式來理解

FEE/EA_BLOCK_NUMBER=(NvMNvBlockBaseNumber << NvMDatasetSelectionBits) + DataIndex

舉個(gè)例子,假如NVM_DATASET_SELECTION_BITS配置為4bits,那么就有14bits留給blocknumber,因此可以分最大有16個(gè)dataset。

207606e8-bfae-11ec-bce3-dac502259ad0.png

3.NvM Basic Storage Object

以上提到的Dataset、NV Block等概念,是不是容易混淆,也不清楚是干什么用的?好了,下面做個(gè)匯總和介紹。

名稱

描述

Basic Storage Object

Basic Storage Object是一個(gè)最小的NVRAM block,多個(gè)Basic Storage Objects可以組成一個(gè)NVRAM Block。

NVRAM Block

NVRAM Block是管理和存儲(chǔ) NV Block所需的整個(gè)結(jié)構(gòu)

NV data

要存儲(chǔ)在Non-Volatile memory的數(shù)據(jù)

Block Management Type

這個(gè)是NVRAM Block的類型,它取決于強(qiáng)制/可選Basic Storage ObjectNVRAM Block的(可配置的)單獨(dú)組成以及該 NVRAM 塊的后續(xù)處理。

RAM Block

屬于Basic Storage Object,它是NVRAM Block的一部分,常駐于RAM空間。

ROM Block

屬于Basic Storage Object,它是NVRAM Block的一部分(可選的),常駐于ROM空間。

NV Block

屬于Basic Storage Object,它是NVRAM Block的一部分(必選的),常駐于NV空間。

NV Block Header

如果Static Block IDenable的,這個(gè)作為附加信息包含在NV Block中。

Administrative Block

屬于Basic Storage Object,它常駐于RAM,是NVRAM Block必選部分。

用一個(gè)圖來表達(dá)就是這樣的

208a8bd6-bfae-11ec-bce3-dac502259ad0.png

圖上得這幾個(gè)block,用圖示來看可能會(huì)更容易理解

20a541b0-bfae-11ec-bce3-dac502259ad0.png

4.NvM Block Management Type

NVM在AUTOSAR中的功能是挺完善的,要滿足車載系統(tǒng)的各種需求,例如數(shù)據(jù)塊錯(cuò)了怎么辦等等,都考慮周全。

NvM支持三種類型實(shí)現(xiàn):Native、Redundant和Dataset。那么這三種類型是怎樣的呢?

我做了個(gè)表,他們包含了哪幾種block

NV Block

RAM Block

ROM Block

Administrator Block

Native

1

1

0..1

1

Redundant

2

1

0..1

1

Dataset

1..255

1

0..n

1

  1. Native
    這種最簡(jiǎn)單,平時(shí)大多情況下,我們用的就是這種

    它包含就簡(jiǎn)單的NV Block,其他如Header和CRC都是隨意可選配置。

    20bfbf5e-bfae-11ec-bce3-dac502259ad0.png

  2. Redundant

    這種就復(fù)雜一點(diǎn)點(diǎn),可以簡(jiǎn)單理解為雙備份,意思是,如有一份數(shù)據(jù)錯(cuò)了,可以用備份的那塊。

    20cfeb7c-bfae-11ec-bce3-dac502259ad0.png

  3. Dataset

Dataset呢,這個(gè)不是多備份哈,而是針對(duì)不同配置做了對(duì)應(yīng)。例如一個(gè)車系統(tǒng)平臺(tái)有很多種配置,但有想集成在同一個(gè)軟件種,那么就有很多個(gè)對(duì)應(yīng)的配置數(shù)據(jù),在運(yùn)行的時(shí)候根據(jù)配置參數(shù)選擇哪份數(shù)據(jù)使用。

20e7470e-bfae-11ec-bce3-dac502259ad0.png

5.NVRAM Manager API 配置類

講到NvM的API,其實(shí)NvM API分三類:

Class3:所有指定的API調(diào)用都可用,最多支持功能。

Class2:有一組中間API調(diào)用可用。

Class1:特別是對(duì)于硬件資源非常有限的匹配系統(tǒng),此API配置類僅提供最少的一組

Class 3 包含下面這些API:Type 1:- NvM_SetDataIndex(...)- NvM_GetDataIndex(...)- NvM_SetBlockProtection(...)- NvM_GetErrorStatus(...)- NvM_SetRamBlockStatus(...)- NvM_SetBlockLockStatusType 2:- NvM_ReadBlock(...)- NvM_WriteBlock(...)- NvM_RestoreBlockDefaults(...)- NvM_EraseNvBlock(...)- NvM_InvalidateNvBlock(...)- NvM_CancelJobs(…)- NvM_ReadPRAMBlock(...)- NvM_WritePRAMBlock(...)- NvM_RestorePRAMBlockDefaults(...)Type 3:- NvM_ReadAll(...)- NvM_WriteAll(...)- NvM_CancelWriteAll(...)- NvM_ValidateAll(...)Type 4:- NvM_Init(...)Class 2 包含下面這些API:Type 1:- NvM_SetDataIndex(...)- NvM_GetDataIndex(...)- NvM_GetErrorStatus(...)- NvM_SetRamBlockStatus(...)- NvM_SetBlockLockStatusType 2:- NvM_ReadBlock(...)- NvM_WriteBlock(...)- NvM_RestoreBlockDefaults(...)- NvM_CancelJobs(…)- NvM_ReadPRAMBlock(...)- NvM_WritePRAMBlock(...)- NvM_RestorePRAMBlockDefaults(...)Type 3:- NvM_ReadAll(...)- NvM_WriteAll(...)- NvM_CancelWriteAll(...)- NvM_ValidatedAll(...) Type 4:- NvM_Init(...)
Class 1 包含下面這些API:Type 1:- NvM_GetErrorStatus(...)- NvM_SetRamBlockStatus(...)- NvM_SetBlockLockStatusType 2:- --Type 3:- NvM_ReadAll(...)- NvM_WriteAll(...)- NvM_CancelWriteAll(...)Type 4:- NvM_Init(...)

也許你會(huì)好奇,上面提到的Type是啥?

其實(shí)是根據(jù)功能分類而已,可以參考下表內(nèi)容

Request Types

Characteristics of Request Types

Type 1:

- NvM_SetDataIndex (...)

- NvM_GetDataIndex (...)

- NvM_SetBlockProtection (...)

- NvM_GetErrorStatus(...)

- NvM_SetRamBlockStatus(...)

n同步請(qǐng)求

n作用于一個(gè)RAM Block

n適用于所有SWC

Type 2:

- NvM_ReadBlock(...)

- NvM_WriteBlock(...)

- NvM_RestoreBlockDefaults(...)

- NvM_EraseNvBlock(...)

- NvM_InvalidateNvBlock(...)

- NvM_CancelJobs(…)

- NvM_ReadPRAMBlock(...)

- NvM_WritePRAMBlock(...)

- NvM_RestorePRAMBlockDefaults(...)

n異步請(qǐng)求(通過callbackpolling返回結(jié)果)

n作用于一個(gè)NVRAM Block

n通過NVRAM manager task處理

n適用于所有SWC

Type 3:

- NvM_ReadAll(...)

- NvM_WriteAll(...)

- NvM_CancelWriteAll(...)

- NvM_ValidateAll(...)

n異步請(qǐng)求(通過callbackpolling返回結(jié)果

n作用于具有常駐RAM dataNVRAM Block

Type 4:

- NvM_Init(...)

n同步請(qǐng)求

n基本初始化

n通過函數(shù)本身內(nèi)部的命令接口向任務(wù)發(fā)出成功信號(hào)

6. NvM Descriptor Table

以上講的都是一些原理或者配置上的東西,那么在軟件代碼上是怎么用的呢,其實(shí)用到了一個(gè)描述符表(Descriptor Table),即將所有的配置信息映射或囊括到這里面來,那么這個(gè)表是怎樣的?

AUTOSAR的配置策略,要將所有和NVRAM 描述符相關(guān)的內(nèi)容在配置期間生成,生成的內(nèi)容包含以下信息。

SWS Item

Items

Type

ECUC_NvM_00476

NvMBlockCrcType

EcucEnumerationParamDef

ECUC_NvM_00554

NvMBlockHeaderInclude

EcucStringParamDef

ECUC_NvM_00477

NvMBlockJobPriority

EcucIntegerParamDef

ECUC_NvM_00062

NvMBlockManagementType

EcucEnumerationParamDef

ECUC_NvM_00557

NvMBlockUseAutoValidation

EcucBooleanParamDef

ECUC_NvM_00556

NvMBlockUseCRCCompMechanism

EcucBooleanParamDef

ECUC_NvM_00036

NvMBlockUseCrc

EcucBooleanParamDef

ECUC_NvM_00552

NvMBlockUseSetRamBlockStatus

EcucBooleanParamDef

ECUC_NvM_00519

NvMBlockUseSyncMechanism

EcucBooleanParamDef

ECUC_NvM_00033

NvMBlockWriteProt

EcucBooleanParamDef

ECUC_NvM_00551

NvMBswMBlockStatusInformation

EcucBooleanParamDef

ECUC_NvM_00119

NvMCalcRamBlockCrc

EcucBooleanParamDef

ECUC_NvM_00116

NvMInitBlockCallback

EcucFunctionNameDef

ECUC_NvM_00533

NvMMaxNumOfReadRetries

EcucIntegerParamDef

ECUC_NvM_00499

NvMMaxNumOfWriteRetries

EcucIntegerParamDef

ECUC_NvM_00478

NvMNvBlockBaseNumber

EcucIntegerParamDef

ECUC_NvM_00479

NvMNvBlockLength

EcucIntegerParamDef

ECUC_NvM_00480

NvMNvBlockNum

EcucIntegerParamDef

ECUC_NvM_00481

NvMNvramBlockIdentifier

EcucIntegerParamDef

ECUC_NvM_00035

NvMNvramDeviceId

EcucIntegerParamDef

ECUC_NvM_00482

NvMRamBlockDataAddress

EcucStringParamDef

ECUC_NvM_00521

NvMReadRamBlockFromNvCallback

EcucFunctionNameDef

ECUC_NvM_00483

NvMResistantToChangedSw

EcucBooleanParamDef

ECUC_NvM_00484

NvMRomBlockDataAddress

EcucStringParamDef

ECUC_NvM_00485

NvMRomBlockNum

EcucIntegerParamDef

ECUC_NvM_00117

NvMSelectBlockForReadAll

EcucBooleanParamDef

ECUC_NvM_00549

NvMSelectBlockForWriteAll

EcucBooleanParamDef

ECUC_NvM_00506

NvMSingleBlockCallback

EcucFunctionNameDef

ECUC_NvM_00532

NvMStaticBlockIDCheck

EcucBooleanParamDef

ECUC_NvM_00072

NvMWriteBlockOnce

EcucBooleanParamDef

ECUC_NvM_00520

NvMWriteRamBlockToNvCallback

EcucFunctionNameDef

ECUC_NvM_00534

NvMWriteVerification

EcucBooleanParamDef

ECUC_NvM_00538

NvMWriteVerificationDataSize

EcucIntegerParamDef

這個(gè)最好對(duì)著代碼去看更好理解。

7. 總結(jié)

以上講得內(nèi)容都不是很深入,適合剛?cè)胧值男』锇閷W(xué)習(xí),我將以上內(nèi)容做成了一份備查手冊(cè),方便以后看代碼或者閱讀文檔的時(shí)候,可以直接查看,不用費(fèi)神看那么多雞腸文英語。

20ffe160-bfae-11ec-bce3-dac502259ad0.png

審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • AUTOSAR
    +關(guān)注

    關(guān)注

    10

    文章

    344

    瀏覽量

    21410
  • 車載系統(tǒng)
    +關(guān)注

    關(guān)注

    1

    文章

    131

    瀏覽量

    27086

原文標(biāo)題:一圖讀懂AUTOSAR NvM(附pdf版文檔資源)

文章出處:【微信號(hào):embedded_sw,微信公眾號(hào):嵌入式軟件實(shí)戰(zhàn)派】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    存儲(chǔ)器的層次結(jié)構(gòu)包括哪些

    存儲(chǔ)器的層次結(jié)構(gòu)是計(jì)算機(jī)系統(tǒng)中一個(gè)關(guān)鍵且復(fù)雜的部分,它決定了數(shù)據(jù)的存儲(chǔ)、訪問和處理效率。存儲(chǔ)器的層次結(jié)構(gòu)主要包括多個(gè)層次,每個(gè)
    的頭像 發(fā)表于 09-10 14:28 ?218次閱讀

    Vector AUTOSAR的TISCI服務(wù)器集成

    電子發(fā)燒友網(wǎng)站提供《Vector AUTOSAR的TISCI服務(wù)器集成.pdf》資料免費(fèi)下載
    發(fā)表于 08-30 11:16 ?0次下載
    Vector <b class='flag-5'>AUTOSAR</b><b class='flag-5'>中</b>的TISCI服務(wù)器集成

    AUTOSAR MCAL驅(qū)動(dòng)程序與演示程序的Libraries的驅(qū)動(dòng)程序有什么不同之處?

    1.關(guān)于 AUTOSAR MCAL 驅(qū)動(dòng)程序 與演示程序的 Libraries 的驅(qū)動(dòng)程序 有什么不同之處? 2.AUTOSAR MCAL 驅(qū)動(dòng)程序
    發(fā)表于 05-17 06:55

    存儲(chǔ)器層次結(jié)構(gòu)如何解釋?

    存儲(chǔ)器層次結(jié)構(gòu)可以從圖片中清晰的看出來,圖片中共分為六級(jí),越向上的層次,存儲(chǔ)器速度越快,容量更小,造價(jià)越高。
    的頭像 發(fā)表于 02-19 14:03 ?800次閱讀
    存儲(chǔ)器<b class='flag-5'>層次</b><b class='flag-5'>結(jié)構(gòu)</b>如何解釋?

    淺談存儲(chǔ)器層次結(jié)構(gòu)

    通過多級(jí)存儲(chǔ)器的設(shè)計(jì),存儲(chǔ)器層次結(jié)構(gòu)能夠存儲(chǔ)容量和訪問速度之間找到一個(gè)平衡點(diǎn)。高速緩存存儲(chǔ)器和主存儲(chǔ)器提供了快速的訪問速度,而輔助存儲(chǔ)器則提供了大量的存儲(chǔ)空間。
    發(fā)表于 02-19 13:54 ?531次閱讀
    淺談存儲(chǔ)器<b class='flag-5'>層次</b><b class='flag-5'>結(jié)構(gòu)</b>

    簡(jiǎn)述存儲(chǔ)器的層次結(jié)構(gòu)及其分層原因

    存儲(chǔ)器的層次結(jié)構(gòu)是計(jì)算機(jī)系統(tǒng)存儲(chǔ)器的層次化組織,分為多個(gè)層次,每個(gè)層次具有不同的訪問速度、容量
    發(fā)表于 02-05 09:46 ?1780次閱讀

    NVM和本地\"內(nèi)存定義數(shù)組(靜態(tài) /global /local)的\"關(guān)鍵字是什么?

    NVM 和本地\"內(nèi)存定義數(shù)組(靜態(tài) /global /local)的\"關(guān)鍵字是什么? 還有與 32 位對(duì)齊的關(guān)鍵字怎么樣。
    發(fā)表于 01-25 07:52

    AUTOSAR架構(gòu)復(fù)雜驅(qū)動(dòng)設(shè)計(jì)

    復(fù)雜驅(qū)動(dòng)(Complex Driver,CDD)是一種不受 AUTOSAR 標(biāo)準(zhǔn)化約束的軟件實(shí)體,它可以通過 AUTOSAR 接口和/或基礎(chǔ)軟件模塊 API 進(jìn)行訪問 AUTOSAR 組件或者被
    的頭像 發(fā)表于 12-21 10:13 ?3727次閱讀
    <b class='flag-5'>AUTOSAR</b>架構(gòu)<b class='flag-5'>中</b>復(fù)雜驅(qū)動(dòng)設(shè)計(jì)

    分析Autosar架構(gòu)下的NVM源碼

    (Non-Volatile Memory)是Autosar架構(gòu)的一個(gè)重要組件,用于管理和操作非易失性存儲(chǔ)器,以確保數(shù)據(jù)的持久性和可靠性。 NVM的實(shí)現(xiàn)是為了解決汽車電子系統(tǒng)重要數(shù)據(jù)
    的頭像 發(fā)表于 12-08 13:56 ?1289次閱讀

    芯片設(shè)計(jì)復(fù)雜性處理之層次結(jié)構(gòu)概念分析

     考慮當(dāng)今使用的層次結(jié)構(gòu)形式的最簡(jiǎn)單方法是要求工程師從概念上設(shè)計(jì)一個(gè)系統(tǒng)。他們可能會(huì)開始繪制一個(gè)包含大塊的框圖,其中包含 CPU、編碼器、顯示子系統(tǒng)等標(biāo)簽。這不是一個(gè)功能層次結(jié)構(gòu),盡管
    發(fā)表于 11-22 09:59 ?935次閱讀
    芯片設(shè)計(jì)復(fù)雜性處理之<b class='flag-5'>層次</b><b class='flag-5'>結(jié)構(gòu)</b>概念分析

    如何在非Autosar應(yīng)用執(zhí)行I2C?

    我是NXP產(chǎn)品的新產(chǎn)品,我試圖了解它的生態(tài)系統(tǒng)。我需要在非Autosar應(yīng)用執(zhí)行I2C,所以我需要了解它是如何工作的,所以我有一些問題: 1) RTD_I2C_UM.pdf
    發(fā)表于 11-13 07:04

    AUTOSARCAN信號(hào)是如何觸發(fā)COM回調(diào)的呢?

    AUTOSAR,COM模塊提供了兩種機(jī)制來處理接收到的PDU:ComRxPduCallout和ComNotification
    的頭像 發(fā)表于 11-01 10:26 ?1568次閱讀
    <b class='flag-5'>AUTOSAR</b><b class='flag-5'>中</b>CAN信號(hào)是如何觸發(fā)COM回調(diào)的呢?

    AUTOSAR CP的復(fù)雜驅(qū)動(dòng)是什么

    、ASIC等,以滿足特殊的功能和時(shí)序要求。此外,CDD還可以用于實(shí)現(xiàn)增強(qiáng)的服務(wù)/協(xié)議或封裝非AUTOSAR系統(tǒng)的傳統(tǒng)功能。CDD的實(shí)現(xiàn)可能與應(yīng)用、微控制器和ECU有關(guān)。最后,CDD可以作為引入現(xiàn)有或新概念到AUTOSAR軟件架構(gòu)
    的頭像 發(fā)表于 10-27 15:39 ?1979次閱讀
    <b class='flag-5'>AUTOSAR</b> CP的復(fù)雜驅(qū)動(dòng)是什么

    AUTOSAR經(jīng)典平臺(tái)介紹

    汽車電子系統(tǒng)的軟件組件、運(yùn)行時(shí)環(huán)境和通信機(jī)制,以實(shí)現(xiàn)模塊化、可重用和可擴(kuò)展的系統(tǒng)開發(fā)。 AUTOSAR CP,軟件組件被分為應(yīng)用軟件組件(SWC)和基礎(chǔ)軟件組件(BSW)。SWC是實(shí)現(xiàn)特定功能的軟件模塊,例如引擎控制、制動(dòng)系
    的頭像 發(fā)表于 10-27 15:30 ?1279次閱讀
    <b class='flag-5'>AUTOSAR</b>經(jīng)典平臺(tái)介紹

    AUTOSAR架構(gòu)自適應(yīng)平臺(tái)

    AUTOSAR架構(gòu)的目標(biāo)是實(shí)現(xiàn)汽車電子系統(tǒng)的模塊化、可重用和可擴(kuò)展,以提高開發(fā)效率和系統(tǒng)的可靠性。 AUTOSAR架構(gòu)由三個(gè)主要的層次組成:應(yīng)用層(Application Layer)、運(yùn)行時(shí)環(huán)境層
    的頭像 發(fā)表于 10-27 15:23 ?1172次閱讀
    <b class='flag-5'>AUTOSAR</b>架構(gòu)自適應(yīng)平臺(tái)