最近在开发Canopen项目中,进行一主多从设备通信时,主站发送同步帧,两个从站往往只有帧ID优先级高的设备可以让主站接收到数据,而另一个从设备的数据往往接收不到。但当我关闭其中一个can从设备,另一个就可以和主站设备通信正常。经过排查发现,是由于Can的冲突解决机制的问题。
在CAN多机通信中,两个设备同时发送数据,帧ID优先级高的CAN设备会“抢占”总线,而另外的设备需要选择冲突解决策略。
总的来说,CAN总线的冲突机制通过使用非破坏性的仲裁和标识符比较,以及回退机制,确保了多个节点之间的有序通信,使得总线上的消息能够按照优先级顺序进行传输。这种设计使得CAN总线非常适用于要求实时性和可靠性的应用,例如汽车控制系统。
我们在进行CAN的多机通信时,往往希望不会丢帧。遇到CAN总线冲突时,受阻的CAN从设备进行自动回传是我们需要的。而打开冲突回传只需要在CAN初始时对AutoRetransmission 进行使能。
hcan1.Init.AutoRetransmission = ENABLE;
AutoRetransmission 是用于配置CAN控制器的自动重传(Automatic Retransmission)功能。在CAN通信中,当节点发送消息但未收到确认时,可以选择是否自动进行重传。当 AutoRetransmission 被启用(ENABLE)时,如果CAN控制器未收到确认,则会自动重传先前的消息。这有助于提高消息的可靠性,特别是在有可能发生干扰或冲突的环境中。当 AutoRetransmission 被禁用(DISABLE)时,如果发送的消息未收到确认,控制器将不会自动进行重传。在这种情况下,需要由软件来处理重传逻辑,开发者可以通过程序来控制何时以及如何进行重传。
全部0条评论
快来发表一下你的评论吧 !