SOEM的周期数据处理耗时异常问题
在ecat主站初始化通过后,会出现rtos任务无法执行问题,推测为ecat任务耗时过长导致。咸鱼ID:tb764914262。b站,知乎:沧海一条狗。
·
在ecat主站初始化通过后,会出现rtos任务无法执行问题,推测为ecat任务耗时过长导致。于是接上逻辑分析仪,测试代码如下:
#define EC_TIMEOUTRET 2000
void ecat_loop(void)
{
IO_1_HIG_OUT;
ecx_send_processdata( & ecx_context);
ecx_receive_processdata( & ecx_context, EC_TIMEOUTRET);
IO_1_LOW_OUT;
}
逻辑分析仪抓到的高电平时长为2ms,大于此任务的执行周期1ms:
为ecx接收阻塞导致,修改为:
ecx_receive_processdata( & ecx_context_dm9k, 100);//阻塞100us
解决!
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)