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

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

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

AUTOSAR Ea深度剖析

嵌入式軟件實(shí)戰(zhàn)派 ? 來源:嵌入式軟件實(shí)戰(zhàn)派 ? 2023-03-22 11:00 ? 次閱讀

我已經(jīng)寫了很多關(guān)于AUTOSAR Memory Stack相關(guān)的文章教程了,初學(xué)者按照這些教程步驟去實(shí)操,入門進(jìn)階是應(yīng)該是沒問題的了。

AUTOSAR的Memory是如何設(shè)計(jì)的?

一圖讀懂AUTOSAR NvM(附pdf版文檔資源)

AUTOSAR NvM模塊配置詳解

AUTOSAR中的NvM、Ea和Eeprom之間是如何相互關(guān)聯(lián)的?

但是對于好學(xué)的人,怎么可以止步于此呢!我剛學(xué)AUTOSAR搞EEPROM的時(shí)候,遇到一堆問題,就想對Ea這個(gè)模塊刨根問底,看看其到底做了哪些功能?;叵氘?dāng)初掉坑、苦惱摸索的日子,心覺甚是艱難,于是總結(jié)一下這個(gè)Ea模塊。

溫馨提示:本文會(huì)涉及或詳細(xì)講到以下內(nèi)容:

分析AUTOSAR的Eeprom為什么效率比較低

如何將AUTOSAR Memory Stack移植到PC上模擬仿真

解讀Ea里面的磨損均衡算法

以gif動(dòng)圖展現(xiàn)Eeprom的最終讀寫行為(文末有下載動(dòng)圖的方法)

1.AUTOSAR Eeprom讀寫效率很低?

之前我搞這個(gè)玩意的時(shí)候,好不容易將這個(gè)NvM和EEPROM等配置好,生成代碼編譯通過運(yùn)行OK,還真以為OK了,誰知高興早了。

如果對Ea里面的機(jī)制不了解的話,平時(shí)也不特別測試這個(gè)EEPROM的讀寫速度,很難發(fā)現(xiàn)這個(gè)效率問題。

之前,我們項(xiàng)目遇到一個(gè)問題,特意測試了下,從寫NvM開始,到實(shí)際EEPROM寫完返回Notification,就簡單寫幾個(gè)字節(jié)就花了超20ms。

一開始不可置信,特意查了EEPROM手冊,明明寫一個(gè)page時(shí)間是<4ms,這幾個(gè)字節(jié)也在一個(gè)page里面,怎么就花了數(shù)倍的時(shí)間!為了做個(gè)對比,直接拿個(gè)非AUTOSAR工程來試試,也就4ms上下。怎么會(huì)差別這么大?

為了搞清楚這個(gè)問題,一開始仿真看看這個(gè)過程在搞什么鬼,奈何這個(gè)NvM、Ea和EEPROM都是異步的,代碼也很復(fù)雜,就Ea一個(gè)模塊就15個(gè)C文件,沒法看下去。

84e14a26-c858-11ed-bfe3-dac502259ad0.png

擼碼擼了很久,最后找到EEPROM的末端函數(shù),看看這個(gè)EEPROM寫入是如何進(jìn)行的,里面?zhèn)鬟f的地址和數(shù)據(jù)到底是什么東西。

不看不知道,一看嚇一跳,寫一段Eeprom數(shù)據(jù),除了有“寫”的接口調(diào)用,也有“讀”的接口調(diào)用,而且這個(gè)“寫”還不止寫一次……讓我瞬間懷疑人生了,還以為我調(diào)用了好多次寫接口。

因?yàn)檫@東西,搞得幾天沒覺好睡。為了搞清楚這Ea里面的行為,翻了很多AUTOSAR的官方文檔和Ea、Eeprom里面的源碼。雖然,能尋得一些皮毛,但是還是很不理解。

為了直觀地理解這個(gè)操作過程,還根據(jù)《RTOS內(nèi)存分析動(dòng)圖是怎么做的?(附源碼)》里面的方法,做出了幾個(gè)動(dòng)圖。

例如,用了《AUTOSAR NvM模塊配置詳解》里面的例子,通過NvM接口往Eeprom寫入8個(gè)字節(jié),其執(zhí)行動(dòng)作如下:

84ee561c-c858-11ed-bfe3-dac502259ad0.gif

其實(shí),從這個(gè)圖可以看出,調(diào)用一些NvM的寫接口:

Rte_Call_NvMService_AC2_NvBlockNeed_8Bytes_WriteBlock(nvm_8bytes_wr_data);

其居然,對Eeprom進(jìn)行了5次操作!可參考下圖每個(gè)小圖下面的Action描述。

85190ae2-c858-11ed-bfe3-dac502259ad0.png

