Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
ulog
串口
10
ulog输出异常-中断与线程打印冲突
发布于 2024-04-10 09:35:16 浏览:535
订阅该版
[tocm] 逻辑:can收到数据后,can中断打印test,并把数据放到消息队列,main函数的消息队列打印消息内容 问题:只要can中断中有test打印的代码,整个串口就会卡死; 中断中无test打印的代码,main函数的打印正常; main函数的打印代码注释掉的话,中断中的test打印正常; .config相关的配置 ```c # # Utilities # # CONFIG_RT_USING_RYM is not set CONFIG_RT_USING_ULOG=y # CONFIG_ULOG_OUTPUT_LVL_A is not set # CONFIG_ULOG_OUTPUT_LVL_E is not set # CONFIG_ULOG_OUTPUT_LVL_W is not set # CONFIG_ULOG_OUTPUT_LVL_I is not set CONFIG_ULOG_OUTPUT_LVL_D=y CONFIG_ULOG_OUTPUT_LVL=7 CONFIG_ULOG_USING_ISR_LOG=y CONFIG_ULOG_ASSERT_ENABLE=y CONFIG_ULOG_LINE_BUF_SIZE=128 CONFIG_ULOG_USING_ASYNC_OUTPUT=y CONFIG_ULOG_ASYNC_OUTPUT_BUF_SIZE=2048 CONFIG_ULOG_ASYNC_OUTPUT_BY_THREAD=y CONFIG_ULOG_ASYNC_OUTPUT_THREAD_STACK=2048 CONFIG_ULOG_ASYNC_OUTPUT_THREAD_PRIORITY=30 # # log format # CONFIG_ULOG_OUTPUT_FLOAT=y CONFIG_ULOG_USING_COLOR=y CONFIG_ULOG_OUTPUT_TIME=y # CONFIG_ULOG_TIME_USING_TIMESTAMP is not set CONFIG_ULOG_OUTPUT_LEVEL=y CONFIG_ULOG_OUTPUT_TAG=y # CONFIG_ULOG_OUTPUT_THREAD_NAME is not set CONFIG_ULOG_BACKEND_USING_CONSOLE=y # CONFIG_ULOG_BACKEND_USING_FILE is not set # CONFIG_ULOG_USING_FILTER is not set # CONFIG_ULOG_USING_SYSLOG is not set # CONFIG_RT_USING_UTEST is not set # CONFIG_RT_USING_VAR_EXPORT is not set # CONFIG_RT_USING_RESOURCE_ID is not set # CONFIG_RT_USING_ADT is not set # CONFIG_RT_USING_RT_LINK is not set # CONFIG_RT_USING_VBUS is not set ``` can中断中打印的代码 ```c void HAL_CAN_RxFifo0MsgPendingCallback(CAN_HandleTypeDef *hcan) { struct can_rx_msg msg; if (HAL_CAN_GetRxMessage(hcan, CAN_RX_FIFO0, &msg.RxHeader, msg.data) != HAL_OK) { LOG_E("get can rx error\n"); } if(msg.RxHeader.StdId != 0x601){ // A板TSDO 0x601 return; } LOG_E("test"); if(RT_EOK != rt_mq_send(&can1_obj.rx_msg_mq, &msg, sizeof(msg))){ LOG_E("send my_canopen_sdo_mq failed"); } } ``` main线程打印消息队列的数据 ```c int main(void) { while (1) { struct can_rx_msg rx_msg; if(1 == can_receive_data(&can1_obj, &rx_msg, RT_WAITING_FOREVER)) { LOG_D("stdid:%x dlc:%d data:%x %x %x %x %x %x %x %x", rx_msg.RxHeader.StdId, rx_msg.RxHeader.DLC, rx_msg.data[0], rx_msg.data[1], rx_msg.data[2], rx_msg.data[3], rx_msg.data[4], rx_msg.data[5], rx_msg.data[6], rx_msg.data[7]); } } } ```
查看更多
3
个回答
默认排序
按发布时间排序
Jam
2024-04-10
这家伙很懒,什么也没写!
与此问题有点类似,可能也是互斥量的问题 https://club.rt-thread.org/ask/question/af4cfb5cf6c82462.html
用户名由3_15位
2024-04-10
这家伙很懒,什么也没写!
- 怀疑你串口驱动有互斥操作以保证日志的完整显示;可以进一步排查看看
aeniac
2024-04-30
这家伙很懒,什么也没写!
把LOG_E("test");去掉试试,可能是因为中断中不可以使用可能会造成阻塞的代码。
撰写答案
登录
注册新账号
关注者
0
被浏览
535
关于作者
Jam
这家伙很懒,什么也没写!
提问
5
回答
8
被采纳
0
关注TA
发私信
相关问题
1
串口DMA发送数据时,数据被覆盖
2
关于串口DMA模式下rt_device_close问题
3
利用stm32f427实现usb转串口,电脑端什么也没有识别到
4
finsh 控制台 适配 RS 485请大神指点????
5
uart_sample.c 中,读串口设备时偏移量pos要设置为-1而不是0?
6
【结贴】at_device软件包中对串口接收数据缺少判断导致数据接收异常
7
串口无法接受数据,但可以发送
8
串口如何有效的清除掉接收缓冲,而不必一个一个的去读取
9
串口接收使用方式问题
10
雅特力FINSH问题
推荐文章
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
GD32F450 片内 flash驱动适配
2
STM32H7R7运行CherryUSB
3
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
4
使用RC522软件包驱动FM1722
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
UART
WIZnet_W5500
ota在线升级
freemodbus
PWM
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
a1012112796
10
个答案
1
次被采纳
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
5
次点赞
YZRD
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部