我們清楚Autosar網(wǎng)絡管理,也知道收到網(wǎng)絡管理報文會喚醒網(wǎng)絡,但是網(wǎng)絡管理如果上PN功能的話,就只能是指定的網(wǎng)絡管理報文才可以喚醒網(wǎng)絡。這個指定網(wǎng)絡管理報文是如何過濾的呢?來,我們看看Autosar怎么做的。
1、縮寫詞
Acronym/abbreviation | Description |
CBV |
Control Bit Vector |
PN |
Partial Network |
PNC | Partial Network Cluster |
PNI | Partial Network Information |
PNC解釋
為便于理解,以最常見的Can總線為例,其它總線同理。比如在某個Can網(wǎng)段內(nèi),有3個ECU,其中ECU1包含3路Can,即Node1、Node2、Node3,ECU2包含兩路Can,即Node4、Node5,ECU3包含1路Can,即Node6。如下所示:
假設(shè),我們示例中的Can網(wǎng)段設(shè)計了5個PNC,分別定義PNC ID為:0x01、0x02、0x03、0x04、0x05。一個Node可以加入一個PNC,也可以加入多個PNC。這里的PNC類似Ethernet的多播組概念。舉個例子:我的微信里有100個好友,但是我要將一些事情告訴某些好友,而不是全部好友。于是,我將好友1、2、3拉了一個小群,設(shè)置標簽PNC1;我又拉了好友1、2、5、6組建了另一個小群,設(shè)置標簽PNC2。我發(fā)朋友圈的時候,選擇PNC1標簽的好友可見我的消息,即使我的所有朋友都會看朋友圈,但是只有我的好友1、2、3可以看到我的消息(即喚醒Node1、Node2、Node3)。
假設(shè)需求如下所示:
PNC1:Node1、Node5、Node6
PNC2:Node2、Node4、Node6
PNC3:Node2、Node6
PNC4:Node1、Node2、Node3、Node4、Node5
PNC5:Node2、Node5
需求可以進行如下分配:
PNC1 (0x01) |
PNC2 (0x02) |
PNC3 (0x03) |
PNC4 (0x04) |
PNC5 (0x05) |
|
Node1 |
1 |
0 |
0 |
1 |
0 |
Node2 |
0 |
1 |
1 |
1 |
1 |
Node3 |
0 |
0 |
0 |
1 |
0 |
Node4 |
0 |
1 |
0 |
1 |
0 |
Node5 |
1 |
0 |
0 |
1 | 1 |
Node6 |
1 |
1 |
1 |
0 |
0 |
注釋:
1 表示使能Node,0 表示不使能Node。
2、NM PDUFormat
一般來說,CAN網(wǎng)絡管理報文的PDU格式如下所示:
Byte0:節(jié)點ID,比如Node ID為0x509(假設(shè)網(wǎng)絡管理報文:0x500~0x5FF),工具配置時,此字節(jié)設(shè)置0x09即可。因為0x05是網(wǎng)段標識,底層收到0x05xx的報文即可知道是網(wǎng)絡管理報文,之后根據(jù)偏移值(本例:0x09)即可知道是哪個Node。
Byte1:控制位向量。
Byte2~Byte7:用戶數(shù)據(jù)
這里只討論和PN功能相關(guān)的Bit6。
Bit6 = 1,表示有PN請求,如果有PN請求,則后面要判斷收到的網(wǎng)絡管理報文的PNC,判斷該節(jié)點是否在此PNC內(nèi);
Bit6 = 0,表示沒有PN請求,一般收到網(wǎng)絡管理報文就直接喚醒網(wǎng)絡。
3、NMPDU過濾算法
前面的討論為本小節(jié)做了鋪墊,那我們就好奇一個問題了:如果節(jié)點有PN功能,如果判斷收到的網(wǎng)絡管理報文可以喚醒當前節(jié)點的網(wǎng)絡?
這里就涉及到了PDU的過濾算法問題。
示例
CanNmPnInfoOffset =4,PnInfo在PDU中偏移的距離
CanNmPnInfoLength = 2,Pn Info在PDU中的長度
Byte0 |
Byte1 | Byte2 | Byte3 | Byte4 | Byte5 | Byte6 | Byte7 |
NID |
CBV |
User Data |
PN Info |
User Data |
|||
0x09 |
0x40 |
0xFF |
0xFF |
0x12 |
0x8E |
0xFF |
0xFF |
如何識別出網(wǎng)絡管理報文可以喚醒該節(jié)點呢?Autosar中使用了屏蔽掩碼過濾的方式,如上例,Pn Info的長度為2byte,對應設(shè)置2個Mask,比如:
CanNmPnFilterMaskByteIndex= 0,設(shè)置CanNmPnFilterMaskByteValue = 0x01;
CanNmPnFilterMaskByteIndex= 1,設(shè)置CanNmPnFilterMaskByteValue = 0x97。
之后對每個Pn Info采用位與運算,運算結(jié)果如下所示:
Filter Mask Value(Byte) |
Compared to received PNinfo |
Resulting |
0x01(byte0) |
0x12(NM PDU Byte4) |
0x00 (no relevant PN information) |
0x97(byte1) |
0x8E(NM PDU Byte5) | 0x86(relevant PN information) |
其中,有一個字節(jié)與結(jié)果不為0,表示該報文可以喚醒當前節(jié)點。如果兩個字節(jié)的比較均為0x00,則當前節(jié)點網(wǎng)絡不被喚醒,忽略該網(wǎng)絡管理報文。
提示:
有些transceiver有PNC過濾功能,也可以在硬件上設(shè)置此過濾功能。針對NXP TJA1145 Transceiver而言,只能過濾通信速率在1Mbps的報文,因此要注意項目中的網(wǎng)絡管理報文速率,如果使用的是CANFD,且速率是500Kbps/2Mbps,則NXP TJA1145 Transceiver硬件過濾功能可能就不能使用。也許在不久的將來,硬件變速率過濾功能也將成為現(xiàn)實。
審核編輯:劉清
-
CAN總線
+關(guān)注
關(guān)注
145文章
1987瀏覽量
132886 -
網(wǎng)絡管理
+關(guān)注
關(guān)注
0文章
125瀏覽量
28215 -
AUTOSAR
+關(guān)注
關(guān)注
10文章
380瀏覽量
22684
發(fā)布評論請先 登錄
TSMaster 中不同總線報文消息過濾的操作方式

AUTOSAR CAN網(wǎng)絡管理
網(wǎng)絡管理NMT與特殊協(xié)議報文
AUTOSAR CAN網(wǎng)絡管理狀態(tài)機介紹
AUTOSAR信息安全框架和關(guān)鍵技術(shù)相關(guān)資料介紹
AUTOSAR_SWS_CAN網(wǎng)絡管理規(guī)范標準4.3.1
CAN網(wǎng)絡管理規(guī)范 AUTOSAR CP中文版
CAN網(wǎng)絡管理規(guī)范 AUTOSAR CP英文版
AUTOSAR CAN網(wǎng)絡管理協(xié)議
網(wǎng)絡管理報文的收/發(fā)與網(wǎng)絡管理時間配置參數(shù)解析

OSEK與AUTOSAR標準分別是怎么實現(xiàn)網(wǎng)絡管理功能的
AUTOSAR CAN網(wǎng)絡管理報文的數(shù)據(jù)場格式
科普系列:AUTOSAR與OSEK網(wǎng)絡管理比較(下)

詳解CAN總線的AUTOSAR網(wǎng)絡管理報文

一文解析AUTOSAR CAN網(wǎng)絡管理

評論