0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于Zynq UltraScale+MPSoC高性能EtherCAT主站方案

jf_pJlTbmA9 ? 來源:f_pJlTbmA9 ? 作者:f_pJlTbmA9 ? 2023-07-07 14:15 ? 次閱讀

1. 技術(shù)背景

EtherCAT 是開放的實時以太網(wǎng)通訊協(xié)議,由德國倍福自動化有限公司研發(fā)。EtherCAT 具有高性能、低成本、容易使用等特點,目前在技業(yè)領(lǐng)域有著廣泛的應(yīng)用。

ZCU102 評估套件可幫助設(shè)計人員快速啟動面向汽車、工業(yè)視頻以及通信應(yīng)用的設(shè)計。該套件具有基于 Xilinx 16nm FinFET+ 可編程邏輯架構(gòu)的 Zynq? UltraScale+? MPSoC 器件,提供一款四核 ARM? Cortex?-A53、雙核 Cortex-R5F 實時處理器以及一款 Mali?-400 MP2 圖像處理單元。ZCU102 支持所有可實現(xiàn)各種應(yīng)用開發(fā)的主要外設(shè)及接口。

KPA EtherCAT 主站是一套質(zhì)量穩(wěn)定、知名度和性價比較高的 EtherCAT 協(xié)議棧,有較大參考價值。本文將介紹KPA EtherCAT 主站在ZCU102平臺的移植與測試。

2 EtherCAT簡介

EtherCAT(以太網(wǎng)控制自動化技技)是一種用于確定性以太網(wǎng)的高性能工業(yè)通信協(xié)議,它擴展了 IEEE 802.3 以太網(wǎng)標準,使得數(shù)據(jù)傳輸中具有可預測性定時及高精度同步等特點。這個開放性標 準作為 IEC 61158 的組成部分,常用于機械設(shè)計及運動控制等應(yīng)用中。EtherCAT 采用標準的 IEEE802-3 以太網(wǎng)幀,幀結(jié)構(gòu)如圖 1。EtherCAT 協(xié)議直接用標準以太網(wǎng)的幀格式傳輸數(shù)據(jù),并不修改其基本結(jié)構(gòu)。

1677203057100484.png

EtherCAT 實現(xiàn)了 CANopen 協(xié)議,在 CANopen 中周期性的數(shù)據(jù)通過 PDO(過程數(shù)據(jù)對象)來傳輸,PDO 優(yōu)先級較高,可用于實時傳輸。非周期性的數(shù)據(jù)比如配置參數(shù)和對象字典等則通過 SDO(服務(wù)數(shù)據(jù)對象)來傳輸。

每個 PDO 都包含單個或多個從設(shè)備的地址,這種數(shù)據(jù)加地址的結(jié)構(gòu)(附帶用于校驗的傳輸計數(shù)位)組成了 EtherCAT 的報文。每個 Ethernet 幀可能包含數(shù)個報文,而一個周期中可能需要多幀來傳送所需的所有報文。

傳統(tǒng)的以太網(wǎng)通信解決方案從站先接受以太網(wǎng)數(shù)據(jù)包,然后解釋和復制過程數(shù)據(jù),最后轉(zhuǎn)發(fā)數(shù)據(jù)。而EtherCAT 以太網(wǎng)幀在特殊的硬件模塊的幫助下可以實現(xiàn)在傳輸?shù)耐瑫r被處理。每個從節(jié)點都有 FMMU(現(xiàn)場總線存儲管理單元),F(xiàn)MMU 會對經(jīng)過的數(shù)據(jù)包進行地址分析,發(fā)現(xiàn)是本節(jié)點的 數(shù)據(jù)就會讀取,同時報文轉(zhuǎn)發(fā)給下一個設(shè)備。同樣在報文通過的時候也可以插入需要傳輸?shù)臄?shù)據(jù)。讀取/插入/轉(zhuǎn)發(fā)數(shù)據(jù)的整個過程,報文只有幾納秒的延遲。如圖 2 所示,設(shè)想以太網(wǎng)的幀就像行駛中的火車,EtherCAT 報文是每節(jié)火車車廂,PDO 數(shù)據(jù)的比特就是車廂內(nèi)的乘客,這些數(shù)據(jù)可以被提取并插入到合適的從設(shè)備中。整輛火車不停止地穿越所有從設(shè)備,在末端從設(shè)備處又掉頭,重新反向穿越所有從設(shè)備。(注:EtherCAT不僅支持主從通訊,也支持從從通訊即S2S)

1677203073808936.png

2.1 KPA EtherCAT主站軟件介紹

