01
網(wǎng)絡(luò)管理初識(shí)
為了更加通俗易懂地介紹網(wǎng)絡(luò)管理,先來(lái)構(gòu)建一個(gè)例子來(lái)進(jìn)行說(shuō)明,如下所示:
對(duì)該圖稍作說(shuō)明:
對(duì)于一個(gè)控制器而言,它可能存在多種喚醒源,包括本地喚醒和網(wǎng)絡(luò)喚醒等方式,圖中這兩種方式都存在;?? ?
對(duì)于一個(gè)控制器參與CAN通訊,其他硬件組成有CAN收發(fā)器,CAN控制器和微控制器;
不同CAN總線網(wǎng)絡(luò)通過(guò)網(wǎng)關(guān)才能進(jìn)行通訊。
當(dāng)整車(chē)處于休眠狀態(tài),即所有的控制器都睡覺(jué)了,在整車(chē)某個(gè)休眠喚醒場(chǎng)景下,制動(dòng)踏板行程傳感器BPS感知到變化了,從而喚醒的硬線信號(hào)有了變化,被IEB檢測(cè)到了,那么處于休眠的IEB將被喚醒,對(duì)應(yīng)著圖中1區(qū)域,這里IEB稱為主動(dòng)喚醒節(jié)點(diǎn)。
此時(shí),為了實(shí)現(xiàn)這個(gè)喚醒場(chǎng)景的功能,需要參與其他一些控制器,比如EPS和VCU,稱為它倆為被動(dòng)喚醒節(jié)點(diǎn),這就意味著IEB需要去喚醒他倆。如果采用CAN總線的喚醒方式,則IEB可以通過(guò)網(wǎng)管報(bào)文去喚醒EPS和VCU,大致過(guò)程是:IEB被傳感器BPS喚醒后,它的網(wǎng)絡(luò)管理狀態(tài)會(huì)產(chǎn)生變化,由睡覺(jué)模式轉(zhuǎn)為網(wǎng)絡(luò)模式。
然后IEB會(huì)發(fā)出網(wǎng)管報(bào)文,EPS和VCU的CAN收發(fā)器會(huì)收到該網(wǎng)管報(bào)文,識(shí)別到需要喚醒,最后它們也會(huì)發(fā)網(wǎng)管報(bào)文,告訴IEB醒來(lái)了,可以一起搞事情,對(duì)應(yīng)到上圖的234部分。
在這個(gè)過(guò)程中,實(shí)現(xiàn)其實(shí)很復(fù)雜,有幾個(gè)層面的問(wèn)題值得深入探究:
一是功能層面,整車(chē)哪些功能有休眠喚醒場(chǎng)景?誰(shuí)是主動(dòng)喚醒節(jié)點(diǎn),誰(shuí)是被動(dòng)喚醒節(jié)點(diǎn)?
二是控制器層面:對(duì)于每個(gè)休眠喚醒場(chǎng)景,主動(dòng)喚醒節(jié)點(diǎn)是怎么被喚醒,被動(dòng)喚醒節(jié)點(diǎn)又是怎么被總線喚醒的?關(guān)于網(wǎng)絡(luò)管理狀態(tài)機(jī),這些控制器之間是如何管理網(wǎng)絡(luò)狀態(tài)?關(guān)于網(wǎng)絡(luò)管理報(bào)文,IEB發(fā)送網(wǎng)管報(bào)文應(yīng)該是怎樣的?而EPS和VCU的又是怎樣的?
02
為什么需要網(wǎng)絡(luò)管理?
在回答上面的這些問(wèn)題之前,先弄清楚下整車(chē)為什么需要進(jìn)行網(wǎng)絡(luò)管理,我們知道隨著汽車(chē)行業(yè)的快速發(fā)展,從燃油車(chē)到混動(dòng)車(chē)和純電動(dòng)車(chē),從傳統(tǒng)的機(jī)械鑰匙到遙控鑰匙再到無(wú)鑰匙進(jìn)入PEPS,汽車(chē)部署控制器越來(lái)越多。下面列舉上世紀(jì)和當(dāng)今汽車(chē)的整車(chē)網(wǎng)絡(luò)拓?fù)洌?/p>
Source: Global B 電子電氣架構(gòu),預(yù)示了通用的下一個(gè)十年。
Source: Global B 電子電氣架構(gòu),預(yù)示了通用的下一個(gè)十年。
不難理解,越來(lái)越多的控制器部署到汽車(chē)電子電器架構(gòu),意味著可以實(shí)現(xiàn)更多的功能,同時(shí)也意味著更多的能量消耗。另外,日益復(fù)雜的網(wǎng)絡(luò)拓?fù)鋵?duì)控制器間如何協(xié)同工作提出巨大的挑戰(zhàn)。為了節(jié)能減小耗電,某些時(shí)刻不需要工作的控制器應(yīng)該休眠;但某些時(shí)刻,又需要休眠的控制器立馬醒來(lái)參與工作。因此,需要一種控制機(jī)制或策略,即網(wǎng)絡(luò)管理策略,使得通訊拓?fù)渚W(wǎng)絡(luò)中的ECU節(jié)點(diǎn)能有序地休眠和喚醒,這樣就可以保證汽車(chē)功能的同時(shí)盡可能節(jié)省電量。
03
結(jié)合硬件來(lái)了解喚醒
當(dāng)車(chē)輛處于長(zhǎng)時(shí)間停止使用或待機(jī)狀態(tài)時(shí),控制器會(huì)進(jìn)入休眠模式以降低功耗。在需要時(shí),控制器又能被喚醒以響應(yīng)特定事件或指令,如車(chē)門(mén)開(kāi)關(guān)、遙控鑰匙信號(hào)等。這里,首先涉及到喚醒源,然后喚醒源作用在控制器硬件,最后一個(gè)控制器通過(guò)CAN總線網(wǎng)絡(luò)作用到另外的控制器,下面來(lái)詳細(xì)了解這些內(nèi)容。
3.1 喚醒源
先聊下喚醒源,常見(jiàn)的喚醒源有:本地喚醒,網(wǎng)絡(luò)喚醒和RTC喚醒等。本地喚醒是指某些控制器可以通過(guò)特定的觸發(fā)信號(hào)被喚醒,比如KL15硬線,某些傳感器喚醒引腳信號(hào)。當(dāng)這些觸發(fā)信號(hào)被檢測(cè)到時(shí),控制器可以被喚醒以執(zhí)行相應(yīng)的操作。
1)KL15硬線喚醒
KL15是汽車(chē)電子中的一個(gè)標(biāo)準(zhǔn)電源信號(hào),常用于控制器的供電。KL15硬線信號(hào)在車(chē)輛點(diǎn)火時(shí)處于高電平狀態(tài),表示電源已連接。KL15硬線喚醒是指通過(guò)監(jiān)測(cè)KL15信號(hào)的狀態(tài)變化來(lái)喚醒控制器或其他電子模塊,并開(kāi)始執(zhí)行相應(yīng)的操作,例如初始化或執(zhí)行特定任務(wù)等。下圖所示是一種最常見(jiàn)的KL15硬線喚醒方式。
Source: KL15和KL30 - Smah - 博客園 (cnblogs.com)
2)傳感器喚醒
做底盤(pán)域控開(kāi)發(fā)時(shí),就碰到制動(dòng)踏板傳感器有喚醒引腳。某些工況下,駕駛員踩制動(dòng)踏板,制動(dòng)踏板傳感器感知到后,通過(guò)其喚醒引腳以硬線形式去喚醒某些控制器,比如IEB,從而及時(shí)觸發(fā)這些車(chē)輛穩(wěn)定性控制系統(tǒng)或防抱死制動(dòng)系統(tǒng)等安全系統(tǒng)的操作。
3)CAN網(wǎng)絡(luò)喚醒
CAN網(wǎng)絡(luò)喚醒源是指能夠通過(guò)CAN總線發(fā)送網(wǎng)絡(luò)報(bào)文,以喚醒處于休眠狀態(tài)的設(shè)備或模塊。這些網(wǎng)絡(luò)報(bào)文可以是預(yù)定義的標(biāo)準(zhǔn)報(bào)文,也可以是自定義的擴(kuò)展報(bào)文。接收到特定的喚醒報(bào)文后,設(shè)備或模塊會(huì)解析該報(bào)文并進(jìn)行相應(yīng)的喚醒操作。比如,當(dāng)CAN收發(fā)器監(jiān)控到總線電平變化或者特定報(bào)文時(shí),就可以通過(guò)INH引腳使能電源芯片供電,從而喚醒ECU。
Source: 你知道BMS有哪些內(nèi)外部的喚醒信號(hào)嗎 (zhihu.com)
CAN網(wǎng)絡(luò)喚醒從喚醒方式來(lái)進(jìn)一步劃分的話,可以分為:
喚醒幀(Wake-up Frame):CAN網(wǎng)絡(luò)中的節(jié)點(diǎn)可以通過(guò)發(fā)送喚醒幀來(lái)喚醒其他節(jié)點(diǎn)或整個(gè)系統(tǒng)。喚醒幀是一種特殊的CAN數(shù)據(jù)幀,它包含喚醒標(biāo)識(shí)符和相關(guān)的控制信息,用于告知接收節(jié)點(diǎn)進(jìn)行喚醒操作。
連續(xù)監(jiān)聽(tīng)(Continuous Listening):某些CAN網(wǎng)絡(luò)實(shí)現(xiàn)中,節(jié)點(diǎn)可以設(shè)置為持續(xù)監(jiān)聽(tīng)CAN總線,以偵聽(tīng)特定的喚醒幀或其他相關(guān)報(bào)文。當(dāng)接收到指定的報(bào)文時(shí),節(jié)點(diǎn)將執(zhí)行喚醒操作。
4)RTC喚醒
RTC喚醒(Real-Time Clock Wakeup)是一種可以在預(yù)定的時(shí)間點(diǎn)或間隔后喚醒控制器的喚醒方式。在汽車(chē)中,RTC喚醒通常用于控制器的定時(shí)操作,通過(guò)配置RTC喚醒功能,可以在設(shè)定的時(shí)間點(diǎn)喚醒相關(guān)控制器,以執(zhí)行特定的任務(wù)或操作。例如,BMS可以利用RTC喚醒來(lái)進(jìn)行電池狀態(tài)監(jiān)測(cè)、數(shù)據(jù)記錄等操作,以確保電池在休眠期間得到適當(dāng)?shù)墓芾砗捅Wo(hù)。
Source: 大普通信高精度高可靠性RTC,為新能源汽車(chē)BMS安全管理助力 (laoyaoba.com)
3.2 控制器相關(guān)硬件?
喚醒源作用到控制器硬件后,有可能直接喚醒微控制器,也有可能經(jīng)電源芯片間接喚醒微控制器,可以先了解下汽車(chē)控制器硬件的組成,其通常由微處理器和相關(guān)的傳感器和執(zhí)行器組成。汽車(chē)控制器實(shí)物如下圖所示,上面有很多芯片和電子元器件,它們能夠?qū)崿F(xiàn)怎么的功能呢?
簡(jiǎn)化一下大概像下圖這樣:?
控制器的功能有電源管理,傳感器信號(hào)采集,執(zhí)行器驅(qū)動(dòng)和通訊等功能,對(duì)于CAN通訊功能的硬件部分,通常由CAN總線,終端電阻,CAN收發(fā)器,CAN控制器和微控制器組成,如下示意:
在控制器上,CAN總線就不是雙絞線形式,而是CAN-H和CAN-L兩個(gè)PIN腳接入;終端電阻可能沒(méi)有而在其他控制器上,CAN收發(fā)器一定有。CAN收發(fā)器最主要作用是提供物理層的接口功能和進(jìn)行信號(hào)轉(zhuǎn)換。當(dāng)接收?qǐng)?bào)文時(shí),將輸入的差分電壓轉(zhuǎn)化成邏輯電平(顯性/隱性);當(dāng)發(fā)送報(bào)文時(shí),將邏輯電平轉(zhuǎn)換成差分電壓輸出。而涉及到網(wǎng)絡(luò)喚醒的話,那么它能夠接收、解析和處理喚醒信號(hào),實(shí)現(xiàn)對(duì)休眠節(jié)點(diǎn)的喚醒操作,通常操作是使能電源芯片給微控制器上電的作用。
在硬件層面,CAN收發(fā)器常見(jiàn)于2種形式,一種是作為一塊獨(dú)立的芯片,如下圖示意;另一種是被集成到某些芯片,比如集成到SBC中。
Source:TLE9252手冊(cè)
CAN控制器的作用是管理CAN總線上的通信活動(dòng)。它負(fù)責(zé)處理消息的發(fā)送和接收,確保消息的正確性、完整性和時(shí)序性。CAN控制器通常集成在微控制器或通信芯片中,用于與其他CAN節(jié)點(diǎn)進(jìn)行通信,通常一個(gè)微控制器中包括多個(gè)CAN控制器,如下示意的英飛凌TC系列芯片就有幾個(gè)。
由這些器件構(gòu)成的CAN通訊硬件,常見(jiàn)的一種C網(wǎng)絡(luò)喚醒方式是這樣:通過(guò)CAN收發(fā)器的喚醒引腳或中斷功能來(lái)觸發(fā)喚醒信號(hào),然后使用喚醒信號(hào)來(lái)激活電源芯片,再由電源芯片提供電源給微控制器。這種方式中,當(dāng)CAN收發(fā)器接收到特定的喚醒幀或觸發(fā)條件時(shí),會(huì)通過(guò)喚醒引腳發(fā)送喚醒信號(hào)給電源芯片,激活電源芯片以為微控制器提供電源。
結(jié)合之前的本地喚醒源和當(dāng)下的整車(chē)通訊網(wǎng)絡(luò)架構(gòu),喚醒機(jī)制通常是:本地喚醒某個(gè)控制器,然后這個(gè)控制器再通過(guò)CAN網(wǎng)絡(luò)喚醒其所在總線的相關(guān)其他控制器,這樣喚醒的這些控制器共同來(lái)實(shí)現(xiàn)某一個(gè)功能。比如鎖車(chē)休眠之后插槍交流充電工況,CP硬線信號(hào)喚醒OBC,OBC再發(fā)送網(wǎng)絡(luò)管理報(bào)文喚醒BMS等控制器,最終實(shí)現(xiàn)交流充電功能。
04
休眠喚醒表
接著從整車(chē)休眠喚醒功能層面來(lái)進(jìn)行介紹,上面的IEB例子僅是眾多休眠喚醒場(chǎng)景中的一個(gè),再多看兩個(gè)例子:
一臺(tái)純電動(dòng)汽車(chē)關(guān)門(mén)鎖車(chē)下電后進(jìn)入休眠,在它處于休眠這期間,實(shí)際上存在很多種喚醒場(chǎng)景。比如用戶有用車(chē)需求了,可能通過(guò)手機(jī)端APP提前遠(yuǎn)程開(kāi)啟空調(diào)或座椅加熱等功能,那么這時(shí)就需要喚醒汽車(chē)上的很多控制器。首先TBOX需要被喚醒,然后TBOX醒來(lái)后會(huì)喚醒上高壓相關(guān)的控制器,再喚醒空調(diào),加熱器的控制器等。? ??
Source:遠(yuǎn)程啟動(dòng)功能可以開(kāi)空調(diào)嗎?夏天遠(yuǎn)程啟動(dòng)車(chē)開(kāi)空調(diào)傷車(chē)嗎
用戶發(fā)現(xiàn)汽車(chē)電量不充足了,那么會(huì)有充電需求,插槍充電,這時(shí)如果插上慢充槍,那么OBC會(huì)先被喚醒,識(shí)別出插槍行為及其慢充槍的連接狀態(tài),然后OBC喚醒BMS和其他相關(guān)的控制器進(jìn)行充電。
Source: 【圖】熱門(mén)電動(dòng)汽車(chē)新聞_新能源汽車(chē)行業(yè)資訊_電動(dòng)邦 (diandong.com)
也就是說(shuō),通過(guò)對(duì)一個(gè)又一個(gè)整車(chē)功能和應(yīng)用場(chǎng)景的詳細(xì)分析,最終能夠匯總出整車(chē)所有的休眠喚醒場(chǎng)景需求,通常會(huì)用一個(gè)表格來(lái)管理,俗稱休眠喚醒表。休眠喚醒表一般有哪些內(nèi)容?根據(jù)上述所講的邏輯:
首先休眠喚醒需求,定義有哪些休眠場(chǎng)景或喚醒場(chǎng)景。針對(duì)每個(gè)喚醒場(chǎng)景,喚醒的條件是什么,針對(duì)每個(gè)休眠場(chǎng)景,休眠的條件又是什么。
其次是對(duì)于每個(gè)喚醒場(chǎng)景,哪些控制器需要參與?誰(shuí)是主動(dòng)喚醒節(jié)點(diǎn),誰(shuí)又是被動(dòng)喚醒節(jié)點(diǎn),每個(gè)控制器需要做什么事情。
然后呢,對(duì)于每個(gè)喚醒或休眠場(chǎng)景,有無(wú)喚醒或休眠的時(shí)間要求。如下圖示意(綠色代表主動(dòng)喚醒節(jié)點(diǎn)):
注意休眠喚醒表是網(wǎng)絡(luò)管理最核心的內(nèi)容,正是有了這樣的需求,才有采用何種網(wǎng)絡(luò)管理方法,來(lái)實(shí)現(xiàn)預(yù)期的休眠喚醒行為。
05
網(wǎng)絡(luò)管理策略
5.1 AutoSAR NM 狀態(tài)機(jī)
當(dāng)整車(chē)處于休眠狀態(tài),如果出現(xiàn)了喚醒場(chǎng)景,那么一定有來(lái)自控制器內(nèi)部的本地喚醒請(qǐng)求,然后才有喚醒網(wǎng)絡(luò)請(qǐng)求,體現(xiàn)在AutoSAR NM狀態(tài)機(jī)就是本地喚醒源使得IEB進(jìn)入總線睡眠模式(BusSleep Mode),成為主動(dòng)喚醒源,然后IEB就會(huì)從總線睡眠模式跳轉(zhuǎn)到網(wǎng)絡(luò)模式(Network Mode)的重復(fù)報(bào)文狀態(tài)(Repeat Message State)。? ??
在重復(fù)報(bào)文狀態(tài),主動(dòng)喚醒節(jié)點(diǎn)IEB會(huì)開(kāi)始以快發(fā)形式發(fā)送網(wǎng)管報(bào)文,而且會(huì)連續(xù)發(fā)送一定的數(shù)量網(wǎng)管報(bào)文,比如以20ms的發(fā)送周期連續(xù)快發(fā)5幀網(wǎng)管報(bào)文。
而被動(dòng)喚醒節(jié)點(diǎn)EPS和VCU接收到IEB的網(wǎng)管報(bào)文,同樣它們的狀態(tài)會(huì)跳轉(zhuǎn)到重復(fù)報(bào)文狀態(tài),也會(huì)周期性發(fā)送不同ID的網(wǎng)管報(bào)文,但不是快發(fā)形式,通常是500ms的發(fā)送周期,具體發(fā)多少幀取決具體需求。另外,對(duì)于被動(dòng)喚醒節(jié)點(diǎn)EPS和VCU需要連續(xù)接收到IEB幾幀網(wǎng)管報(bào)文,可能是一幀,也可能是兩幀等,取決于具體需求。
另外在這個(gè)狀態(tài),對(duì)于主動(dòng)喚醒節(jié)點(diǎn)IEB除了需要發(fā)送網(wǎng)管報(bào)文,還需要發(fā)送應(yīng)用報(bào)文,但第一幀是需要先發(fā)網(wǎng)管報(bào)文,再發(fā)應(yīng)用報(bào)文。
當(dāng)IEB處于重復(fù)報(bào)文狀態(tài)一段時(shí)間后,就會(huì)跳轉(zhuǎn)到正常運(yùn)行狀態(tài)(Normal Operation State),主動(dòng)喚醒節(jié)點(diǎn)IEB將繼續(xù)周期性發(fā)送網(wǎng)管報(bào)文,比如500ms的發(fā)送周期,以此告訴其他節(jié)點(diǎn)自己在正常通信。
而EPS和VCU可能繼續(xù)周期性發(fā)送報(bào)文,也可能會(huì)停發(fā),取決于節(jié)點(diǎn)是否需要與與總線上其他節(jié)點(diǎn)進(jìn)行信息交換。
當(dāng)節(jié)點(diǎn)需要主動(dòng)與總線上其他節(jié)點(diǎn)進(jìn)行信息交換時(shí),就通過(guò)發(fā)送網(wǎng)管報(bào)文來(lái)請(qǐng)求網(wǎng)絡(luò),并將其網(wǎng)絡(luò)狀態(tài)設(shè)置為“網(wǎng)絡(luò)請(qǐng)求”;
當(dāng)節(jié)點(diǎn)不需要主動(dòng)與總線上的其他節(jié)點(diǎn)進(jìn)行交互時(shí),就將網(wǎng)絡(luò)狀態(tài)設(shè)置為“網(wǎng)絡(luò)釋放”,節(jié)點(diǎn)在“網(wǎng)絡(luò)釋放”狀態(tài)下依然需要響應(yīng)總線上其他節(jié)點(diǎn)的網(wǎng)絡(luò)請(qǐng)求。
5.2 AutoSAR NM 網(wǎng)絡(luò)管理報(bào)文
網(wǎng)絡(luò)管理報(bào)文定義如下表:
Byte0 用于發(fā)送源節(jié)點(diǎn)ID,每一個(gè) ECU 都會(huì)被分配一個(gè)唯一的ID,來(lái)告知接收節(jié)點(diǎn)該網(wǎng)管報(bào)文是由哪個(gè)節(jié)點(diǎn)發(fā)送的。比如定義IEB的網(wǎng)管報(bào)文ID為0x410, 則節(jié)點(diǎn)ID為0x10;同樣地,EPS的網(wǎng)管報(bào)文ID為0x412, 則節(jié)點(diǎn)ID為0x12;VCU亦是如此邏輯。??
Byte1控制位向量,非常重要,這里著重介紹Bit0, 4, 6。
Bit 0 : 重復(fù)報(bào)文狀態(tài)請(qǐng)求位,用來(lái)表示有無(wú)請(qǐng)求重發(fā)報(bào)文狀態(tài),1則有,0則無(wú);
Bit 4 : 主動(dòng)喚醒位,用來(lái)表示是否為主動(dòng)喚醒網(wǎng)絡(luò),1為主動(dòng)喚醒,0為被動(dòng)喚醒;
Bit 6 : 局部網(wǎng)絡(luò)信息位,用來(lái)表示網(wǎng)管報(bào)文包含PNC信息,如果網(wǎng)絡(luò)管理有使用到PN功能,那么該位會(huì)被置為1,否則為0;
其他位暫時(shí)預(yù)留。
06
休眠喚醒表與網(wǎng)絡(luò)管理
網(wǎng)絡(luò)管理是指車(chē)輛(下電,Power off)休眠之后,喚醒需要工作的控制器一起去實(shí)現(xiàn)相應(yīng)的整車(chē)功能。說(shuō)到底就是需要結(jié)合好休眠喚醒表和網(wǎng)絡(luò)管理策略才有更完善的整車(chē)功能和行為,那他倆是如何相互結(jié)合的呢?
首先是休眠喚醒表與網(wǎng)絡(luò)管理報(bào)文相聯(lián)系,首先是網(wǎng)絡(luò)管理報(bào)文的Byte1(CBV),對(duì)應(yīng)上表中的某個(gè)場(chǎng)景滿足,綠框打勾的那個(gè)ECU就是主動(dòng)喚醒節(jié)點(diǎn),那么該ECU的網(wǎng)絡(luò)管理報(bào)文Byte1的Bit4就應(yīng)該置1;其次,與網(wǎng)絡(luò)管理報(bào)文Byte 2-7相關(guān),即User data。就結(jié)合本文IEB例子,某個(gè)喚醒場(chǎng)景需要實(shí)現(xiàn)底盤(pán)域控相關(guān)功能,需要喚醒IEB, EPS, EPB和VCU,其中IEB是主動(dòng)喚醒節(jié)點(diǎn),那么對(duì)于IEB的網(wǎng)絡(luò)管理報(bào)文的User data可以如下圖這樣的定義:
這樣通過(guò)休眠喚醒需求分析各個(gè)場(chǎng)景,最終可以提煉出每一個(gè)控制器作為主動(dòng)喚醒節(jié)點(diǎn),它需要去喚醒哪些控制器或網(wǎng)絡(luò)。因此可以確定每個(gè)控制器的網(wǎng)絡(luò)管理報(bào)文,不難理解,byte0和byte1。同時(shí)針對(duì)不同休眠或喚醒場(chǎng)景,網(wǎng)管報(bào)文的user data有所區(qū)別,如何做到場(chǎng)景與網(wǎng)管報(bào)文內(nèi)容一一映射,通常會(huì)定義另一幀報(bào)文,用來(lái)表明當(dāng)前是哪個(gè)或哪幾個(gè)請(qǐng)求條件或釋放條件滿足。另外,采取何種網(wǎng)絡(luò)管理策略其實(shí)會(huì)影響休眠喚醒表的定義,比如采用PN,那么在休眠喚醒表中,是需要定義清楚PN cluster的。對(duì)于PN,有需要的話,可關(guān)注開(kāi)心果 Need Car。
07
代碼的角度
?
?
/*************************************************************************************************** Function name : CanNm_InternalMainProcess Syntax : void CanNm_InternalMainProcess( const NetworkHandleType CanNm_NetworkHandle ) Description : This is an internal main function of CANNM which does state machine processing for all channels. Parameter : CanNm_NetworkHandle - Identification of the CANNM-channel Return value : None ***************************************************************************************************/
?
?
?
?
/*************************************************************************************************** Function name : CanNm_NetworkRequest Description : This is the AUTOSAR interface to request the network, since ECU needs to communicate on the bus. This API shall be called by Nm. Parameter : nmChannelHandle - Identification of the NM-channel Return value : E_OK - No error : E_NOT_OK - Requesting of network has failed ***************************************************************************************************/
?
?
?
?
?
/*************************************************************************************************** Function name : CanNm_NetworkRelease Description : This is the AUTOSAR interface to release the network, since ECU doesn't have to communicate on the bus. This API shall be called by Nm. Parameter : nmChannelHandle - Identification of the NM-channel Return value : E_OK - No error : E_NOT_OK - Releasing of network has failed ***************************************************************************************************/
?
?
審核編輯:黃飛
評(píng)論
查看更多