作者:Atul Kumar,ADI應用工程師 摘要 穩健的通信協議和接口在工業電機控制應用中發揮著重要作用。在工業驅動應用中,當需要多個處理器元件來持續通信以完成復雜任務時,CANopen®因其易于集成、高度可配置,以及支持高效、可靠的實時數據交換等特性,受到了眾多工程師青睞。本文從低功耗電機控制應用的角度深入探討CANopen。 控制器局域網的背景 控制器局域網(CAN)由Robert Bosch Gmbh于1983年研發,是一種高度穩健的通信協議和接口,創建之初是為了克服RS232等傳統串行通信網絡的局限性,這些網絡無法支持多個控制器之間的實時通信。汽車行業要求多個傳感器連續同步傳輸數據,因而率先采用CAN。CAN允許多個節點使用短小的消息相互通信,因此成為汽車應用的理想選擇。 隨著時間推移,CAN憑借其經過驗證的穩健性和諸多優勢,在各行各業越來越受歡迎。然而,受限于專有編碼規則,利用CAN協議將來自不同供應商的多個設備集成到單個系統中頗有挑戰性,有時甚至是天方夜譚。為了克服這一限制,自動化領域CAN (CiA)的國際用戶和制造商協會開發了一種高層協議CANopen。 本文接下來將探討CANopen協議架構及其在控制多軸電機驅動器中的應用。本文將深入探究這種高層通信協議的復雜之處及其對電機和運動控制領域的影響。為了讓讀者了解CANopen協議,我們會分析ADI Trinamic™ TMCM-6212多軸電機控制器/驅動器模塊與QSH4218-35-10-027步進電機的實時通信日志。具體來說,我們將重點關注網絡管理(NMT)狀態和基于客戶端-服務器的CANopen協議。此外,我們還將通過案例研究來展示如何解讀通信日志并確定驅動器的狀態。 CANopen架構 本節講解CANopen協議的各種應用原理,包括NMT和SDO(服務數據對象)。 網絡管理:NMT是CANopen中的關鍵通信原則,每個CANopen兼容設備都必須遵守。它作為狀態機運行,在協調CANopen框架內的應用方面發揮著重要作用。 網絡管理狀態機架構:NMT狀態機如圖1所示,由三個不同的狀態組成,詳情如下: ► 初始化狀態 ► 預運行狀態 ► 運行狀態 圖1.NMT狀態機 客戶端節點承擔著監督不同運行狀態下,相關服務器節點通信狀態的關鍵角色。這是通過實施NMT機制來實現的?赏ㄟ^心跳和節點守護兩種不同方法,使客戶端節點能夠評估服務器節點的通信完整性。TMCM-6212采用心跳技術來驗證通信是否正確。每個節點利用對象1017h,以用戶可配置的循環時間間隔(以毫秒為單位)發出心跳信號。這種方式確保所有節點都處于活動狀態,可以進行通信。 表1.NMT通信中的狀態配置
表1列出了不同通信狀態下使用的所有通信對象的組合。設備上電或復位后進入初始化狀態時,會產生啟動消息。然后,設備轉換到預運行狀態,準備好執行期望的操作。在預運行狀態下,網絡中的所有節點可以傳輸與SDO、心跳/節點守護、緊急情況和時間/同步相關的所有對象。在運行狀態下,除了預運行狀態下可用的所有對象之外,還可以映射PDO對象。最后,在停止狀態下,設備會禁用所有SDO和PDO對象的通信,僅允許執行NMT命令。 服務數據對象:SDO通信協議主要用于NMT狀態機的預運行狀態。它以客戶端-服務器配置運行,其中客戶端可以訪問所有連接的服務器(節點)的對象字典中可用的所有對象。在該協議中,客戶端總是發起服務器的讀/寫事務,并由服務器確認任務完成。此過程可確保SDO中的每個事務都得到確認。 圖2顯示了多節點網絡中SDO協議的基于客戶端-服務器的配置。每個節點都被分配一個通道,通過該通道可以與客戶端進行通信。在這種情況下,Trinamic TMCM-6212六步進電機驅動器/控制器充當服務器,而連接的PC充當客戶端,發起與特定節點(本例中為NODE-1)的讀/寫事務。雖然所有節點都會收到SDO客戶端消息,但只有目標節點會響應,而其他服務器會忽略客戶端請求。 圖2.多節點SDO配置 服務數據對象數據報 圖2顯示了SDO數據報的完整結構。SDO報頭由COB-ID(連接對象ID)組成,該ID是分配給特定任務(例如讀寫功能)的唯一編號。因此,SDO通信需要兩個COB-ID。第一個COB-ID代表客戶端上載/下載請求的NODE-ID+功能代碼,即600h + NODE-ID。第二個COB-ID(580h + NODE-ID)用于服務器的響應。 圖3.SDO數據報結構 SDO消息中的第一個字節為說明符,對于確定消息的性質至關重要,可表明客戶端是打算寫入(下載)還是讀。ㄉ蟼鳎⿺祿疫通過中止消息表示事務中的任何錯誤。說明符字節分為8位,如圖3所示。位7-5為客戶端命令說明符(CCS),提供有關消息性質的關鍵信息?蛻舳嗣钫f明符根據客戶端的操作(例如讀取、寫入、分段/快速傳輸或事務中的錯誤)而有不同的配置。在服務器的響應中,說明符(SCS,服務器命令說明符)的三位用于確定事務是否成功。表2列出了不同操作中CCS和SCS位的各種組合。說明符數據報中的位4是超過四字節的數據傳輸中使用的切換位。位3-2不包含任何數據,并且僅當設置了位0-1時才有效。位1決定通過SDO通道傳輸的消息類型,指示它是分段傳輸還是快速傳輸。在SDO數據報中,如圖3所示,最后四個字節專門用于存放需要傳輸的數據。如果數據超過四個字節,則會以分段方式發送。另一方面,如果SDO數據報包含完整數據,則其被視為快速傳輸。因此,位1為高電平表示快速傳輸,位1為低電平表示分段傳輸。在分段傳輸中,數據以數據包的形式傳輸。為了響應客戶端的初始讀/寫請求,服務器在數據字段中提供數據大小。然后,隨著每個數據包傳輸到客戶端,第四位(切換位)開始切換。最后,如果說明符數據報中的位0已設置,則位3-2會指示數據大小,如前所述。 表2.CCS和SCS配置
SDO數據報中的字節2-3和4分別對應索引和子索引字節,如圖3所示。這些字節用于訪問設備對象字典中可用的所有對象。對象字典包含所有設備參數,用戶可根據實時應用需求配置設備的功能。通過設備剖析,無論是像驅動器這樣的控制設備,還是簡單的I/O器件,我們都可以實現行為標準化。如前所述,SDO數據報中的最后四個字節專門用于存放需要通過SDO層傳輸的數據。 一旦發生錯誤,SDO傳輸就會中止,傳輸停止的原因可以參考目標設備手冊中提供的錯誤代碼解釋來確定。在這種情況下,CCS位的值為4,索引和子索引指定傳輸期間設備中受影響的參數,最后四個字節表示錯誤代碼。 實時通信分析 本節使用機器處于預運行狀態下的實時通信日志窗口來解釋SDO數據報。ADI Trinamic TMCM-6212六軸步進電機驅動器/控制器4與QSH4218-35-10-027 [5]步進電機配合使用。對于此設置,電機的最大電流(對象2003h)設置為200。利用目標設置的軟件界面日志窗口中突出顯示的消息,客戶端和服務器之間的上傳和下載事務得到進一步解釋,如圖4所示。 圖4.CANopen IDE 情形1:客戶端與服務器之間的下載操作 由客戶端發起:0x601:2f 03 20 c8 00 00 00(圖5)。 圖5.客戶端發起下載請求 服務器響應:0x581:60 03 20 00 00 00 00(圖6)。 圖6.服務器的下載響應 在圖6所示的操作中,CCS和SCS位的組合顯示了客戶端的成功寫入操作和服務器的響應,這在表2中也有體現。 情形2:客戶端與服務器之間的上傳操作 由客戶端發起:0x601:40 03 20 00 00 00 00(圖7)。 圖7.客戶端發起上傳請求 服務器響應:0x581:4f 03 20 00 c8 00 00 00(圖8) 圖8.服務器的上傳響應 結論 CCS和SCS位的組合指示在客戶端和服務器之間成功執行上傳操作。本文提到的示例可以推廣到設備對象字典中的其他對象,幫助我們深入了解機器的狀態。本次演示的主要目的是幫助用戶解讀通信日志并監視驅動器的狀態。用戶可以實時排除錯誤,更高效地探索ADI Trinamic CANopen的高級特性。ADI產品中集成CANopen協議為客戶帶來了靈活性。客戶可以將自己的PLC與ADI Trinamic模塊集成,從而實現多供應商系統的開發。此界面對于從事實驗室自動化、機器人、液體處理、半導體處理等復雜應用領域的客戶特別有價值。本CANopen系列的下一篇文章將深入分析過程數據對象(PDO) CANopen協議,同時探索TMCM-6212針對電機控制應用的更高級特性。 參考文獻 1 Olaf Pfeiffer、Andrew Ayre和Christian Keydel,“采用CAN和CANopen的嵌入式網絡”,Copperhill Technologies Corporation,2008年。 2 “TMCM-6212 CANopen固件手冊”,Trinamic Motion Control,2018年。 關于作者 Atul Kumar是愛爾蘭都柏林中央應用中心的應用工程師,主要專業領域是電機控制、低功耗步進電機的閉環控制架構以及BLDC/PMSM電機。他在都柏林城市大學攻讀了研究生課程,并于2022年2月加入Maxim Integrated(現為ADI公司的一部分),擔任助理應用工程師。 |