获取SOEM主站或了解文件分布,可以读取我以前写的博客SOEM主站软件包及函数头文件介绍,本篇ethercatcoe文件相关的函数,COE的全称是CanOpen over EtherCAT, 采用CanOpen的相关协议开发了EtherCAT的运用层,核心是对象字典,想了解PDO相关知识,可以读CanOpen通信----PDO与SDO。对于报文结构体相关知识,可以参照EtherCAT数据帧及SOEM报文数据结构介绍,对下文的理解有一定帮组。
为了比较全面的了解COE, 本文将先给出ethercatcoe.h的头文件,如下所示,其中核心的是读写函数。
/* * Licensed under the GNU General Public License version 2 with exceptions. See * LICENSE file in the project root for full license information */ /** \file * \brief * Headerfile for ethercatcoe.c */ #ifndef _ethercatcoe_ #define _ethercatcoe_ #ifdef __cplusplus extern "C" { #endif /** max entries in Object Description list */ #define EC_MAXODLIST 1024 /** max entries in Object Entry list */ #define EC_MAXOELIST 256 /* Storage for object description list */ typedef struct { /** slave number */ uint16 Slave; /** number of entries in list */ uint16 Entries; /** array of indexes */ uint16 Index[EC_MAXODLIST]; /** array of datatypes, see EtherCAT specification */ uint16 DataType[EC_MAXODLIST]; /** array of object codes, see EtherCAT specification */ uint8 ObjectCode[EC_MAXODLIST]; /** number of subindexes for each index */ uint8 MaxSub[EC_MAXODLIST]; /** textual description of each index */ char Name[EC_MAXODLIST][EC_MAXNAME+1]; } ec_ODlistt; /* storage for object list entry information */ typedef struct { /** number of entries in list */ uint16 Entries; /** array of value infos, see EtherCAT specification */ uint8 ValueInfo[EC_MAXOELIST]; /** array of value infos, see EtherCAT specification */ uint16 DataType[EC_MAXOELIST]; /** array of bit lengths, see EtherCAT specification */ uint16 BitLength[EC_MAXOELIST]; /** array of object access bits, see EtherCAT specification */ uint16 ObjAccess[EC_MAXOELIST]; /** textual description of each index */ char Name[EC_MAXOELIST][EC_MAXNAME+1]; } ec_OElistt; #ifdef EC_VER1 void ec_SDOerror(uint16 Slave, uint16 Index, uint8 SubIdx, int32 AbortCode); int ec_SDOread(uint16 slave, uint16 index, uint8 subindex, boolean CA, int *psize, void *p, int timeout); int ec_SDOwrite(uint16 Slave, uint16 Index, uint8 SubIndex, boolean CA, int psize, void *p, int Timeout); int ec_RxPDO(uint16 Slave, uint16 RxPDOnumber , int psize, void *p); int ec_TxPDO(uint16 slave, uint16 TxPDOnumber , int *psize, void *p, int timeout); int ec_readPDOmap(uint16 Slave, int *Osize, int *Isize); int ec_readPDOmapCA(uint16 Slave, int Thread_n, int *Osize, int *Isize); int ec_readODlist(uint16 Slave, ec_ODlistt *pODlist); int ec_readODdescription(uint16 Item, ec_ODlistt *pODlist); int ec_readOEsingle(uint16 Item, uint8 SubI, ec_ODlistt *pODlist, ec_OElistt *pOElist); int ec_readOE(uint16 Item, ec_ODlistt *pODlist, ec_OElistt *pOElist); #endif void ecx_SDOerror(ecx_contextt *context, uint16 Slave, uint16 Index, uint8 SubIdx, int32 AbortCode); int ecx_SDOread(ecx_contextt *context, uint16 slave, uint16 index, uint8 subindex, boolean CA, int *psize, void *p, int timeout); int ecx_SDOwrite(ecx_contextt *context, uint16 Slave, uint16 Index, uint8 SubIndex, boolean CA, int psize, void *p, int Timeout); int ecx_RxPDO(ecx_contextt *context, uint16 Slave, uint16 RxPDOnumber , int psize, void *p); int ecx_TxPDO(ecx_contextt *context, uint16 slave, uint16 TxPDOnumber , int *psize, void *p, int timeout); int ecx_readPDOmap(ecx_contextt *context, uint16 Slave, int *Osize, int *Isize); int ecx_readPDOmapCA(ecx_contextt *context, uint16 Slave, int Thread_n, int *Osize, int *Isize); int ecx_readODlist(ecx_contextt *context, uint16 Slave, ec_ODlistt *pODlist); int ecx_readODdescription(ecx_contextt *context, uint16 Item, ec_ODlistt *pODlist); int ecx_readOEsingle(ecx_contextt *context, uint16 Item, uint8 SubI, ec_ODlistt *pODlist, ec_OElistt *pOElist); int ecx_readOE(ecx_contextt *context, uint16 Item, ec_ODlistt *pODlist, ec_OElistt *pOElist); #ifdef __cplusplus } #endif #endifSDO服务数据,也称为邮箱数据,通常用在驱动器配置阶段,其数据传输是非周期性的。
参数解释:
ecx_contextt *context:报文结构体指针,所有信息都是通过报文传递的,报文中包含了一系列配置信息;uint16 slave :从站编号,有顺序寻址、逻辑寻址等,采用顺序寻址在驱动器配置过程自动扫描分配,与连接顺序有关;uint16 index:对象字典索引,CanOpen相关协议uint8 subindex:对象字典子索引,CanOpen相关协议boolean CA:完全访问(Complete Access),会访问所有子索引,一般填写False,仅访问给定子索引。int *psize: 读取参数字节数void *p:读取参数指针,通过该指针可获取想要的信息int timeout:读取最大超时,单位us(微秒),一般给EC_TIMEOUTRXM,其值为700000@return Workcounter:返回计数wck,用于对比是否正确处理报文。参数解释:
ecx_contextt *context:报文结构体指针,所有信息都是通过报文传递的,报文中包含了一系列配置信息;uint16 slave :从站编号,有顺序寻址、逻辑寻址等,采用顺序寻址在驱动器配置过程自动扫描分配,与连接顺序有关;uint16 index:对象字典索引,CanOpen相关协议uint8 subindex:对象字典子索引,CanOpen相关协议boolean CA:完全访问(Complete Access),会访问所有子索引,一般填写False,仅访问给定子索引。int psize: 需要写入参数字节数void *p:写入参数指针,通过该指针可获修改对应从站数据int timeout:写入最大超时,单位us(微秒),一般给EC_TIMEOUTRXM,其值为700000@return Workcounter:返回计数wck,用于对比是否正确处理报文。