Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
workqueue_工作队列
_workqueue_submit_work 函数有概率返回-RT_EBUSY
发布于 2022-03-28 23:39:50 浏览:614
订阅该版
``` static rt_err_t _workqueue_submit_work(struct rt_workqueue *queue, struct rt_work *work, rt_tick_t ticks) { rt_base_t level; rt_err_t err; level = rt_hw_interrupt_disable(); /* remove list */ rt_list_remove(&(work->list)); work->flags &= ~RT_WORK_STATE_PENDING; /* */ if (ticks == 0) { if (queue->work_current != work) { rt_list_insert_after(queue->work_list.prev, &(work->list)); work->flags |= RT_WORK_STATE_PENDING; work->workqueue = queue; err = RT_EOK; } else { err = -RT_EBUSY; } /* whether the workqueue is doing work */ if (queue->work_current == RT_NULL && ((queue->work_thread->stat & RT_THREAD_STAT_MASK) == RT_THREAD_SUSPEND)) { /* resume work thread */ rt_thread_resume(queue->work_thread); rt_hw_interrupt_enable(level); rt_schedule(); } else { rt_hw_interrupt_enable(level); } return err; } else if (ticks < RT_TICK_MAX / 2) { /* Timer started */ if (work->flags & RT_WORK_STATE_SUBMITTING) { rt_timer_stop(&work->timer); rt_timer_control(&work->timer, RT_TIMER_CTRL_SET_TIME, &ticks); } else { rt_timer_init(&(work->timer), "work", _delayed_work_timeout_handler, work, ticks, RT_TIMER_FLAG_ONE_SHOT | RT_TIMER_FLAG_SOFT_TIMER); work->flags |= RT_WORK_STATE_SUBMITTING; } work->workqueue = queue; /* insert delay work list */ rt_list_insert_after(queue->delayed_list.prev, &(work->list)); rt_hw_interrupt_enable(level); rt_timer_start(&(work->timer)); return RT_EOK; } rt_hw_interrupt_enable(level); return -RT_ERROR; } ``` 在调试wlan框架时,频繁的wifi断线重连,可能会使某些wlan事件在执行到 _workqueue_submit_work函数时返回-RT_EBUSY,此时会打印如下日志 ![微信截图_20220328233729.png](https://oss-club.rt-thread.org/uploads/20220328/7e268857b8f138621897a21bb77d3d0f.png) 经测试,可能是因为 queue->work_current 会在执行完work函数后才会清空,如果在任务函数内 free 相应的work对象,之后线程进行调度,在别的线程中重新执行malloc申请work对象内存,有概率会使得 if (queue->work_current != work) 判断条件不成立,因而返回 -RT_EBUSY 错误码
查看更多
1
个回答
默认排序
按发布时间排序
出出啊
2022-03-29
恃人不如自恃,人之为己者不如己之自为也
`_workqueue_submit_work` 返回 BUSY 是正常的。 所以要求上层调用它的时候要判断返回值,如果是 BUSY 那就稍微延时一会儿再次尝试调用。 如果使用者没注意这个问题,那就是使用者代码逻辑有漏洞
撰写答案
登录
注册新账号
关注者
0
被浏览
614
关于作者
qqjmk15263
这家伙很懒,什么也没写!
提问
5
回答
1
被采纳
0
关注TA
发私信
相关问题
1
system workqueue stack
2
workqueue代码疑问
3
DeviceDrivers中未见workqueue的配置
4
无法使用workqueue
5
rt_wqueue_wakeup每执行一次只能唤醒等待队列中的一个线程?
6
rt-thread work queue 延时较大
7
我用工作队列时经常报错
8
workqueue、waitqueue等有demo或者使用指南吗?
9
workqueue工作项生命周期
10
workqueue的问题讨论
推荐文章
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
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部