基於CANoen協議實現DSP系統與上位機CAN的通訊

轉 基於CANoen協議實現DSP系統與上位機CAN的通訊

電子設計•來源:郭婷•作者:電子設計 • 2019-07-10 08:08 • 1103次閱讀

 1、引言

  CANopen是一個開放的、標準化的應用層協議,在各種控制系統中得到了廣泛的應用。依靠CANopen協議的支持,可以對不同CAN廠商的設備通過總線進行實時通訊。

 

  本文針對自主研發的全數字電機伺服驅動系統,使用CANopen通訊協議實現了CAN總線數字信號處理器(DSP)系統與上位機CAN卡之間的通訊,並通過測試實驗驗證了信息傳遞的可靠性,保證了全數字網絡化伺服驅動系統中對電機控制的快速性、準確性和實時性。

  2 、通訊系統實現的基本原理

  2.1 LF240x系列DSP的CAN控制器模塊

  LF240x系列DSP的CAN控制器模塊,是一個完全的CAN控制器。具有以下特性[6]:

  (1)完全支持CAN2.0B協議;

  (2)對象有6個郵箱,用於接收和發送信息,其數據長度爲0~8個字節;

  (3)可編程的中斷配置,位定時器及CAN總線喚醒功能;

  (4)當發送出現錯誤或仲裁丟失數據時,CAN控制器有自動重發功能;

  (5)總線錯誤自診斷功能;

  (6)支持自測試模式。

  2.2 CANopen協議

  CANopen協議以CAN芯片爲硬件基礎,有效利用CAN芯片所提供的簡單通信功能區實現工業控制網絡的複雜應用層協議要求。應用中應該注意以下幾個方面的內容:

  2.2.1 對象字典OD(Object Dictionary)

  OD是CANopen協議的核心概念[1],它是一個有序的對象組,每個對象用一個16位的索引值和一個8位的子索引尋址。CANopen網絡中的每個節點都有一個OD,包含了描述這個設備和它的網絡行爲的所有參數。

  2.2.2 CANopen 標識符

  CANopen定義了強制性的缺省標識符(COB-ID)分配表。它是基於11位的CAN-ID,包括4位功能段(Function Code)和7位地址段(Node-ID),如圖1所示。文獻[1]中給出了CANopen預定義主/從連接集CAN標識符分配情況。

基於CANoen協議實現DSP系統與上位機CAN的通訊

  2.2.3 CANopen通訊機制

  CANopen通訊模型定義了四種報文(通訊對象)[1]:

  1) 管理報文NMT(Network Management)

  用於網絡中主節點對從節點監控和管理。此消息不需要應答。NMT消息格式如表1所示。

基於CANoen協議實現DSP系統與上位機CAN的通訊

  2)服務數據對象SDO(Service Data Object)

  SDO通過使用索引和子索引來訪問一個設備的OD。協議屬於確認服務類型。根據傳送數據的長度不同,有兩種傳送機制:加速傳送(最多4字節)和分段傳送(大於4字節)。發送和應答報文總是包含8字節信息,基本結構如表2所示:

基於CANoen協議實現DSP系統與上位機CAN的通訊

  3) 過程數據對象PDO(Process Data Object)

  用於傳輸正常網絡操作中的實時數據。每個PDO在OD中用2個對象描述:PDO通訊參數和PDO映射參數。在此舉例說明PDO的使用方法。假設第二個發送PDO映射如表3所示,如果這個報文被髮送,則由3字節組成,報文結構如表4所示。

基於CANoen協議實現DSP系統與上位機CAN的通訊

  4) 預定義報文或特殊功能報文

  定義了三個用於同步,應急指示和時間標記的特定對象。用於配合以上三種通訊機制。

  3、系統通訊的軟、硬件設計

  3.1 CAN總線硬件設計

  由於TMS320LF2407A芯片內自帶了CAN總線控制器模塊,使得CAN總線的電路設計變得非常簡單。將TMS320LF2407A的CANTX、CANRX引腳和CAN收發器PCA82C250的TXD、RXD引腳相連即可。CAN總線之間需要使用一個合適的終端電阻連接。爲了進一步提高系統的抗干擾能力,可以在控制器和傳輸介質之間加接光電隔離器件6N137。電路原理圖如圖2所示。

