Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
DMA
UART
Hardfault
STM32F207ZE UART2 DMA 接收存在问题
发布于 2021-11-03 10:56:55 浏览:1010
订阅该版
RT-Thread Studio 版本: 2.1.2 RT-Thread 4.0.3 按照https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/programming-manual/device/uart/uart_v1/uart 文档中描述的,使用uart2 dma 接收数据,但是每次调用rt_device_open会出现错误 ``` psr: 0x01000000 r00: 0x2000121c r01: 0x00000200 r02: 0x0800f210 r03: 0x12ab9cba r04: 0xdeadbeef r05: 0xdeadbeef r06: 0xdeadbeef r07: 0x20002fd0 r08: 0xdeadbeef r09: 0xdeadbeef r10: 0xdeadbeef r11: 0xdeadbeef r12: 0x00000000 lr: 0x08008ab9 pc: 0x08008f7c hard fault on thread: tshell thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- tshell 20 running 0x000000c8 0x00001000 10% 0x00000008 000 tidle0 31 ready 0x00000070 0x00000100 43% 0x00000009 000 timer 4 suspend 0x0000007c 0x00000200 24% 0x00000009 000 main 10 suspend 0x000000bc 0x00000800 14% 0x00000013 000 bus fault: SCB_CFSR_BFSR:0x82 PRECISERR SCB->BFAR:12AB9CBA ``` 原因是调用DMA_CalcBaseAndBitshift的时候hdma->Instance为空导致的 代码如下 ```c #include
static char hello[] = "hello rtthread!\n"; #define SAMPLE_UART_NAME "uart2" static rt_device_t serial_port = RT_NULL; static struct rt_messagequeue rx_mq; struct rx_msg { rt_device_t dev; rt_size_t size; }; static void serial_thread_entry(void* parameter) { struct rx_msg msg; rt_err_t result; rt_uint32_t rx_length; static char rx_buffer[RT_SERIAL_RB_BUFSZ + 1]; while(1) { rt_memset(&msg, 0, sizeof(msg)); result = rt_mq_recv(&rx_mq, &msg, sizeof(msg), 0); if(RT_EOK == result) { rx_length = rt_device_read(msg.dev, 0, rx_buffer, msg.size); rx_buffer[rx_length] = '\0'; /* 打印数据 */ //rt_kprintf("%s\n",rx_buffer); } } } static rt_err_t uart_input(rt_device_t dev, rt_size_t size) { struct rx_msg msg; rt_err_t result = RT_EOK; msg.dev = dev; msg.size = size; result = rt_mq_send(&rx_mq, &msg, sizeof(msg)); if(result == -RT_EFULL) { //rt_kprintf("message queue full!\n"); } return result; } static int dma_uart_sample(void) { rt_err_t result = RT_EOK; static char msg_pool[256]; serial_port = rt_device_find(SAMPLE_UART_NAME); if(serial_port == RT_NULL){ rt_kprintf("find %s failed!\n", SAMPLE_UART_NAME); return RT_ERROR; } /* 初始化消息队列 */ rt_mq_init(&rx_mq, "rx_mq", msg_pool, sizeof(struct rx_msg), sizeof(msg_pool), RT_IPC_FLAG_FIFO); rt_device_set_rx_indicate(serial_port, uart_input); result = rt_device_open(serial_port, RT_DEVICE_FLAG_DMA_RX); if(RT_EOK != result)return result; rt_thread_t thread = rt_thread_create("serial", serial_thread_entry, RT_NULL, 1024, 25, 10); if(RT_NULL == thread) { result = RT_ERROR; } else { rt_thread_startup(thread); } return result; } /* 导出到 msh 命令列表中 */ MSH_CMD_EXPORT(dma_uart_sample, uart device dma sample); ``` board.h中配置如下 ```c #define BSP_UART2_RX_USING_DMA //#define BSP_UART2_TX_USING_DMA #define BSP_USING_UART1 #define BSP_UART1_TX_PIN "PA9" #define BSP_UART1_RX_PIN "PA10" #define BSP_USING_UART2 #define BSP_UART2_TX_PIN "PA2" #define BSP_UART2_RX_PIN "PA3" ``` rtconfig.h中也已经打开了 使用uart dma功能 请帮忙分析问题出现在哪里,谢谢
查看更多
5
个回答
默认排序
按发布时间排序
kid
2021-11-03
这家伙很懒,什么也没写!
```c static char msg_pool[256]; ``` 这一句放到文件的最上面, 提示tshell 错误, 大概率是堆栈不足导致了, 而且 msh_cmd_export 宏定义使用的函数, 建议格式如下 ```c int demo(int argc, char **argv) { } ```
xiaomo1527
2021-11-03
这家伙很懒,什么也没写!
感谢回复,按照你说的尝试了,没有作用 我自己仿真跟踪了一下,调用stm32_dma_config函数,然后`if (HAL_DMA_DeInit(DMA_Handle) != HAL_OK)`,然后进入`DMA_CalcBaseAndBitshift`函数, ```c uint32_t stream_number = (((uint32_t)hdma->Instance & 0xFFU) - 16U) / 24U; ``` 这个stream_number值会很大,导致数组越界,但是`hdma->Instance`这个值究竟在那里赋值,我在源码中没有找到
李肯陪你玩赚嵌入式
认证专家
2021-11-03
2022年度和2023年度RT-Thread社区优秀开源布道师,COC深圳城市开发者社区主理人,专注于嵌入式物联网的架构设计
查了下4.0.3的源码: ![image.png](https://oss-club.rt-thread.org/uploads/20211103/a8815255fe5e70392ce68412c621012e.png.webp) 如图quan圈起来的地方就是对DMA的Instance进行设值。 ![image.png](https://oss-club.rt-thread.org/uploads/20211103/79c5ed1c594fc3819b48de5ea9993f67.png.webp) hdma就等于DMA_Handle
出出啊
2021-11-03
恃人不如自恃,人之为己者不如己之自为也
在调用 `rt_device_open` 之前内存已经被污染了, ``` if (RT_DEVICE_FLAG_DMA_RX == flag) { DMA_Handle = &uart->dma_rx.handle; dma_config = uart->config->dma_rx; } ``` 这一句,看 uart 这个结构体的内存,或者更广泛些,追查 uart_obj 这个全局静态变量的内容。 我文章里的“系统调试利器” 可以尝试一下。 几个重要的查看节点。 uart_obj 数组初始化完成;stm32_dma_config 进入之后;`if (HAL_DMA_DeInit(DMA_Handle) != HAL_OK)` 之前。 大胆预测,第一次打印出来的和后面两次有很大区别。
fxman
2024-07-02
这家伙很懒,什么也没写!
感谢前面同学们的讨论,问题已解决。如上面所说确实是没有赋值 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240702/ec00dee838ca3847038cea98f63a8415.png) 导致的,在dev_uart.c中,添加|| defined(SOC_SERIES_STM32F2)即可,如下图 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20240702/75cbc59f9f8d61782e74552a968fd896.png.webp)
撰写答案
登录
注册新账号
关注者
0
被浏览
1k
关于作者
xiaomo1527
这家伙很懒,什么也没写!
提问
1
回答
1
被采纳
0
关注TA
发私信
相关问题
1
RTT1.0,STM32调试时会跑到HardFault【已解决】,出现新问题
2
新手请教关于hardfault怎么查
3
github最新版本库中stm32f0X分支,运行切换任务时候出现hardfault[已解决]
4
实现iap功能,bootloader使用了rtt操作系统,在跳转到app代码的时候提示出现hardfault的问题
5
ymodem在on_begin内发送can无法断开连接,而且RTT会报hardfault
6
挂载UFFS文件系统执行到退出_BuildTreeStepOne函数时hardfault异常
7
STM32F1+RTT串口接收中断进入hardfault
8
STM32F746NG随机进入hardfault(已解决)
9
[已解决]自已建了个STM32F103的MDK工程,初始化时总是进入HardFault,求教!
10
将 Cortex M3 的 hardfault 处理与 M4、M7、M0 保持一致?
推荐文章
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
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
次被采纳
本月文章贡献
程序员阿伟
8
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
3
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部