Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
DMA
UART
5
UART DMA接收报错
发布于 2021-04-08 15:43:58 浏览:1265
订阅该版
大家好,我在测试uart dma接收功能时,出现了下列现象,查找论坛资料,没有解决,请教一下串口dma接收的正确用法。 RTT4.0.3 / stm32f103re 依据bsp模板,新建核心板bsp,只添加了串口功能(中断接收模式收发正常) 测试代码: ```c // drv_usart.c result = rt_hw_serial_register(&uart_obj[i].serial, uart_obj[i].config->name, RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX | RT_DEVICE_FLAG_INT_TX | RT_DEVICE_FLAG_DMA_RX // 添加DMA收发 | RT_DEVICE_FLAG_DMA_TX | uart_obj[i].uart_dma_flag , NULL); ``` ```c #include
#define LOG_TAG "app.uart" #define LOG_LVL LOG_LVL_DBG //#define LOG_LVL LOG_LVL_INFO #include
#define DEVICE_UART2 "uart2" #define THREAD_PRIORITY 25 #define THREAD_STACK_SIZE 512 #define THREAD_TIMESLICE 10 static rt_device_t dev_uart2_handle; static struct rt_messagequeue u2_mq; static struct rt_thread u2_thread; static rt_uint8_t u2_thread_stack[THREAD_STACK_SIZE]; typedef struct uart_rx_msg { rt_device_t dev; rt_size_t size; }uart_rx_msg_t; static rt_err_t u2_uart_input(rt_device_t dev, rt_size_t size) { uart_rx_msg_t msg; rt_err_t ret; msg.dev = dev; msg.size = size; ret = rt_mq_send(&u2_mq, &msg, sizeof(msg)); if(ret == -RT_EFULL) { //LOG_W("mq full...\r\n"); } return ret; } static void u2_read_thread_entry(void *para) { uart_rx_msg_t msg; rt_err_t ret; rt_uint32_t rx_length; static char rx_buf[RT_SERIAL_RB_BUFSZ + 1]; // 要根据串口初始化时 control 设置的大小调整,这里写rtt默认的串口大小 while(1) { rt_memset(&msg, 0, sizeof(uart_rx_msg_t)); rt_memset(rx_buf, 0, RT_SERIAL_RB_BUFSZ + 1); // 从消息队列读消息 ret = rt_mq_recv(&u2_mq, &msg, sizeof(msg), RT_WAITING_FOREVER); if(ret == RT_EOK) { // 从串口读取数据 rx_length = rt_device_read(msg.dev, 0, rx_buf, msg.size); rx_buf[rx_length] = '\0'; LOG_D("uart rx data, dev:%s, size:%d, data:%s\r\n", msg.dev, rx_length, rx_buf); // 解析数据 // TODO } } } static int dy_uart_send(rt_device_t dev, void* buf) { rt_err_t ret = -1; ret = rt_device_write(dev, 0, buf, rt_strlen(buf)); return ret; } static int app_uart_init(void) { rt_err_t ret = RT_EOK; static char msg_pool[256]; struct serial_configure u2config = RT_SERIAL_CONFIG_DEFAULT; // find dev_uart2_handle = rt_device_find(DEVICE_UART2); if(dev_uart2_handle == RT_NULL) { LOG_E("can't find %s device.\r\n", DEVICE_UART2); return RT_ERROR; } // mq ret = rt_mq_init(&u2_mq, "u2_rx_mq", msg_pool, // 消息缓存 sizeof(uart_rx_msg_t), // 一条消息的最大长度 sizeof(msg_pool), // 消息缓存区大小 RT_IPC_FLAG_FIFO); ASSERT(ret == RT_EOK); // control // u2config.bufsz = 128; // 修改缓冲区大小 // rt_device_control(dev_uart2_handle, RT_DEVICE_CTRL_CONFIG, &u2config); // open ret = rt_device_open(dev_uart2_handle, RT_DEVICE_FLAG_DMA_RX); // 以DMA接收及轮询发送方式打开 if(ret != RT_EOK) { LOG_E("can't open %s device. ret:%d\r\n", DEVICE_UART2, ret); } // rx callback rt_device_set_rx_indicate(dev_uart2_handle, u2_uart_input); ret = rt_thread_init(&u2_thread, "u2_rx", u2_read_thread_entry, RT_NULL, u2_thread_stack, THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE); ASSERT(ret == RT_EOK); rt_thread_startup(&u2_thread); return RT_EOK; } INIT_APP_EXPORT(app_uart_init); static void uart_send_test(void) { rt_err_t ret = -1; char str_buf[] = "uart send test.\n"; // 15+1 ret = dy_uart_send(dev_uart2_handle, str_buf); if(ret == 0) { LOG_E("uart send failed.\r\n"); } else { LOG_D("send ok. ret:%d\r\n", ret); } } MSH_CMD_EXPORT(uart_send_test, u2 send test); ``` 现象: ![uartlog.png](https://oss-club.rt-thread.org/uploads/20210408/62ba66070acb2b4032b166b7b915c118.png)
查看更多
3
个回答
默认排序
按发布时间排序
flashman2002
2021-04-08
这家伙很懒,什么也没写!
串口设置是轮训,终端,DMA模式3选1,你的串口设置不对。
mii
2021-04-08
这家伙很懒,什么也没写!
`result = rt_hw_serial_register(&uart_obj[i].serial, uart_obj[i].config->name, RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX | RT_DEVICE_FLAG_INT_TX | RT_DEVICE_FLAG_DMA_RX // 添加DMA收发 | RT_DEVICE_FLAG_DMA_TX | uart_obj[i].uart_dma_flag , NULL);` 这一部分代码你修改了?官方指导并不要求修改。 https://docs.rt-thread.org/#/rt-thread-version/rt-thread-standard/programming-manual/device/uart/uart?id=%e4%b8%b2%e5%8f%a3%e8%ae%be%e5%a4%87%e4%bd%bf%e7%94%a8%e7%a4%ba%e4%be%8b
Ka$ha
2021-04-08
这家伙很懒,什么也没写!
v5编译器数据收发正常;v6编译的固件,发数据正常,收数据报hard fault on handler错误... ![编译器.png](https://oss-club.rt-thread.org/uploads/20210408/4c1387e1f9a38c185f72c630ce46fcb4.png) ![v5编译.png](https://oss-club.rt-thread.org/uploads/20210408/906894b4f802716ee944af1ac4d0b388.png) *** 测试发现,AC6编译器`-Ofast`和`-Os`编译出的固件是可以正常工作的,`-Oz`编译运行后会提示“未对齐”错误 ![ac6优化.png](https://oss-club.rt-thread.org/uploads/20210412/3708de6240a0087cd2e33c546de84c1f.png)
撰写答案
登录
注册新账号
关注者
0
被浏览
1.3k
关于作者
Ka$ha
这家伙很懒,什么也没写!
提问
2
回答
4
被采纳
0
关注TA
发私信
相关问题
1
rt thread 2.0.2 usart 接收缓存问题
2
关于STM32串口通信的问题
3
STM32F1+RTT串口接收终端数据丢失问题
4
UART TX丢数据?
5
RTT打开串口的时候如何自定义波特率呢?
6
STM32F4的USART数据接收问题
7
串口1234使用问题
8
串口接收回调函数
9
LPC18xx UART问题讨论
10
x1000串口配置的失败问题
推荐文章
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
简单两步配置RTT源码阅读环境 vsc+clangd
2
恩智浦[FRDM-MCXN947]初探 之 ADC与DAC
3
LVGL使用字库IC芯片显示中文
4
基于STM32H750和Rt-Thread的CANFD通信实现的记录(一)
5
freemodbus主机在freertos的适配,参考rtthread例程
热门标签
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
编译报错
SFUD
msh
rt_mq_消息队列_msg_queue
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1443
个答案
289
次被采纳
张世争
805
个答案
174
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
4
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
1
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部