Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
rt_mq_消息队列_msg_queue
使用消息队列处理串口接收,出现线程卡住的问题
发布于 2022-08-16 20:07:19 浏览:1550
订阅该版
代码如下,串口中断里面发送消息,在serial_thread_entry线程里面接收,发现数据量比较大的时候,中断uart_input里面报消息队列满了之后,`result = rt_mq_recv(rx_mq, (void*)&msg, sizeof(msg), 5);`会一直卡在这里面,设置了超时也没有任何作用,是不是系统的bug? ```c #include
//#include
#include
//#include "debug_pin.h" #define SAMPLE_UART_NAME "uart2" /* 串口设备名称 */ #define BUF_SIZE (256) /* 串口接收消息结构*/ struct rx_msg { //rt_device_t dev; //rt_size_t size; char buffer[BUF_SIZE + 1]; rt_size_t size; }; /* 串口设备句柄 */ static rt_device_t serial; /* 消息队列控制块 */ static struct rt_messagequeue* rx_mq; /* 接收数据回调函数 */ static rt_err_t uart_input(rt_device_t dev, rt_size_t size) { struct rx_msg msg; rt_err_t result; //msg.dev = dev; //msg.size = size; msg.size = rt_device_read(dev, 0, msg.buffer, BUF_SIZE); result = rt_mq_send(rx_mq, (void*)&msg, sizeof(msg)); rt_kprintf("mlen %d\n", size); if ( result == -RT_EFULL) { /* 消息队列满 */ rt_kprintf("message queue full!\n"); } return result; } static void serial_thread_entry(void *parameter) { struct rx_msg msg; rt_err_t result; //rt_uint32_t rx_length; //static char rx_buffer[BUF_SIZE + 1]; rt_kprintf("start serial thread\n"); while (1) { rt_memset(&msg, 0, sizeof(msg)); /* 从消息队列中读取消息*/ result = rt_mq_recv(rx_mq, (void*)&msg, sizeof(msg), 5);//RT_WAITING_FOREVER); if (result == RT_EOK) { /* 从串口读取数据*/ //rx_length = rt_device_read(msg.dev, 0, rx_buffer, msg.size); //rx_buffer[rx_length] = '\0'; msg.buffer[msg.size] = '\0'; /* 通过串口设备 serial 输出读取到的消息 */ //debug_pin_on(); //rt_device_write(serial, 0, rx_buffer, rx_length); rt_device_write(serial, 0, msg.buffer, msg.size); //debug_pin_off(); /* 打印数据 */ rt_kprintf("%s\n",msg.buffer); } } } static rt_err_t uart_tx_finish(rt_device_t dev, void *buffer) { rt_kprintf("message tx finish!\n"); return RT_EOK; } int uart_dma_sample(void) { rt_err_t ret = RT_EOK; char uart_name[RT_NAME_MAX]; char str[] = "hello RT-Thread!\r\n"; struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT; rt_strncpy(uart_name, SAMPLE_UART_NAME, RT_NAME_MAX); /* 查找串口设备 */ serial = rt_device_find(uart_name); if (!serial) { rt_kprintf("find %s failed!\n", uart_name); return RT_ERROR; } /* 初始化消息队列 */ rx_mq = rt_mq_create("rx_mq", sizeof(struct rx_msg), 3, RT_IPC_FLAG_PRIO); config.baud_rate = BAUD_RATE_115200; config.data_bits = DATA_BITS_8; config.stop_bits = STOP_BITS_1; config.bufsz = BUF_SIZE; config.parity = PARITY_NONE; rt_device_control(serial, RT_DEVICE_CTRL_CONFIG, &config); /* 以 DMA 接收及轮询发送方式打开串口设备 */ rt_device_open(serial, RT_DEVICE_FLAG_DMA_RX|RT_DEVICE_FLAG_INT_TX);//RT_DEVICE_FLAG_DMA_RX); /* 设置接收回调函数 */ rt_device_set_rx_indicate(serial, uart_input); rt_device_set_tx_complete(serial, uart_tx_finish); /* 发送字符串 */ rt_device_write(serial, 0, str, (sizeof(str) - 1)); /* 创建 serial 线程 */ rt_thread_t thread = rt_thread_create("serial", serial_thread_entry, RT_NULL, 1024, 25, 10); /* 创建成功则启动线程 */ if (thread != RT_NULL) { rt_thread_startup(thread); } else { ret = RT_ERROR; } return ret; } /* 导出到 msh 命令列表中 */ MSH_CMD_EXPORT(uart_dma_sample, uart device dma sample); void uart_task(void) { uart_dma_sample(); } ```
查看更多
3
个回答
默认排序
按发布时间排序
出出啊
2022-08-17
恃人不如自恃,人之为己者不如己之自为也
`rx_mq = rt_mq_create("rx_mq", sizeof(struct rx_msg), 3, RT_IPC_FLAG_PRIO);` 你这个消息队列池,只有一个消息体大小的内存容量,但是你还想用仨。绝对会内存溢出。 [rt-thread 使用宝典(2022-0802更新)](https://club.rt-thread.org/ask/article/2460fcd7db4821ae.html) 这里有用法陷阱提醒。
jizhongbiao
2022-08-17
这家伙很懒,什么也没写!
是怎么确定线程没被唤醒的?在if那里打断点了吗,如果是随机暂停整个线程只有这个5ms阻塞比较耗时,大概率停在这里,看起来就像是一直卡在这里。
QQSN_9927
2022-08-17
这家伙很懒,什么也没写!
问题找到了,对比了教程的代码,我在串口初始化时,增加了RT_DEVICE_FLAG_INT_TX,只要加上,就会出现上面的问题。我直接用教程的代码,也加上RT_DEVICE_FLAG_INT_TX,也有这个问题。应该是一个系统层面的bug,我另外开个贴报告一下。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.6k
关于作者
QQSN_9927
这家伙很懒,什么也没写!
提问
6
回答
5
被采纳
0
关注TA
发私信
相关问题
1
rt_object_init中报assertion failed错误?
2
在 MDK中的NANO 里创建消息队列失败,内存堆已开启
3
如何用消息队列传递结构体数据
4
消息队列满了以后接收乱码
5
消息队列传输不定长数据
6
使用消息队列在线程中发送总失败
7
初始化第二个消息队列时发生硬件错误
8
rtthread消息队列一对多的情况
9
消息队列为什么会出现获取到的内容有旧的数据?
10
通过消息队列名称,获取消息队列句柄
推荐文章
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
在RT-Thread Studio中构建前执行python命令
2
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
3
CherryUSB开发笔记(一):FSDEV USB IP核的 HID Remote WakeUp (USB HID 远程唤醒) 2025-01-18 V1.1
4
RT-thread 缩写字典
5
RT Thread 源码分析笔记 :线程和调度器
热门标签
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
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
聚散无由
2
篇文章
14
次点赞
catcatbing
2
篇文章
4
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
4
次点赞
xiaorui
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部