KPA EtherCAT主站軟件根據(jù)功能不同,提供了Basic,Standard,Premium以及Extension四個版本主站協(xié)議棧,因此除了支持ETG1500定義了Class A和Class B兩種主站類型外,KPA還支持一些拓展功能比如:Data- and Frame-Logger(記錄數(shù)據(jù)和報文)、Access Rights(設(shè)置不同的訪問權(quán)限)Multi Master(多主站,冗余)、Cable Redundancy (線纜冗余)、Hot-Connect(熱插拔)、其他。

提供了基于多種不同硬件平臺和OS的現(xiàn)成開發(fā)包,支持SoC(ARM+FPGA)/ARM/X86 /PowerPC等主流硬件平臺,支持Linux(Xenomai/RT-preempt)/ Windows(INtime/RTX)/ QNX/ Ucos/ Vxworks等。幾乎滿足目前所有用戶主站開發(fā)要求的一款主站方案。

KPA主站協(xié)議棧采用模塊化的架構(gòu),可以實現(xiàn)每個特殊的項目應(yīng)用。它使得主站可以自由擴展以適應(yīng)不同大小的應(yīng)用程序、可以移植不同的操作系統(tǒng)和各種各樣的硬件平臺。每個模塊可以單獨定制化或者二次開發(fā),而且不會破壞其他模塊的完整性。主站結(jié)構(gòu)如圖

1677203091573764.png

KPA主要功能模塊為:

(1)應(yīng)用層:應(yīng)用層負責與各種不同的編程/配置環(huán)境交互,負責與不同的應(yīng)用或設(shè)備交互。確保在應(yīng)用或過程任務(wù)端順利訪問主站功能函數(shù);與主站通過Remote Procedure Calls服務(wù)交互,提供了TCP/IP以及UDP連接,比如:通過UDP與從站設(shè)備進行mailbox相關(guān)的通訊

(2)Mailbox Module:EtherCAT主站核心mailbox模塊利用不同的協(xié)議處理服務(wù)數(shù)據(jù)對象(SDP),數(shù)據(jù)傳輸以及數(shù)據(jù)交換。支持CoE,FoE,EoE,SoE,VoE,AoE等郵箱服務(wù)。

(3)Process Image Module過程映像模塊:Process Image簡稱PI,它的地址是由EtherCAT network information (ENI) 文件提出的,ENI文件可由配置工具KPA Studio自動生成。從控制/過程任務(wù)訪問過程映像是由主站接口執(zhí)行的。

(4)Distribution Clock分布時鐘模塊:使得所有的EtherCAT設(shè)備(包括主站和從站)總是能夠共享相同的EtherCAT系統(tǒng)時間。這是通過補償編譯和漂移時間來實現(xiàn)的。

(5)Frame Schedule Module幀調(diào)度模塊:不同PDO采用不同的掃描周期。在配置工具KPA Studio里,用戶可以單獨定義每個從站的掃描速率。幀調(diào)度表模塊管理EtherCAT幀速率,轉(zhuǎn)發(fā)它們到EtherCAT網(wǎng)絡(luò)驅(qū)動。

(6)OSAL操作系統(tǒng)抽象層模塊:包含與操作系統(tǒng)相關(guān)的功能函數(shù)的包裝,比如處理線程、計時器、互斥量等;包括網(wǎng)絡(luò)適配驅(qū)動器模塊:從底層的網(wǎng)絡(luò)實現(xiàn)提取主站堆棧的core核心

2.2 KPA EtherCAT主站硬件介紹

主站硬件主要由三部分組成見下圖:ZCU102主站開發(fā)板以及外擴的FMC網(wǎng)卡。KPA MAC IPcore在PL端構(gòu)建了FPGA網(wǎng)卡,FreeRTOS master既可以運行在R5 CPU中也可以運行在A53 CPU中,另外需要一臺PC通過串口終端來實現(xiàn)操作系統(tǒng)指令輸入,PC端上的EtherCAT網(wǎng)絡(luò)診斷配置工具KPA EtherCAT Studio通過RPC服務(wù)連接ZCU102主站板,可以實現(xiàn)對主站和從站的配置,掃描生成網(wǎng)絡(luò)配置文件。

1677203120453891.png

2.3 KPA EtherCAT主站移植

2.3.1 硬件開發(fā)板

Xilinx HW-Z1-ZCU102 revision1.1

2.3.2 EtherCAT主站軟件開發(fā)包

MDK_xilinx-2018.3_freertos_a53_trial_v2.4.48714.0-release.zip

HW_SAMPLE_xilinx-2018.3_freertos_a53_trial_v2.4.48714.0-release.zip

2.3.3 軟件編譯

將MDK_xilinx-2018.3_freertos_a53_trial_v2.4.48714.0-release.zip解壓到mdk_a53文件夾下

1677203148234483.png

