学习CANopen --- [12] Abort报文

当我们使用SDO进行读写操作时,有时device会返回abort报文,意味着本次SDO读写失败。本文使用例子来讲解Abort报文,以及如何解读失败原因。


一 Device例子

下面是device的python代码,文件名叫device.py,device的CANopen id是6,

python 复制代码
import signal
import canopen


running = True

def sigint_handler(signum, frame):
	global running
	print('')
	running = False
	exit(0)


## 创建自定义的对象字典
def createOD():
    od = canopen.ObjectDictionary()
    
    # 添加单个项 --- 0x1009,类型是字符串
    var = canopen.objectdictionary.Variable('Manufacturer hardware version', 0x1009)
    var.data_type = canopen.objectdictionary.VISIBLE_STRING
    od.add_object(var)


    # 添加单个项 --- 0x1017,类型是unsigned int16
    var = canopen.objectdictionary.Variable('Producer heartbeat time', 0x1017)
    var.data_type = canopen.objectdictionary.UNSIGNED16
    od.add_object(var)

    return od


# 处理按键发送的信号,优雅的关闭程序
signal.signal(signal.SIGINT,  sigint_handler)
signal.signal(signal.SIGHUP,  sigint_handler)
signal.signal(signal.SIGTERM, sigint_handler)

# 创建一个网络用来表示CAN总线
network = canopen.Network()

# 连接到CAN总线
network.connect(bustype='socketcan', channel='vcan0')

# 创建slave节点,其id是6,对象字典为CANopenSocket.eds
node = network.create_node(6, createOD())

# 向CAN总线上发送启动消息
node.nmt.send_command(0)

# 发送心跳报文,每隔1s发送一次
node.nmt.start_heartbeat(1000) # 1000ms


# 循环
while running:
	time.sleep(0.05) # 降低CPU使用率

代码里自定义了对象字典,只添加了2个OD项 --- 0x1009和0x1017


二 报文分析

首先开启一个终端,使用python运行device.py;接着再开一个终端运行candump vcan0,这个用来观察CAN报文。

最后再开一个终端,使用cansend去发送读SDO的命令,这里读0x1018_00,很明显这个OD项不在Device的对象字典里,
cansend vcan0 606#4018100000000000

最后观察到的报文如下,

图中红框就是Abort报文,586h是Abort报文的COB-id,报文内容解释如下,

可以看出该Abort报文的CS值是0x80,OD项的Index是0x1018,SubIndex是0(通过Index和SubIndex可以帮助我们知道是哪条SDO报文出错),Abort code是0x06020000

而abort code的释义如下,

所以0x06020000对应的含义是device的对象字典里不存在该OD项,对应本文例子就是device的对象字典不存在0x1018_00


三 总结

本文通过例子来讲解abort报文,以及如何分析它,这样当出现其它的abort报文都可以很容易理解了。

相关推荐
大丈夫立于天地间8 小时前
ISIS基础知识
网络·网络协议·学习·智能路由器·信息与通信
Chambor_mak9 小时前
stm32单片机个人学习笔记14(USART串口数据包)
stm32·单片机·学习
PaLu-LI9 小时前
ORB-SLAM2源码学习:Initializer.cc⑧: Initializer::CheckRT检验三角化结果
c++·人工智能·opencv·学习·ubuntu·计算机视觉
yuanbenshidiaos10 小时前
【大数据】机器学习----------计算机学习理论
大数据·学习·机器学习
汤姆和佩琦10 小时前
2025-1-20-sklearn学习(42) 使用scikit-learn计算 钿车罗帕,相逢处,自有暗尘随马。
人工智能·python·学习·机器学习·scikit-learn·sklearn
Tech智汇站10 小时前
Quick Startup,快捷处理自启程序的工具,加快电脑开机速度!
经验分享·科技·学习·学习方法·改行学it
qq_3127384510 小时前
jvm学习总结
jvm·学习
执念斩长河12 小时前
Go反射学习笔记
笔记·学习·golang
陈王卜13 小时前
html与css学习笔记(2)
笔记·学习
Rinai_R13 小时前
【Golang/gRPC/Nacos】在golang中将gRPC和Nacos结合使用
经验分享·笔记·学习·微服务·nacos·golang·服务发现