ISO 15765-2
ISO 15765-2[1]也稱為ISO-TP( TP表示傳輸層,Transport Layer),是在控制器區域網路(CAN)上傳輸網路封包的國際標準。傳統CAN訊息,每一帧的資料最多只有八個位元組,透過ISO-TP可以傳輸超過八個位元組的資料。ISO-TP會將長資料封包拆成許多的資料帧,其中再加入一些編碼資料,方便傳送端及接收端解讀各資料帧,並且讓接收端可以將許多的資料帧還原成原始訊息。ISO-TP的一個資料封包的最大酬載為4095位元組。 在OSI模型中,ISO-TP對應第三層(網路層)及第四層(傳輸層)。ISO-TP最常見的應用是針對有OBD-2設備的車輛,用KWP2000或统一诊断服务(UDS)傳輸診斷訊息,不過ISO-TP也可以用在其他特定的CAN通訊協定中。 ISO-TP有二種運作的模式,有一種是不加額外的位址位元組,只利用CAN ID來定址,稱為正常定址(normal addressing),另一種是會加上一個定位用的位元組,稱為延伸定址(extended addressing)。延伸定址會用CAN資料的第一個位元來作為定址用,資料帧的酬載量會因此再減少一個位元組。為了簡單起見,以下的說明都是以正常定址下進行的。ISO 15765-2通訊協定允許六種定址方式。 ISO-TP會使用八個位元組的CAN資料帧中的一個或多個位元組來存放元資料,因此酬載量最多只有七個位元組。元資料稱為協定控制資訊(Protocol Control Information),簡稱PCI。PCI可能是1-3個位元組。最前面的第四位元說明帧的型態,也間接的說明PCI的長度。 ISO 15765-2是ISO 15765(道路車輛,在CAN網路上的診斷通訊)的一部份,其中分為四個部份:
PCI幀種類列表ISO-TP定義了四種不同的幀:
單一幀可以傳送小於等於七個位元組以下的訊息,其第一Nibble(4 Bits)為0,酬載長度為1至7位元組。種類欄位的數值為0,是比較簡單的資料格式,開頭位元組是長度,不過若沒有特別說明,很容易造成誤解。 若訊息超過七個位元組,可以用多重幀傳送。首幀(FF)的PCI欄位有二個位元組,前4個位元是種類編碼(1),之後的12個位元是訊息長度(不包括種類及長度位元)。接收端會確認此一傳送,用流量控制幀(FC)回應。流量控制幀的PCI欄位有三個位元組,標示各幀之間的時間間隔,以及連續幀傳送的方式(區塊大小)。
第一個Byte(8 Bits)的前四個Bit會包括種類編號(type = 3),後四個Bit會說明是否允許傳送(0 = 繼續傳送、1 = 等待、2 = 超載/結束)。下一個位元組是區塊大小(block size),在下一個流量控制幀之前可以傳送的幀數量,若為0,表示剩下的幀都可以在沒有流量控制的條件下傳送。第三個位元組是間隔時間(Separation Time、ST),二個幀之間的最小延遲時間。若數量小於127 (0x7F),表示以ms為單位的間隔時間,若數值在241 (0xF1) 至 249 (0xF9) 之間,表示間隔時間從 100 到 900 ms。間隔時間的定義是從前一個幀的結束到下一個幀的開始。在實作時,需要有嚴謹的實作,接受傳送端可能將間隔時間定義為前一個幀的開始到下一個幀的開始的可能性(即幀傳送率)。就算是很仔細的實現,也可能是因為位元填充機制增加位元數量而失效。 傳送端之後會用連續幀來傳送後續的資料。每一個連續幀都有一個位元組的PCI,前四個位元對應type = 2,後面四個位元是索引號。索引號從1開始,每一個連續幀會加1(1, 2,..., 15, 0, 1,...),因此可以檢測到遺漏的幀。 第一筆資料會在首幀的後面送出,因此第一個連續幀的索引號會是1,依序往下遞增,一直到15為止,再從0開始計數。 長度欄位12位元,因此封包的資料最多可以到4095位元組。不過在實務上,典型應用的最大長度會因接收緩衝區或是硬體的限制而比較短。 標準
參考資料
|