Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
CAN总线
CAN被动错误恢复后,rt_device_write返回异常
发布于 2022-03-11 16:11:22 浏览:1400
订阅该版
1、系统启动,给CAN总线发送数据,总线设备通讯正常 2、制造总线错误,当总线设备错误帧达到128之后,总线进入被动错误,总线数据发送失败,rt_device_write函数返回0 3、恢复总线设备,CAN总线错误帧降低到0,**rt_device_write仍然返回0,但总线设备通讯正常**
查看更多
7
个回答
默认排序
按发布时间排序
张世争
2022-03-11
学以致用
可以软件调试下,是否 can device 异常被关闭了,恢复后没有open
TXH97
2022-04-03
这家伙很懒,什么也没写!
可以单步调试下write,看看正常的时候和异常的时候有什么不同
mhxsoft
2022-04-30
这家伙很懒,什么也没写!
波特率对不
吕蛋蛋
2022-05-05
这家伙很懒,什么也没写!
铁子,解决了吗,我也遇到这个问题了。size返回为0但是依旧可以发送出数据
自挂东南枝
2022-05-08
这家伙很懒,什么也没写!
- 一样的问题现象,出现时问题时,中断服务函数中判定应该是发送成功的 ```c if (__HAL_CAN_GET_FLAG(hcan, CAN_FLAG_TXOK0)) { rt_hw_can_isr(&drv_can1.device, RT_CAN_EVENT_TX_DONE | 0 << 8); } ``` 这个判断可以进入,单步进入rt_hw_can_isr后发现进入到这里 ```c case RT_CAN_EVENT_TX_DONE: case RT_CAN_EVENT_TX_FAIL: struct rt_can_tx_fifo *tx_fifo; rt_uint32_t no; no = event >> 8; tx_fifo = (struct rt_can_tx_fifo *) can->can_tx; RT_ASSERT(tx_fifo != RT_NULL); if ((event & 0xff) == RT_CAN_EVENT_TX_DONE) { tx_fifo->buffer[no].result = RT_CAN_SND_RESULT_OK; } else { tx_fifo->buffer[no].result = RT_CAN_SND_RESULT_ERR; } rt_completion_done(&(tx_fifo->buffer[no].completion)); break; ``` `RT_CAN_EVENT_TX_DONE`这个case是没有break的,处理在下边`RT_CAN_EVENT_TX_FAIL`的case中处理,断点调试后发现返回的是成功 ![image.png](https://oss-club.rt-thread.org/uploads/20220508/38b3d117ec1e54760e36909e04ad1529.png) 最终回到_can_int_tx中时,结果如注释中写的,最终导致size返回0 ```c rt_completion_wait(&(tx_tosnd->completion), RT_WAITING_FOREVER); level = rt_hw_interrupt_disable(); result = tx_tosnd->result; //返回值是2 if (!rt_list_isempty(&tx_tosnd->list)) { rt_list_remove(&tx_tosnd->list); } rt_list_insert_before(&tx_fifo->freelist, &tx_tosnd->list); rt_hw_interrupt_enable(level); rt_sem_release(&(tx_fifo->sem)); if (result == RT_CAN_SND_RESULT_OK)//RT_CAN_SND_RESULT_OK: 0 RT_CAN_SND_RESULT_WAIT:2 { level = rt_hw_interrupt_disable(); can->status.sndpkg++; rt_hw_interrupt_enable(level); data ++; msgs -= sizeof(struct rt_can_msg); if (!msgs) break; } else { level = rt_hw_interrupt_disable(); can->status.dropedsndpkg++; rt_hw_interrupt_enable(level); break; } ``` 第一次使用rt-thread,求解
用户名由3_15位
2022-10-11
这家伙很懒,什么也没写!
按照这个帖子的办法可以解决 https://club.rt-thread.org/ask/article/5cedb728813e6fd8.html `drv_can.c`里,当CAN总线拔掉发送时,会进入ACK错误中断SCE,这时TSR的TXOK都是0, 另`CAN_FLAG_TXOK0/1/2`值的定义,还要移位才能对应,READ_BIT没有进行移位,所以下面这三个条件并不会执行,改为下面方式就可以执行了,并且清理了发送请求位`CAN_TSR_RQCP0/1/2` ```c CAN1_SCE_IRQHandler(void) { ...... case RT_CAN_BUS_ACK_ERR:/* attention !!! test ack err's unit is transmit unit */ drv_can1.device.status.ackerrcnt++; if (!READ_BIT(drv_can1.CanHandle.Instance->TSR, CAN_FLAG_TXOK0)) rt_hw_can_isr(&drv_can1.device, RT_CAN_EVENT_TX_FAIL | 0 << 8); else if (!READ_BIT(drv_can1.CanHandle.Instance->TSR, CAN_FLAG_TXOK1)) rt_hw_can_isr(&drv_can1.device, RT_CAN_EVENT_TX_FAIL | 1 << 8); else if (!READ_BIT(drv_can1.CanHandle.Instance->TSR, CAN_FLAG_TXOK2)) rt_hw_can_isr(&drv_can1.device, RT_CAN_EVENT_TX_FAIL | 2 << 8); break; ...... } ``` ———————-改为以下代码——————— ```c CAN1_SCE_IRQHandler(void) { ...... case RT_CAN_BUS_ACK_ERR:/* attention !!! test ack err's unit is transmit unit */ drv_can1.device.status.ackerrcnt++; if (__HAL_CAN_GET_FLAG(hcan, CAN_FLAG_RQCP0)) { if (!__HAL_CAN_GET_FLAG(hcan, CAN_FLAG_TXOK0)) { rt_hw_can_isr(&drv_can1.device, RT_CAN_EVENT_TX_FAIL | 0 << 8); } SET_BIT(hcan->Instance->TSR, CAN_TSR_RQCP0); } else if (__HAL_CAN_GET_FLAG(hcan, CAN_FLAG_RQCP1)) { if (!__HAL_CAN_GET_FLAG(hcan, CAN_FLAG_TXOK1)) { rt_hw_can_isr(&drv_can1.device, RT_CAN_EVENT_TX_FAIL | 1 << 8); } SET_BIT(hcan->Instance->TSR, CAN_TSR_RQCP1); } else if (__HAL_CAN_GET_FLAG(hcan, CAN_FLAG_RQCP2)) { if (!__HAL_CAN_GET_FLAG(hcan, CAN_FLAG_TXOK2)) { rt_hw_can_isr(&drv_can1.device, RT_CAN_EVENT_TX_FAIL | 2 << 8); } SET_BIT(hcan->Instance->TSR, CAN_TSR_RQCP2); } break; ...... } ```
e_donkey
2024-07-30
这家伙很懒,什么也没写!
好像可以解决,通过https://club.rt-thread.org/ask/article/5cedb728813e6fd8.html 能解决卡死问题,然后恢复后,这个方法解决了write返回是0字节,但是实际发送成功的问题。棒
撰写答案
登录
注册新账号
关注者
4
被浏览
1.4k
关于作者
Memory_
这家伙很懒,什么也没写!
提问
1
回答
0
被采纳
0
关注TA
发私信
相关问题
1
我也来传一个CANOpen移植,RTT+STM32F107+CanOpenNode
2
谁有STM32裸跑的CANopen程序啊???
3
CAN驱动程序框架
4
CAN驱动接口如何规范一下
5
RTT无法进入线程.Cannot access Memory
6
编译提示arm-none-eabi/bin/ld: cannot find crt0.o: No such file o
7
rtt 2.1.0 正式版 mdk4 bsp/stm32 编译canapp.c错误
8
STM32F10XCAN驱动使用的问题
9
2.1版本stm32f10x分支bxcan驱动波特率设置的bug
10
rtthread2.1.0下,找不到can1设备
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
ota在线升级
UART
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
at_device
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
张世争
8
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
KunYi
6
个答案
1
次被采纳
本月文章贡献
程序员阿伟
6
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部