CanOpen学习笔记3

Stella981
• 阅读 1078

主机部分(Master):

从机PDO发送发送或者接收需要SYNC信号,也就是从机接收到一个或者多个SYNC信号后发送一个PDO,也可以主机明确给出请求信号。

SYNC同步信号产生设置:

1、写0x40000080到index 0x1005, subindex 0位置(SYNC COB ID)。

2、设置同步信号周期,在index 0x1006, subindex 0位置写入周期值(以us为单位)。

3、启动时钟定时器(StartTimerLoop(),此函数中启动定时器(单片机)或者创建定时器线程(PC),定时时间到调用TimeDispatch()完成定时任务)。

注:若需要停止产生SYNC信号,可在0x1005-0x00位置写0。

主机接收设置:

主机需要将自己的OD的RPDO(如0x1400-0x01即index 0x1400, subindex 0x01)的COB-ID的值改成从机的TPDO(0x1800-0x01)的一样的值,即建立一一对应的关系。同时其PDO MAPPING也是一一对应的,即Master的RPDO和Slave的TPDO的MAPPING中的变量是一一对应的。

主机发送设置:

主机需要将自己的OD的TPDO(如0x1800-0x01)的COB-ID的值改成从机的RPDO(0x1800-0x01)的一样的值,即建立一一对应的关系。同时其PDO MAPPING也是一一对应的,即Master的TPDO和Slave的RPDO的MAPPING中的变量是一一对应的。

在PDO MAPPING索引项中,从第一至后面的子索引项,那个32位的值高16位为对应变量的在此OD中的索引值,中间8位为其索引项的子索引值,低8位为此变量的位数。注:一个PDO Mapping的所有变量的位数总和不得超过64位。

主机必须处于Operational状态才能发送或者接收处理PDO帧。

主机post_sync()回调函数调用发生在SYNC帧发出去之后,从机在接收到SYNC之后调用。post_TPDO()调用发生在处理完SYNC帧之后。

从机部分:

类似主机,补充几点,发送接收之前需要确定PDO的传输类型(Transmission Type),若为0,只能异步发送(即接收到发送请求或者主动发送),接收到SYNC帧不会发送;若为1240,则接收到1240个SYNC帧发送一次,若为其他见协议。

TRANS_RTR_SYNC( 252)当收到PDO请求,若该PDO_status的状态位PDO_RTR_SYNC_READY置位(会在接收到SYNC信号调用的_sendPDOevent中BuildPDO并置该位),则直接发出PDO的最后一帧(PDO_status[numPdo].last_message)。

TRANS_RTR(253)参数,当收到PDO请求(SendPDORequest)后立即BuildPDO发送被请求的PDO帧(cob_id标示)。

TRANS_EVENT_SPECIFIC(254)以及TRANS_EVENT_PROFILE(255):调用sendPDOevent()(未被阻止inhibited)后建立PDO并检查其PDO帧与上一次发送(PDO_status.last_message)的PDO帧内容是否发生变化,若发生变化则发送,否则不发送。接收到SYNC帧不会发送该帧。但是若接收到PDO请求则强制建立并发送。

TRANS_SYNC_ACYCLIC(0):当接收到SYNC帧,若PDO Mapping中索引的变量发生变化则发送,否则不发送。调用sendPDOevent()不会发送。

综上可知,TRANS_SYNC_MIN,TRANS_SYNC_MAX及TRANS_EVERY_N_SYNC(n)是在接收到相应数量SYNC后建立发送PDO。TRANS_SYNC_ACYCLIC是接收到SYNC后检查其PDO帧是否发生变化,若有变化发送。TRANS_RTR和TRANS_RTR_SYNC是根据PDO请求发送,前者得到请求立即发送,后者是在已经接收到SYNC帧建立PDO后发送。TRANS_EVENT_SPECIFIC和TRANS_EVENT_PROFILE是由sendPDOevent()检查PDO帧发生变化后发送,在收到PDO请求也会强制发送一次。

当需要禁止某个远程节点的某个PDO,可以在其OD的PDO的COB-ID值的最高位(第31位)置1,这需要通过SDO服务实现。

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
2年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Peter20 Peter20
3年前
mysql中like用法
like的通配符有两种%(百分号):代表零个、一个或者多个字符。\(下划线):代表一个数字或者字符。1\.name以"李"开头wherenamelike'李%'2\.name中包含"云",“云”可以在任何位置wherenamelike'%云%'3\.第二个和第三个字符是0的值wheresalarylike'\00%'4\
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这