基於CANoen協議實現DSP系統與上位機CAN的通訊

  3.2 CANopen協議對象字典OD的建立

  本伺服驅動器通訊支持CANopen通訊子協議(DS301)和驅動設備子協議及運動控制命令(DSP-402)。在開發的過程中,根據應用的具體要求,將數字輸入/輸入模塊、電機及驅動設備、控制器、編碼器等設備類型及其相應的功能在設備描述的協議中進行了描述。建立的OD分爲三個部分:

  1) 通訊協議對象(Index 0x1000-0x1AFF)

  定義設備類型,錯誤寄存器,廠商指定狀態寄存器,COB-ID同步信息,通訊循環週期,同步CAN信息窗口,以及設備名,軟硬件版本號等。另外SDO的通訊參數以及PDO的通訊和映射參數也在該部分定義。本設計中採用固定PDO映射,不允許動態映射。

  2) 標準設備子協議對象(Index 0x6000-0x65FF)

  定義三類信息:第一類是電機及驅動器的相關設備參數,如類型,廠商信息,分類號等;第二類是命令字和狀態字;第三類是位置、速度的相關參數。

  3) 廠商指定協議對象(0x2000-0x20FF)

  根據廠商需求,靈活定義所使用的變量。 此部分的使用使CANopen協議既保證了設備的通用性,又保證了系統良好的擴展性。

  3.3 通訊程序的設計及實現

  針對帶CAN控制器的TMS320LF2407A和PC機CAN卡之間的通訊進行了軟件設計。

  TMS320LF2407A的CAN控制器的郵箱2配置爲接收方式,郵箱3配置爲發送方式。都採用標準信息幀格式(11Bit ID)。其中發送信息採用查詢方式,接收信息採用中斷方式,郵箱2用低中斷優先級。信息傳輸波特率設置爲500Kbps。

  採用CANopen協議對設備進行控制的過程可以理解爲用SDO對數據字典的讀寫過程。檢測設備對象的狀態或查詢設備當前信息時,可用SDO讀取數據字典中的對象;要對設備發佈控制命令可利用SDO向相應的數據字典對象寫入數據。接收到信息幀時首先要將其命令字節(byte0)讀出,以確定下一步的讀寫命令處理。

  信息幀的接收和發送均採用緩衝區的方式。讀操作時,發送信息幀長度爲4字節,應答信息幀約定爲8字節;寫操作時,發送信息幀長度約定爲8字節,應答信息幀爲4字節。

  採用不同的發送郵箱發送數據長度不同的信息幀。本程序設計中,採用郵箱4發送4字節長度的信息幀,採用郵箱5發送8字節長度的信息幀。這種方式可以提高信息傳輸的效率。軟件設計流程圖如圖3所示。

基於CANoen協議實現DSP系統與上位機CAN的通訊

  4 、測試結果

  爲了測試CAN總線DSP系統與PC機CAN卡之間的通訊情況,採用VC++編寫了友好的人機界面(見圖4)。進行通訊測試時,首先要選擇通訊端口,設置通訊波特率,ID屏蔽位,信息幀格式及傳輸數據的格式(十進制或十六進制)。特別需要注意PC端設置的通訊波特率要和DSP端的通訊波特率保持一致。然後打開CAN總線端口,選定發送SDO的功能段及地址段,填寫信息幀長度(以字節爲單位)及內容,即可進行通訊測試。

基於CANoen協議實現DSP系統與上位機CAN的通訊

  例如,要將1號地址的電機輪速期望值設爲0x3E8,電機輪速期望值在OD中的索引爲0x606B,使用啓動域下載協議,加速傳輸。則設置地址段爲1,信息幀長度爲8,信息幀內容爲2B 6B 60 00 E8 03 00 00。發送成功後返回應答信息幀內容爲:ID=581,LENTH=4,DATA=60 6B 60 0 0 0 0 0,說明寫入操作正確(見圖4)。

  要將1號地址的電機輪速期望值讀出,即讀出OD中的對象0x606B,使用啓動域上傳協議,服務器使用加速傳輸方式應答。則設置地址段爲1,信息幀長度爲4,信息幀內容爲40 6B 60 00 00 00 00 00,發送成功後返回應答信息幀內容爲:ID=581,LENTH=8,DATA=4B 6B 60 0 E8 03 0 0,說明讀取操作正確(見圖4)。

  5 、結束語

  本文用CANoen協議實現了CAN總線DSP系統與上位機CAN的通訊,實現了控制系統的數字化、模塊化,並保持了系統的可擴展性,爲提高伺服驅動系統的智能化水平奠定了堅實的基礎。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章