由于Eeprom的最大寫入時(shí)間為4ms(我實(shí)驗(yàn)的EEPROM是4ms,其他型號(hào)請參考對于的規(guī)格書),所以Eeprom_MainFunction的周期時(shí)間定義 為4ms,確保其執(zhí)行是可以順利完成的。

從上面捕捉到的數(shù)據(jù)看,這個(gè)Eeprom的MainFunction至少執(zhí)行了5次。所以,寫一次NvM不是和寫一次Eeprom時(shí)間等同的。

越搞越好奇,為什么寫個(gè)NvM要讀2次和寫3次Eeprom呢?,不是浪費(fèi)時(shí)間嗎?

2.AUTOSAR 能否在PC上仿真測試?

為了徹底搞清楚這些過程動(dòng)作,我不斷嘗試打log和仿真,很費(fèi)時(shí)間,用起來很不爽。

想著,這AUTOSAR能否搬到PC上模擬?

整套AUTOSAR搬過去應(yīng)該是非常困難的,因?yàn)樯婕暗胶芏嘤布嚓P(guān)的接口。那么只是將AUTOSAR的Memory Stack(NvM、MemIf、Ea和Eeprom)搬到PC上運(yùn)行,是否可行呢?

唯一跟硬件相關(guān)的只是Eeprom模塊調(diào)用的IIC接口了,把IIC接口打樁不就行了。然后將實(shí)際寫入EEPROM的數(shù)據(jù)重定向到PC上寫文件不就行了。

想想好像也不難,不難那就干起來。

開發(fā)編譯環(huán)境,我嘗試了微軟的visual studio IDE,用起來不爽,關(guān)鍵遇到一堆編譯錯(cuò)誤,后來換GCC編譯(Windows上的Cygwin環(huán)境),順手寫了個(gè)Makefile。

一頓操作猛如虎,編譯調(diào)試二百五。

都怪當(dāng)初沒好好學(xué)習(xí),搞得現(xiàn)在將Makefile、Gcc編譯、Cygwin的環(huán)境等等統(tǒng)統(tǒng)研究了一番,也算是額外的收獲吧。

其實(shí)也很簡單,就兩步,而我走了很多彎路而已:

按這個(gè)思路搞下去,雖然要花一點(diǎn)點(diǎn)時(shí)間,你也會(huì)把AUTOSAR里面這幾個(gè)模塊的編譯依賴也搞清楚了,對學(xué)習(xí)AUTOSAR是挺有幫助的。

添加所需的C文件,包括:

NvM、MemIf、Ea、Eeprom模塊里所有的.c文件

配置生成的和Memory相關(guān)的文件,例如NvM_Cfg.c等

測試代碼,例如仿真工程理解的main.c等

解決編譯問題,gcc一個(gè)命令搞過去,肯定有很多編譯錯(cuò)誤的,例如:

第一個(gè)就是頭文件找不到問題,通過gcc的-I參數(shù)指定路徑就可以了;

還有就是AUTOSAR里面定義的一些跟編譯選項(xiàng)有關(guān)的預(yù)編譯(例如#pragmaghs...這種是Greenhills用的)問題,屏蔽這些沒用的代碼即可

Rte.c里面很多內(nèi)容編譯錯(cuò)誤或者鏈接時(shí)找不到,這個(gè)只能把有用的函數(shù)或定義摳出來,重新放到一個(gè)文件里面,加入編譯,而Rte.c就不要包含到編譯選項(xiàng)了;

...

接下來最關(guān)鍵的就是Eeprom的讀寫接口了,因?yàn)槲覀兙拖胪ㄟ^這個(gè)看數(shù)據(jù)的,例如我是這樣模擬這個(gè)write接口的:

FILE* f = fopen("./EEP_MEM.data", "rb+"); if (f) { fseek(f, addr, SEEK_SET); int cur = ftell(f); fwrite(data, len, 1, f); fclose(f); } printf("EEPROM Write data to 0x%04X: ", addr); MEM_PRINT_DATA(data, len);

直接操作文件,病通過printf輸出log,絲滑一般順暢。

然后,把你想看的過程都輸出log,那么就可以得出我曾在《AUTOSAR NvM模塊配置詳解》就放出來過的log:

