Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
bug
IPC
rt_event_事件集
5
懵逼了,rt_event_recv设置RT_WAITING_FOREVER却直接返回,recved居然是入参set值
发布于 2024-08-26 15:47:06 浏览:185
订阅该版
rt-thread版本4.1.1 在一个thread中使用rt_event_recv接收在中断中发出的event, ```c if (rt_event_recv(&event, (FLAG(FB_OverCurrent) | FLAG(FB_ROverCurrent) | FLAG(FB_OverTemp) | FLAG(FB_Scram)), RT_EVENT_FLAG_OR|RT_EVENT_FLAG_CLEAR, RT_WAITING_FOREVER, &e) == RT_EOK) ``` 收到一次正常`event(FLAG(FB_OverCurrent))`后一直连续收到异常event,值为`(FLAG(FB_OverCurrent) | FLAG(FB_ROverCurrent) | FLAG(FB_OverTemp) | FLAG(FB_Scram))`直到程序死掉,而此时`event->set`值其实际0,进入`rt_event_recv`调试发现走到了以下代码分支中: ```c else { /* fill thread event info */ thread->event_set = set; thread->event_info = option; /* put thread to suspended thread list */ _ipc_list_suspend(&(event->parent.suspend_thread), thread, event->parent.parent.flag); /* if there is a waiting timeout, active thread timer */ if (timeout > 0) { /* reset the timeout of thread timer and start it */ rt_timer_control(&(thread->thread_timer), RT_TIMER_CTRL_SET_TIME, &timeout); rt_timer_start(&(thread->thread_timer)); } /* enable interrupt */ rt_hw_interrupt_enable(level); /* do a schedule */ rt_schedule(); if (thread->error != RT_EOK) { /* return error */ return thread->error; } /* received an event, disable interrupt to protect */ level = rt_hw_interrupt_disable(); /* set received event */ if (recved) *recved = thread->event_set; } ``` 这里面开头`thread->event_set = set`; 结尾`*recved = thread->event_set`; 等于是把入参`set`赋给`rt_event_recv`的接收值e了,为什么会有这样这样的操作? 想知道这段分支代码是在干嘛? 该如何debug我遇到的这问题?望大佬们赐教! 进一步到rt_schedule里发现 ```c if (rt_thread_ready_priority_group != 0) ``` 这个分支没进入就直接返回了,所以*recved直接就变成set的值了,仍需进一步排查。
查看更多
2
个回答
默认排序
按发布时间排序
sync
2024-08-27
这家伙很懒,什么也没写!
官方文档有[事件集应用示例](https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/ipc1/ipc1?id=%e4%ba%8b%e4%bb%b6%e9%9b%86%e5%ba%94%e7%94%a8%e7%a4%ba%e4%be%8b "事件集应用示例"),先跑通了再看自己的代码吧
rv666
认证专家
2024-08-27
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
一直等待走这个分支是没有问题的 想知道为啥这么设置 你的看一下发送的源码 找到修改event的地方 发送与接收一起看就明白了
撰写答案
登录
注册新账号
关注者
1
被浏览
185
关于作者
guyqqcom
这家伙很懒,什么也没写!
提问
5
回答
2
被采纳
1
关注TA
发私信
相关问题
1
rt_thread事件某位如何置0,如何简单获取某位状态
2
有单独清除事件标志的函数么?
3
rt_event事件问题
4
事件集的选择清除重置事件标志位
5
Nano 内核FinSH 的 list_event 查询问题
6
Nano 初始化两次 event,使用list_event 导致的问题
7
关于事件集和邮箱那一块
8
rt-thread事件集多线程接收的一个疑问?
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】记录一次对主仓的bsp进行修复并提交pr的总结
2
【请投票】嵌入式大赛Top10排名等你来选!
3
【24嵌入式设计大赛】HPM5300-EVK 网络测速仪
4
RT-Thread Nano 上线ST CubeMX
5
Nordic移植笔记: RT_Thread v5.1.0(基于Nordic nRF52840的ble_app_hids_mouse工程)
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
ART-Pi
FinSH
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
ESP8266
I2C_IIC
WIZnet_W5500
ota在线升级
UART
flash
packages_软件包
cubemx
PWM
freemodbus
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
socket
flashDB
中断
Debug
编译报错
msh
rt_mq_消息队列_msg_queue
keil_MDK
C++_cpp
ulog
at_device
SFUD
本月问答贡献
出出啊
1515
个答案
342
次被采纳
小小李sunny
1438
个答案
289
次被采纳
张世争
786
个答案
168
次被采纳
crystal266
546
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
6
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
2
次点赞
crystal266
2
篇文章
1
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部