Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
completion完成量
完成量等待代码执行太慢,而中断发送太快导致完成量提前完成怎么办?
发布于 2024-06-20 22:28:40 浏览:334
订阅该版
[tocm] ### 重新讨论 - 这里不小心已采纳,无法修改了;重新开一个话题 > https://club.rt-thread.org/ask/question/3ae041fe0cf2ea1a.html - 在调试STM32 硬件I2C驱动,使用中断方式收发I2C数据 - 代码在bsp\stm32\libraries\HAL_Drivers\drivers\drv_hard_i2c.c中,以下是简洁代码 ```c //发送I2C数据,使用中断方式 static rt_ssize_t stm32_i2c_master_xfer(struct rt_i2c_bus_device *bus, struct rt_i2c_msg msgs[], rt_uint32_t num) { HAL_GPIO_WritePin(GPIOA, DEBUG_IO_Pin, GPIO_PIN_SET); HAL_I2C_Master_Seq_Receive_IT(handle,(msg->addr<<1), msg->buf, msg->len, mode); if (rt_completion_wait(completion, timeout) != RT_EOK) { LOG_D("transmit time out"); goto out; } } //中断回调中 void HAL_I2C_MasterRxCpltCallback(I2C_HandleTypeDef *hi2c) { HAL_GPIO_WritePin(GPIOA, DEBUG_IO_Pin, GPIO_PIN_RESET); struct stm32_i2c *i2c_drv = rt_container_of(hi2c, struct stm32_i2c, handle); rt_completion_done(&i2c_drv->completion); } ``` - 发现永远打印I2C传输超时,调整timeout时间怎么调大都没用; - 打断点调试发现,rt_completion_wait执行到一半时,中断就已经触发了rt_completion_done;导致永远是超时的; ```c rt_err_t rt_completion_wait(struct rt_completion *completion, rt_int32_t timeout) { rt_err_t result; rt_base_t level; rt_thread_t thread; RT_ASSERT(completion != RT_NULL); //! 这里就触发中断了 RT_DEBUG_SCHEDULER_AVAILABLE(timeout != 0); } ``` - 问题来了,这应该改驱动代码还是完成量代码? - 是完成量wait代码添加中断屏蔽呢?还是驱动中发送前后添加中断屏蔽? - 我在RX和RX完成回调中加入IO高低电平;查看是否配置有问题; 可以看到RX发送地址前电平为低; 发送开始时电平拉高 接收回调中拉低电平; 时序是满足I2C的; 观察电平持续时间为不到1ms; ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240620/a44b16ecd115e4d9d421d866b85b1369.png.webp) - 可以证明完成量是没法满足运行至挂起线程,就已经进入RX回调中断了; ### 有没有什么好方式? - 加入中断屏蔽在RX发送前后也没有用 - 完成量代码中注释判断是否在中断中的代码还是在调度前进入中断回调触发了这个完成量 - 只能用全局变量了?
查看更多
2
个回答
默认排序
按发布时间排序
张世争
2024-06-21
学以致用
I2C 中断发送方式是个什么方式?没有阻塞式的发送接口吗?
用户名由3_15位
2024-06-24
这家伙很懒,什么也没写!
- 顶一下
撰写答案
登录
注册新账号
关注者
1
被浏览
334
关于作者
用户名由3_15位
这家伙很懒,什么也没写!
提问
63
回答
240
被采纳
33
关注TA
发私信
相关问题
1
scons编译提示没找到adc.h文件
2
rt_completion_wait 使用
3
rtthread中的completion.c是用来干什么的?
4
Can 发送卡在rt_completion_wait函数
5
rt_completion_wait不能用在ISR里
6
completion使用问题
7
2.1.0版本UART发送完成,和dma用到的queue和rt_completion_init问题
8
completion,dataqueue,waitqueue等文件的使用说明在哪?
9
完成量的使用,rt_completion_done()函数可以在中断里调用吗?
10
rt_completion_wait函数clash问题
推荐文章
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项目助手v0.2.0 - 支持Env Windows
2
RttreadV5.10上,GD32F450Z RTC时间显示问题
3
rt-smart启动流程分析
4
EtherKit快速上手PROFINET
5
RTThread USB转串口无法接收数据
热门标签
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
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
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部