Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
completion完成量
rt_completion_wait函数clash问题
发布于 2024-06-17 17:54:08 浏览:249
订阅该版
求助大佬,我的程序小概率会clash,定位发现是在rt_completion_wait函数中,没想明白这个函数为什么会clash,附件中附上clash信息。 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240617/6fbb168430d7081f98162c95932205d1.png) 我的程序很简单,我在一个中断回调函数中发送完成量,然后在一个线程中等待完成量。下面是我的代码: ```c /* gpio中断回调函数 */ void handshake_call(void *args) { rt_kprintf("esp32 handshake call!\n"); rt_completion_done(&completion); } static void spi2_master_thread_entry(void *parameter) { CODE_PROTEC(chip_id_str, PASSWORD_STR, true); while (1) { switch (e_spi_read) { case SPI_READ_WAIT: { LOG_D("wait spi handshake"); rt_completion_wait(&completion, RT_WAITING_FOREVER); e_spi_read = SPI_READ_FLAG; } break; case SPI_READ_FLAG: { memset(spi_recv_buff, 0, SPI_RECV_SIZE); rt_size_t ret = rt_spi_recv(spi2_dev, spi_recv_buff, sizeof(struct data_info)); memcpy(&g_data_info, spi_recv_buff, ret); LOG_D("spi recv data info, ret = %d data len = %d", ret, g_data_info.data_len); e_spi_read = SPI_READ_DATA; } break; case SPI_READ_DATA: { memset(spi_recv_buff, 0, SPI_RECV_SIZE); rt_size_t ret = rt_spi_recv(spi2_dev, spi_recv_buff, g_data_info.data_len); LOG_D("spi recv data, ret = %d", ret); if((memcmp(spi_recv_buff, end_sign, 8) == 0) && (ret <= 10)) { LOG_D("The receiving file is completed! last len = %d", ret); // 如果是文件结束标志 fpga_data_src = WRITE_FPGA_SPI; write_fpga_data_process(); } else { // 把接收到的数据放到缓冲区中 rt_ringbuffer_put(write_fpga_rb, spi_recv_buff, ret); } e_spi_read = SPI_READ_WAIT; } break; default: break; } rt_thread_mdelay(1); } } void spi2_master_init(void) { struct rt_spi_device *spi_device = RT_NULL; spi_device = (struct rt_spi_device *)rt_malloc(sizeof(struct rt_spi_device)); if(RT_NULL == spi_device) { LOG_E("Failed to malloc the spi device."); } if (RT_EOK != rt_spi_bus_attach_device_cspin(spi_device, "spi20", "spi2", GET_PIN(B, 9), RT_NULL)) { LOG_E("Failed to attach the spi device."); } struct rt_spi_configuration cfg; cfg.data_width = 8; cfg.mode = RT_SPI_MASTER | RT_SPI_MODE_0 | RT_SPI_MSB; cfg.max_hz = 20 * 1000 *1000; rt_spi_configure(spi_device, &cfg); /* 查找 spi 设备获取设备句柄 */ spi2_dev = (struct rt_spi_device *)rt_device_find("spi20"); // 向FPGA写数据的缓冲区 spi_recv_buff = rt_malloc(SPI_RECV_SIZE); if (spi_recv_buff == RT_NULL) { rt_kprintf("No memory:spi_recv_buff\n"); return; } /* 创建线程 */ rt_thread_t spi2_master_tid = rt_thread_create("spi2_master", spi2_master_thread_entry, RT_NULL, 1024, 3, 5); if (spi2_master_tid != RT_NULL) rt_thread_startup(spi2_master_tid); else LOG_E("spi2_master thread creation failed!"); /* 初始化完成量对象 */ rt_completion_init(&completion); /* 握手信号 */ rt_pin_mode(PIN_HANDSHAKE, PIN_MODE_INPUT_PULLUP); rt_pin_attach_irq(PIN_HANDSHAKE, PIN_IRQ_MODE_RISING, handshake_call, RT_NULL); rt_pin_irq_enable(PIN_HANDSHAKE, PIN_IRQ_ENABLE); } ``` - [clash_log.txt](https://club.rt-thread.org/file_download/bdbb6a5064fda3eb)
查看更多
1
个回答
默认排序
按发布时间排序
IWWW_8128
2024-06-17
这家伙很懒,什么也没写!
我好像知道是什么原因了,我先创建了线程,调用了rt_completion_wait,然后才调用rt_completion_init
撰写答案
登录
注册新账号
关注者
0
被浏览
249
关于作者
IWWW_8128
这家伙很懒,什么也没写!
提问
2
回答
1
被采纳
0
关注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
完成量等待代码执行太慢,而中断发送太快导致完成量提前完成怎么办?
推荐文章
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
如何在master上的BSP中添加配置yml文件
2
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
3
RT-Thread 发布 EtherKit开源以太网硬件!
4
rt-thread使用cherryusb实现虚拟串口
5
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
热门标签
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
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
ulog
C++_cpp
at_device
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
13
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
9
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
5
次点赞
RTT_逍遥
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部