therCAT是一种高效且常用的工业通讯协议。本系列文章将带领您使用ZLG致远电子的PCIe EtherCAT通讯卡,一步步实现从搭建编译环境到程序运行。
ZLG致远电子 PCIe EtherCAT通讯卡 是一款高性能的总线控制卡,专为满足高实时的工业控制需求而设计。基于PCI Express技术,该卡通过使用实时内核+商业授权EtherCAT协议栈的方式,实现了高达125us的控制周期。
为了方便用户的使用,该卡配套提供了全面的上位机配置软件AWStudio,用户通过使用AWStudio软件,可快速扫描从站设备,轻松地得到ENI的配置文件。此外,该卡还支持Windows、Linux、Vxworks等多平台,并提供了简洁易用的SDK接口。无论是在复杂的工业控制中,还是在追求高性能的场景中,ZLG致远电子的PCIe EtherCAT通讯卡都是您的理想选择。运行框架:
表1 PCIe EtherCAT通讯卡型号
搭建步骤为了优化客户使用PCIe EtherCAT通讯卡的体验,我们将详细介绍在Ubuntu环境下开发项目搭建环境的步骤,以及如何快速上手使用PCIE卡和IO从站进行通讯。这将使您能够快速而轻松地将ZLG致远电子的PCIe EtherCAT通讯卡接入到您的工程项目中。
1. 前期准备1.1 在目标机器上安装驱动;
1.2 获得SDK包;
1.3 使用AWStudio导出EtherCAT网络信息文件(ENI)。
2. 项目创建
2.1 构建工程目录
新建Project文件夹。
将sdk移动到工程目录中。
移动完后,工程目录Project将会是下图的样子。
2.2 CMakeLists.txt编写
在Project目录下,创建CMakeLists.txt文件。
在CMakeLists.txt文件中输入。
2.3 创建测试程序
在src目录中创建主程序ecat_api_io_test.cpp,该文件名需要和CMakeLists.txt中的SRC变量相同。
打开ecat_api_io_test.cpp文件。输入内容:
#include <iostream>#include <chrono> //用于sleep#include <thread> //用于sleep#include "pci_errno.h"#include "pci_zecm.h"#include "pci_dbg.h"
int32_t testDemo(int alias, int channel, const char* fileName){int result = 0;char buff[256]; ECAT_HANDLE hHandle; //初始化hHandle句柄 EXIT_IF_FAIL(EcatOpen(&hHandle, BOARD_ALIAS(buff, alias), channel));//启动主站 EXIT_IF_FAIL(EcatBusRun(hHandle, fileName));//将状态切换为8(Operational) EXIT_IF_FAIL(EcatRequestMasterState(hHandle, EcatStateO));EXIT_IF_FAIL(EcatClose(hHandle)); return result;}
int main(int argc, char* argv[]){ ECAT_HANDLE hHandle; char buff[256]; uint32_t channel = 0, alias = 0; std::string eniFile; if (argc != 4){ std::cout << "usage: " << argv[0] << " encoder_id channel eni.xml" << std::endl; return1; } alias = atoi(argv[1]); channel = atoi(argv[2]); eniFile = argv[3]; if (channel > 1){ channel = 1; } testDemo(alias, channel, eniFile.c_str()); return0;}上面的示例代码实现了主站的启动以及关闭,具体的过程数据修改将在下一章节做介绍。2.4 测试编译环境
构建项目,先去到项目的根目录。
创建构建的文件夹build。
进入到文件夹build。
执行cmake构建项目。
编译(编译完成后,生成的执行程序将会在build目录下,可执行程序的名字为CMakeLists.txt中TARGET_NAME变量指定的名字)。
|