Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
SPI
外部中断
workqueue_工作队列
rt-thread work queue 延时较大
发布于 2021-08-05 21:04:19 浏览:989
订阅该版
[tocm] ## 问题描述 rt-thread workqueue 从中断触发到执行有2~3ms 延时,不知是哪里问题? ## 问题细节: s0: 工作队列优先级: 已经试最高 ```c thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- thd_spi3 5 suspend 0x00000090 0x00000800 24% 0x00000001 000 thd_spi2 5 suspend 0x00000090 0x00000800 25% 0x00000001 000 thd_spi1 5 suspend 0x00000090 0x00000800 24% 0x00000001 000 thd_spi0 5 suspend 0x00000090 0x00000800 34% 0x00000001 000 spi_wq 1 suspend 0x00000148 0x00001000 09% 0x00000007 000 // 工作队列优先级 最高是中断 thd_card 5 suspend 0x000000e8 0x00000400 36% 0x00000001 000 thd_jsd 5 suspend 0x000000a0 0x00000400 38% 0x00000001 000 thd_xsd 5 suspend 0x000000a0 0x00000400 40% 0x00000001 000 thd_bee 4 suspend 0x000000a4 0x00000400 16% 0x00000001 000 thd_lcd 5 suspend 0x000000cc 0x00000400 32% 0x00000001 000 tshell 20 ready 0x00000220 0x00000c18 17% 0x00000002 000 tidle 31 ready 0x00000048 0x00000100 40% 0x00000007 000 main 10 suspend 0x0000010c 0x00000800 30% 0x00000013 000 ``` 日志测试时间: ```c void drv_spi_irq_rx_work(struct rt_work *work, void *work_data) { uint8_t sbuf_size = 0; struct spi_work_data *spi_data = NULL; spi_data = (struct spi_work_data *)work_data; LOG_D("rx s0"); /* s0:提取数据 */ sbuf_size = app_data_queue_size(SPI0_S + spi_data->port * 2); if (sbuf_size > 0) { LOG_D("rx s1"); uint8_t *s_pac = app_data_queue_pop(SPI0_S + spi_data->port * 2); /* s1: 发送数据: 此处存在 dma_sem 管理发送完成才会退出函数 */ app_spi_transfer(spi_data->port, &(port_ant[spi_data->port].ant_spi), s_pac, port_ant[spi_data->port].rpac, ANT_SPI_LEN); /* s2: 回收数据 */ app_data_queue_push(IDLE_E, s_pac); /* s3: 数据发送完成继续扫描数据 */ if (app_data_queue_size(SPI0_S + spi_data->port * 2) == 0) { rt_sem_release(&(port_ant[spi_data->port].scan_lock)); } LOG_D("rx s2"); } else { LOG_D("tx rx"); app_spi_transfer(spi_data->port, &(port_ant[spi_data->port].ant_spi), port_ant[spi_data->port].spac, port_ant[spi_data->port].rpac, ANT_SPI_LEN); } /* 解析数据 */ // app_dtq_rcmd_decode(&port_ant[spi_data->port], \ (spi_pac_t *)(port_ant[spi_data->port].rpac)); } ``` ``` [534518]: isr rx 接收中断时间 [534521]: rx s0 工作队列函数开始时间 [534521]: rx s1 [534522]: rx s2 ``` 实际测量测试时隙: **SPI_FIFO 是从机控制的管脚,主机配置为上升沿中断,有数据上报拉高,数据读走后拉低** ![6CDECDBF-A2C6-4c53-9D69-9889D26D1EE7.png](https://oss-club.rt-thread.org/uploads/20210805/9ba41942af917a22f7dfd691455cde46.png.webp)
查看更多
2
个回答
默认排序
按发布时间排序
mysterywolf
认证专家
2021-08-06
https://github.com/mysterywolf
workqueue 的性质就是这样的,你不可以把实时性有要求的任务放在workqueue中
aozima
2021-08-06
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
这个workqueue队列里面是否还有其它任务? workqueue是一个一个任务往下执行的,所以不适合实时任务,只适合一些如OTA检查等任务。 你可以用一个独立的新高优先级来测试,并把优先级调到最高。
撰写答案
登录
注册新账号
关注者
0
被浏览
989
关于作者
懒洋洋
这家伙很懒,什么也没写!
提问
9
回答
0
被采纳
0
关注TA
发私信
相关问题
1
BBB的SPI驱动
2
求个SPI上挂两个或多个设备的使用例子
3
SPI设备有个bug
4
spi flash 的fatfs使用一段时间后读写文件出现故障
5
SPI驱动
6
请教rt_spi_configure函数理解
7
SPI FLASH挂载的问题
8
SPI-FLASH 文件系统 SPIFFS
9
求助一个完整的 spi flash 驱动
10
关于同时使用文件系统与SPI FLASH的问题
推荐文章
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
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部