進入mdk_a53samples路徑下修改對應(yīng)樣例程序,此處每個不同的樣例程序包含不同的API,具有不同的功能,此處以24_DriveRotationCiA402為例,這是一個簡單運行單軸伺服的樣例程序,為了適配邁信伺服驅(qū)動器,需保持C文件中的描述和ENI文件描述一致,修改后保存

1677203155966839.png

1677203251409291.png

進入mdk_a53下,打開build.bat,修改編譯器路徑,路徑是xilinx SDK安裝路徑

1677203259460039.png

運行cmd,進入該路徑下,運行build.bat,編譯所有樣例代碼,包括編譯24樣例,在buildsamples路徑下生成24_DriveRotationCiA402.elf文件

1677203268327139.png2.3.4 創(chuàng)建運行程序

進入mdk_a53externalsboot路徑,根據(jù)readme文件以及24_DriveRotationCiA402.bif文件;

拷貝zcu102_freeRTOS內(nèi)vivado工程生成的design_1_wrapper.bit()文件到該路徑下,覆蓋原來bit文件;

拷貝zcu102_freertosproject_1project_1.sdkfsblRelease下的fsbl.elf到該路徑下,覆蓋原來fsbl.elf文件;

拷貝buildsamples路徑下生成的24_DriveRotationCiA402.elf到該路徑下;

拷貝生成的ENI文件(master.xml)文件到該路徑下

打開Xilinx XSCT tool進入到externalsboot路徑下,生成boot.bin

1677203303490772.png

將boot.bin文件拷貝到SD卡中,設(shè)置開發(fā)板SD卡啟動,上電運行

1677203315270132.png

2.4 主站性能數(shù)據(jù)

網(wǎng)絡(luò)配置:Beckhoff EK1100+EL1004+EL2004+EL6692 (60 bytes frame)。

運行在R5 CP(x32)上測試數(shù)據(jù):

運行在A53 CPU(x64)上測試數(shù)據(jù):

1677203332730959.png

3. 第三方抓包工具性能分析方法

一般情況下EtherCAT主站性能測試會關(guān)注主站通訊周期,circle time是否穩(wěn)定,抖動多少,因此可以設(shè)置在不同的circle time,比如2ms,1ms,500us,250us,125us等條件下測試抖動,可以采用第三方的抓包工具+wireshark進行報文分析,不同主站周期,需要修改代碼以及ENI文件的circle time,此處以1ms主站周期,郵箱任務(wù)周期是5ms(主站周期的5倍)

1677203353998501.png

1677203360568117.png

對Wireshark數(shù)據(jù)包進行針對性分析,設(shè)置時間顯示格式如下

1677203368824216.png

使用ecat.ado == 0x130命令,過濾出從站在第幾條報文處進入op狀態(tài)的,這里是33900,意味著33900前的報文不能用于分析circle time,因為pdo數(shù)據(jù)/周期性數(shù)據(jù)只在從站進入op后才被發(fā)送

1677203377218295.png

分析周期性報文,注意到每個周期性報文包含三個子報文(邏輯尋址)以及一個DC相關(guān)的ARMW命令

1677203388624683.png

過濾出周期性報文,使用該指令ecat.sub1.cmd == LRD && ecat.sub1.cnt == 0,過濾出子報文1為LRD且計算器值為0(表示從主站發(fā)出,未經(jīng)過從站)的周期性報文,選擇三角進行報文排序,可以是從小到大,或者從大到小。

最小周期是999.496us


審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 以太網(wǎng)
    +關(guān)注

    關(guān)注

    40

    文章

    5453

    瀏覽量

    172200
  • Zynq
    +關(guān)注

    關(guān)注

    10

    文章

    610

    瀏覽量

    47230
  • ethercat
    +關(guān)注

    關(guān)注

    18

    文章

    722

    瀏覽量

    38769
  • MPSoC
    +關(guān)注

    關(guān)注

    0

    文章

    199

    瀏覽量

    24302
