Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
栈stack
系统崩溃
串口输出线程输出异常
发布于 2020-11-13 09:14:32 浏览:1050
订阅该版
![问题流程.png](/uploads/20201113/7963baec6584e6680c9ce706c123f3c5.png) 芯片:STM32F429ZGT6 线程信息: ```c cmd_tx_thread = rt_thread_create("cmd_tx_thread", cmd_tx_thread_entry, &cmd_tx_thread, 1024, 6, 30); cmd_rx_thread = rt_thread_create("cmd_rx_thread", cmd_rx_thread_entry, &cmd_rx_thread, 1024, 6, 50); TQ_thread = rt_thread_create("TQ_thread", TQ_thread_entry, RT_NULL, 4096, 6, 30); YY_thread = rt_thread_create("YY_thread", YY_thread_entry, RT_NULL, 4096, 6, 30); YY_X_thread = rt_thread_create("YY_X_thread", YY_X_thread_entry, RT_NULL, 4096, 6, 30); YY_Z_thread = rt_thread_create("YY_Z_thread", YY_Z_thread_entry, RT_NULL, 4096, 6, 30); YY_Y_thread = rt_thread_create("YY_Y_thread", YY_Y_thread_entry, RT_NULL, 4096, 6, 30); YY_P_thread = rt_thread_create("YY_P_thread", YY_P_thread_entry, RT_NULL, 4096, 6, 30); TQ_X_thread = rt_thread_create("TQ_X_thread", TQ_X_thread_entry, RT_NULL, 4096, 6, 30); TQ_Z_thread = rt_thread_create("TQ_Z_thread", TQ_Z_thread_entry, RT_NULL, 4096, 6, 30); TQ_Y_thread = rt_thread_create("TQ_Y_thread", TQ_Y_thread_entry, RT_NULL, 4096, 6, 30); heat_timer = rt_thread_create("heat_timer", heat_timer_entry, RT_NULL, 512, 6, 30); heat_thread = rt_thread_create("heat_thread", heat_thread_entry, RT_NULL, 1024, 6, 30); ``` 内核堆栈信息 ```c #define RT_HEAP_SIZE 1024*32 static uint32_t rt_heap[RT_HEAP_SIZE] /*__at(0x10000000)*/; // heap default size: 4K(1024 * 4) ``` 还有一些其他的线程,就在详细列出: 指令数据都是定长16位; 所有线程优先级相同; 线程将指令处理完以后,通过 ```c void send_ack(uint8_t data_buf[16]) { data_buf[14] = XorVerify(data_buf, 1, 13); //HAL_UART_Transmit(&cmd_com, data_buf, CMD_LENGTH,100); rt_mq_send(cmd_tx_mq, data_buf, CMD_LENGTH); } ``` 唤醒指令返回线程,发送返回数据给上位机 ```c void cmd_tx_thread_entry(void *parameter) { rt_err_t uwRet; //rt_uint32_t recved; uint8_t cmd_tx[16]; while (1) { /* 从消息队列中接收要返回的数据信息 */ uwRet = rt_mq_recv(cmd_tx_mq, cmd_tx, CMD_LENGTH, RT_WAITING_FOREVER); if (uwRet == RT_EOK) { //rt_enter_critical(); HAL_UART_Transmit(&cmd_com, cmd_tx, CMD_LENGTH, 200); //rt_exit_critical(); rt_thread_mdelay(5); } } } ``` 现在遇到的问题是: 设备运行一段时间后,通过串口监控发现,通过cmd_tx_thread线程返回的数据出现断帧现象;并且此时,上位机再发送指令给主控板,下位机不再响应; MDK仿真,给指令串口打断点,发现也没有响应串口接收中断。
查看更多
张世争
2020-11-26
学以致用
* HAL_UART_Transmit,这个HAL 的超时使用的systick是否正常。(多线程的串口操作,建议用串口设备驱动) * 调试时出现这种情况,断下来,看程序卡在位置。
1
个回答
默认排序
按发布时间排序
撰写答案
登录
注册新账号
关注者
0
被浏览
1.1k
关于作者
梅江松子
这家伙很懒,什么也没写!
提问
12
回答
18
被采纳
3
关注TA
发私信
相关问题
1
局部变量的存储在哪段内存区域
2
内联函数不压栈,会因为中断导致栈内现场被破坏吗
3
idle->sp被改写,导致内存溢出
4
如何在调试状态下查看线程堆栈的占用量?
5
map文件堆栈分配查看
6
请教线程堆栈的作用以及大小设置
7
如何打印出函数调用栈
8
线程初始化时栈地址为什么加4
9
rtthread中的栈设置请教?
10
ps命令 sp栈地址问题
推荐文章
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
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部