Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
rt_event_事件集
rt_mq_消息队列_msg_queue
关于消息队列、时间的接收响应冲突问题
发布于 2022-05-23 12:16:57 浏览:1016
订阅该版
```c /*************************************************** ****系统数据处理线程 */ static void dataproc_thread_entry(void* parameter) { uint8_t i; uint8_t Sys_Mode = 0; rt_uint32_t recved; rt_err_t wret; while(1) { //等待AD转换完成事件通知,超时时间1S wret = rt_event_recv(get_addata_event,AD_DATA_EVENT,RT_EVENT_FLAG_AND|RT_EVENT_FLAG_CLEAR,1000,&recved); if(wret == RT_EOK) //-------AD转换完成事件正确接收 { dataproc_tick++; //翻转AD转换指示灯 if((dataproc_tick % 100) == 0) { DEV_LED_TOGGLE(AD_LED); } } else if(wret == (-RT_ETIMEOUT)) //-------等待AD转换完成事件超时 { PRINT_ERR("Dataproc Timeout - recved: %d \r\n",recved); } else //-------AD转换完成事件接收错误 { PRINT_ERR("Dataproc ThreadERR - sta: %d recved: %d \r\n",(uint8_t)wret,recved);; } } } /*************************************************** ****系统数据通信线程 */ static void datacomm_thread_entry(void* parameter) { uint8_t i; rt_err_t qret; rt_uint32_t recved; rt_uint8_t mqdata_buff[256]; //接收缓存区,比预定义的消息大小大一些 while(1) { // qret = rt_mq_recv(data_comm_mq,mqdata_buff,sizeof(mqdata_buff),1); //2秒超时等待,消息队列 qret = rt_event_recv(test_event,AD_DATA_EVENT,RT_EVENT_FLAG_AND|RT_EVENT_FLAG_CLEAR,2000,&recved); if(qret == RT_EOK) //接收到消息 { //PRINT_RUN("接收到消息:%s",mqdata_buff); } else if(qret == (-RT_ETIMEOUT)) //接收超时 { // PRINT_RUN("接收队列超时,发送实时数据!\r\n"); // RealtimeData_Pack(&SysSTA_Data,&SysReal_Data,mqdata_buff); // Data_Uart_SendBuff(mqdata_buff,(mqdata_buff[3]<<8)|mqdata_buff[4]); } else //接收错误 { PRINT_ERR("MQ队列接收错误: 0x%2x \r\n",(uint8_t)qret); } } } ``` 初次使用RT_thread。。版本是nano最新版本,dataproc_thread_entry任务优先级是1,datacomm_thread_entry任务优先级是3. 现象是,假如datacomm_thread_entry任务不接收任何事件通知或者消息队列,直接延迟100ms,dataproc_thread_entry任务可以每秒响应10000次AD转换完成的任务通知。 但是datacomm_thread_entry中接收任务通知或者消息队列时,dataproc_thread_entry就会受到极大的影响。不知是何原因。。
查看更多
2
个回答
默认排序
按发布时间排序
xiaosela
2022-05-23
这家伙很懒,什么也没写!
找到问题所在了。。因为之前参考的代码是动态申请内存的 rt_event_t get_addata_event;//只是初始化了指针 rt_event_init();//这个函数是静态初始化事件组的,不开启内核调试的时候,是不报错的,但是指向的内存区就是有问题的。而且简单测试时,因为内存被修改的可能性不大,还是可以工作的。 //正常的静态创建事件组结构体,应该使用下面的方式。 struct rt_event get_addata_event; 由于不太了解RT_THREAD,且自身不够细心,基础不扎实的原因,导致了这个情况的发生!希望大家引以为戒! 再者就是,前期搭建框架时,最好打开内核调试,等相关流程跑通了,再关掉也不迟!
出出啊
2022-05-23
恃人不如自恃,人之为己者不如己之自为也
https://club.rt-thread.org/ask/article/2460fcd7db4821ae.html 先搞清楚消息队列中的消息体是啥
撰写答案
登录
注册新账号
关注者
0
被浏览
1k
关于作者
xiaosela
这家伙很懒,什么也没写!
提问
1
回答
1
被采纳
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
ART-Pi2移植CMSIS-DAP(基于CherryUSB协议栈)
2
RT-thred的stm32h723对应bsp包CubeMX添加其他外设报错
3
RT-Thread中的time溢出问题,时间戳溢出,解决方法
4
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
5
SystemView线程名字不显示
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
I2C_IIC
UART
ESP8266
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
9
个答案
2
次被采纳
xiaorui
3
个答案
2
次被采纳
winfeng
2
个答案
2
次被采纳
三世执戟
8
个答案
1
次被采纳
KunYi
8
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
4
次点赞
lizimu
1
篇文章
4
次点赞
Days
1
篇文章
4
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部