SylixOS ICAN 協議移植筆記

  1. ICAN協議簡介

  2. ICAN簡介。

    ICAN協議( Industrial CAN protocol )爲基於現場總線 CAN-bus的應用層協議。ICAN協議爲工業控制應用領域提供了一種簡單可靠,易於開發的總線系統。網絡

    在市場中,DeviceNet 和CANopen使用的較多,可是它們的協議規範比較複雜,理解和開發的難度比較大,對於一些並不複雜的基於CAN總線的控制網絡不太適合。所以有必要開發設計一種簡單可靠的CAN高層協議,以適合於    CAN的簡單應用,ICAN協議所以而生。spa

    ICAN協議屬於面向節點的協議。在ICAN協議中,經過特定的功能碼來創建或者刪除數據鏈接。而且在報文的標識符中指定了源節點地址和目標節點地址,所以信息連接創建之後,數據通信的雙方就已經肯定,而且能夠在該鏈接的基礎上進行數據通訊。操作系統

  3. ICAN報文簡介

  4. ICAN協議的標識符分配

    ICAN協議通訊的全部報文都依賴於CAN 2.0B協議。也就是ID幀爲29bit,在CAN2.0B協議中這29bit只當節點的ID使用,ICAN則充分利用了這29bit。在ID中加入了不少控制信息。如圖 21所示主要分爲SrcMACID(源節點編號)佔擴展幀ID的21 – 28位,DestMACID(目標節點編號)佔擴展幀ID的13 – 20位,ACK(應答位)單獨佔擴展幀ID的12位,設計

    FUNC ID(功能碼)佔擴展幀ID的8 – 11位,和Source ID(資源節點編號)佔擴展幀ID的0 – 7位。資源

                                                                      

    圖 21 ICAN協議對 CAN報文ID段的分配開發

  5. ICAN協議的報文數據分配

    CAN報文爲短幀報文,最多能夠傳送8個字節數據。在ICAN協議中報文的數據部分主要用於傳送功能碼相關的參數,以及特定的功能數據。對於報文數據部分的分配相對比較簡單,主要考慮如下方面:文檔

    在實際應用中須要傳送大於8個字節的數據,所以對報文數據部分的分配須要增長分段傳送的機制。同時在報文數據定義時,充分利用報文數據的8字節長度,合理分配特殊的功能碼和有效數據,儘量在每幀報文中攜帶儘量多的有效數據。it

    如圖 22所示:在ICAN協議報文數據分配中,報文數據的第一個字節用做特定的報文分段傳送標識。報文數據剩餘的7個字節都可擁有傳送有效的數據(功能碼相關的參數)。在ICAN協議中每幀可以傳輸的有效數據達到7個字節。基礎

     

    圖 22 ICAN報文數據分配百度

     

    關於ICAN協議主要是CAN2.0B協議中的ID 段和數據段。因爲ICAN協議中具體每段如何使用所佔篇幅過多,文本再次不作過多介紹。(注:詳情請見《ICAN應用層協議V1.0》百度可查)。

  6. SylixOS移植ICAN

    在網上查找相關ICAN資料,發現ICAN協議只是在中國一些特定的場合使用,並且大多用於STM32這種主頻較低,且沒有移植操做系統的單片機上。本人蔘考了STM32系列單片機有關ICAN協議部分的移植,與其說是移植不如說是本人蔘照ICAN協議,在應用APP中,本身實現了對ICAN的報文的封裝和解析。有些功能和機制還未徹底實現,若是發現實現有不穩當的地方,請及時和做者聯繫進行更正。

    本文移植的ICAN協議,是在底層CAN控制器已經調通能正常收發報文的前提下進行的。在APP中已經封裝好了一幀CAN報文,(注:詳細應用APP的操做在以前的文章中已經有詳細的介紹。在此就不作過多介紹,本次移植基於本公司IMAX6Q試驗箱平臺。)在硬件電路上,把試驗箱上CAN0和CAN1兩個CAN控制器輸出端的CAN_H相連,CAN_L相連。打開CAN0設備進入讀取模式,打開CAN1進入發送模式,(發送的報文在應用程序中已經封裝完畢。)CAN1設備向外發送CAN報文。CAN0設備收到CAN報文後根據ICAN協議進行報文解析而且打印出解析後的相關數據。

     

  7. 免責聲明

    內部交流文檔,若發現相關錯誤或者建議,請及時聯繫文檔建立者進行修訂和更新。

相關文章
相關標籤/搜索