收藏 人收藏

    評論

    相關(guān)推薦

    如何利用ZYNQ MPSoC玩DOOM?

    賽靈思和 DornerWorks 的系統(tǒng)軟件團隊在賽靈思的 Zynq? Ultrascale+? MPSoC 上啟動 Xen Project 管理程序時,我們發(fā)現(xiàn)可通過運行當年叱詫一時的流行電子游戲
    發(fā)表于 10-09 06:21

    請問Zynq Ultrascale + MPSOC本身是否存在問題?

    你好我們正在考慮在我們的新設(shè)計中使用Zynq Ultrascale + MPSOC。我們想在我們的電路板設(shè)計中加入HDMI接口。 Zynq Ultr
    發(fā)表于 10-14 09:17

    如何調(diào)試Zynq UltraScale+ MPSoC VCU DDR控制器

    的普通問題,還是一個出現(xiàn)在正在使用 Zynq UltraScale+ MPSoC VCU DDR 控制器的地方的特殊問題?! DR 性能:  對于
    發(fā)表于 01-07 16:02

    如何調(diào)試Zynq UltraScale+ MPSoC VCU DDR控制器

    如何調(diào)試 Zynq UltraScale+ MPSoC VCU DDR 控制器?
    發(fā)表于 01-22 06:29

    ZYNQ Ultrascale+ MPSOC FPGA教程

    ZYNQ Ultrascale+ MPSOC FPGA教程
    發(fā)表于 02-02 07:53

    開源!ZYNQ IgH EtherCAT方案分享

    前 言:創(chuàng)龍科技已基于IMX8、ZYNQ、AM5728、AM5708、AM437x、AM335x、T3/A40i等平臺提供了開源EtherCATIgH案例。本文主要演示
    發(fā)表于 10-29 11:17

    Zynq UltraScale+ MPSoC系列有多少SerDes接口?

    作者:Steve Leibson, 賽靈思戰(zhàn)略營銷與業(yè)務(wù)規(guī)劃總監(jiān) 在高性能系統(tǒng)中越來越多地使用高速串行互聯(lián)意味著你會在Zynq UltraScale+ MPSoC系列中的11款器件中發(fā)
    發(fā)表于 02-08 05:50 ?684次閱讀

    Ti推出面向Zynq UltraScale+ MPSoC的電源參考設(shè)計

    本篇文章將與大家討論的是Xilinx Zynq UltraScale+ MPSoC的電源解決方案參考設(shè)計。
    發(fā)表于 03-14 02:24 ?3730次閱讀
    Ti推出面向<b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale</b>+ <b class='flag-5'>MPSoC</b>的電源參考設(shè)計

    Zynq UltraScale+ MPSoC的發(fā)售消息

    Zynq?UltraScale+?MPSoC,現(xiàn)已開始發(fā)售。視頻向您重點介紹了Xilinx UltraScale +產(chǎn)品組合的第一位成員
    的頭像 發(fā)表于 11-27 06:47 ?3623次閱讀

    如何使用Zynq UltraScaleMPSOC管理電源和性能資料說明

    為了滿足關(guān)鍵的系統(tǒng)級需求,設(shè)計者必須將功率/熱量與整體性能抵消。Zynq UltraScale+?MPSOC有助于實現(xiàn)這種平衡。
    發(fā)表于 02-19 11:53 ?18次下載
    如何使用<b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale</b>和<b class='flag-5'>MPSOC</b>管理電源和<b class='flag-5'>性能</b>資料說明

    如何調(diào)試 Zynq UltraScale+ MPSoC VCU DDR 控制器?

    Zynq UltraScale+ MPSoC VCU DDR 控制器是一款專用 DDR 控制器,只支持在 Zynq UltraScale+
    發(fā)表于 02-23 06:00 ?15次下載
    如何調(diào)試 <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale</b>+ <b class='flag-5'>MPSoC</b> VCU DDR 控制器?

    米爾電子zynq ultrascale+ mpsoc底板外設(shè)資源清單分享

    米爾電子推出的國內(nèi)首款zynq ultrascale+ mpsoc平臺核心板(及開發(fā)板):MYC-CZU3EG吸引了人工智能、工業(yè)控制、嵌入式視覺、ADAS、算法加速、云計算、有線/無線通信等
    發(fā)表于 01-07 15:20 ?3次下載
    米爾電子<b class='flag-5'>zynq</b> <b class='flag-5'>ultrascale</b>+ <b class='flag-5'>mpsoc</b>底板外設(shè)資源清單分享

    Zynq UltraScale+ MPSoC的隔離設(shè)計示例

    電子發(fā)燒友網(wǎng)站提供《Zynq UltraScale+ MPSoC的隔離設(shè)計示例.pdf》資料免費下載
    發(fā)表于 09-13 11:28 ?3次下載
    <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale</b>+ <b class='flag-5'>MPSoC</b>的隔離設(shè)計示例

    Zynq UltraScale+MPSoC嵌入式設(shè)計教程

    電子發(fā)燒友網(wǎng)站提供《Zynq UltraScale+MPSoC嵌入式設(shè)計教程.pdf》資料免費下載
    發(fā)表于 09-13 09:14 ?5次下載
    <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+MPSoC</b>嵌入式設(shè)計教程

    Zynq UltraScale+ MPSoC數(shù)據(jù)手冊

    電子發(fā)燒友網(wǎng)站提供《Zynq UltraScale+ MPSoC數(shù)據(jù)手冊.pdf》資料免費下載
    發(fā)表于 12-30 14:37 ?0次下載