NVMTestWriteData:0001020304050607
Runnable_NvMcalled(1),ret=0
Runnable_NvMcalled(2),ret=0
Runnable_NvMcalled(3),ret=0
Runnable_NvMcalled(4),ret=0
EEPROMReaddatafrom0x000C:FF
Runnable_NvMcalled(5),ret=0
Runnable_NvMcalled(6),ret=0
EEPROMReaddatafrom0x0015:FF
Runnable_NvMcalled(7),ret=0
Runnable_NvMcalled(8),ret=0
Runnable_NvMcalled(9),ret=0
Runnable_NvMcalled(10),ret=0
Runnable_NvMcalled(11),ret=0
Runnable_NvMcalled(12),ret=0
EEPROMWritedatato0x000C:F0
Runnable_NvMcalled(13),ret=0
Runnable_NvMcalled(14),ret=0
Runnable_NvMcalled(15),ret=0
EEPROMWritedatato0x000D:0001020304050607
Runnable_NvMcalled(16),ret=0
Runnable_NvMcalled(17),ret=0
Runnable_NvMcalled(18),ret=0
EEPROMWritedatato0x0015:F0
Runnable_NvMcalled(19),ret=0
Runnable_NvMcalled(20),ret=0
Runnable_NvMcalled(21),ret=0
Runnable_NvMcalled(22),ret=0
Runnable_NvMcalled(23),ret=0
NvMNotifyJobFinished_NvBlockNeed_8Byte_JobFinished(7,0)
NVMTestWritefinish.

就這樣,NvM執(zhí)行后對Eeprom的操作過程就一目了然了,為什么效率低也變得很清晰了。

那么,關(guān)鍵問題來了:為什么寫NvM有這么多操作,都是做什么用的?

審核編輯 :李倩

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

    關(guān)注

    7

    文章

    2730

    瀏覽量

    47630
  • 算法
    +關(guān)注

    關(guān)注

    23

    文章

    4625

    瀏覽量

    93143
  • AUTOSAR
    +關(guān)注

    關(guān)注

    10

    文章

    363

    瀏覽量

    21672

原文標(biāo)題:AUTOSAR Ea深度剖析

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

收藏 人收藏

    評論

    相關(guān)推薦

    《C語言深度剖析》【超經(jīng)典書籍】

    本帖最后由 zgzzlt 于 2012-8-16 14:23 編輯 《C語言深度剖析》【超經(jīng)典書籍】
    發(fā)表于 08-02 08:59

    C語言深度剖析

    C語言深度剖析——一本關(guān)于C語言學(xué)習(xí)的教程,里面包含C語言編寫規(guī)范,各種變量指針用法等。以含金量勇敢挑戰(zhàn)國內(nèi)外同類書籍
    發(fā)表于 08-14 11:36

    c語言深度剖析

    c語言深度剖析
    發(fā)表于 04-02 09:12

    陳正沖《C語言深度剖析

    陳正沖編寫的《C語言深度剖析》,挺經(jīng)典,剛來論壇,多多指教~~
    發(fā)表于 08-17 12:06

    linux內(nèi)核深度剖析,另附有光盤資料

    linux內(nèi)核深度剖析,對于想學(xué)linux內(nèi)核的人來說,絕對值得一看,另附有光盤資料。
    發(fā)表于 01-15 21:25

    【資料分享】C語言深度剖析

    C語言深度剖析
    發(fā)表于 10-16 15:16

    C語言深度剖析

    C語言深度剖析
    發(fā)表于 08-25 09:08

    C語言深度剖析

    C語言深度剖析[完整版].pdfC語言深度剖析[完整版].pdf (919.58 KB )
    發(fā)表于 03-19 05:11

    功能安全---AUTOSAR架構(gòu)深度解析 精選資料分享

    AUTOSAR架構(gòu)深度解析本文轉(zhuǎn)載于:AUTOSAR架構(gòu)深度解析AUTOSAR的分層式設(shè)計(jì),用于支持完整的軟件和硬件模塊的獨(dú)立性(Indep
    發(fā)表于 07-23 08:34

    AUTOSAR架構(gòu)深度解析 精選資料推薦

    AUTOSAR架構(gòu)深度解析本文轉(zhuǎn)載于:AUTOSAR架構(gòu)深度解析目錄AUTOSAR架構(gòu)深度解析
    發(fā)表于 07-28 07:40

    AUTOSAR架構(gòu)深度解析 精選資料分享

    AUTOSAR架構(gòu)深度解析本文轉(zhuǎn)載于:AUTOSAR架構(gòu)深度解析AUTOSAR的分層式設(shè)計(jì),用于支持完整的軟件和硬件模塊的獨(dú)立性(Indep
    發(fā)表于 07-28 07:02

    C語言深度剖析

    C語言深度剖析。
    發(fā)表于 05-05 17:40 ?7次下載

    C語言深度剖析

    C語言深度剖析
    發(fā)表于 12-20 22:50 ?0次下載

    AUTOSAR Fee模塊配置詳解

    AUTOSAR Fee的配置跟Ea類似,方法都可以觸類旁通。
    的頭像 發(fā)表于 06-01 10:05 ?4747次閱讀
    <b class='flag-5'>AUTOSAR</b> Fee模塊配置詳解

    C語言深度剖析.zip

    C語言深度剖析
    發(fā)表于 12-30 09:20 ?5次下載