近日调试一块H7的板子, 板上资源丰富,运行速度很快, 我移植了Lwip等应用,然后想简单打开一下串口, 使用DMA形式接收. 但是无论怎么设置都没有正常收发. 9 C: I+ x% z6 k3 F" V; }" ^ W4 W 可以进入回调函数, 但是接收数组内容一直是0, 就像DMA没有搬运过来一样.. x5 F4 U+ A- q6 Z& ~. h9 { 调试良久,终于通畅可以跑满串口带宽:9 M: A0 M E3 W4 {0 \& L6 n2 O - U1 w0 p, z* O# e 下面说我是怎么搞的: ' z# m, r+ w& K3 q8 d s3 o! Z 配置UART, 再cubeMX中点选我想用得uart8 , 设置波特率. 1 g A, w3 X) ? DMA选项开启. RX要启用循环模式, 这样收到一次就会再启动一次.* v' Y1 Q1 u: H. c1 Z* j ok,到这里cubeMX的配置就完了, 网上都是这么写的. 点击在CubeMX IDE 点击保存,就生成代码了.9 o1 }3 A2 S' ?2 F3 t! H 然后我在代码端再加写一些代码:$ n- M) s2 K6 a3 J/ l ! h" d/ w6 a* ]/ f# C9 N 在串口配置内, USER CODE 注释空间内添加 立刻启动接收. 接收1字节帮我DMA搬运去uart8_RXdata这个数组内. 6 K" J1 F- ]' H 下面写一个函数叫: HAL_UART_RxCpltCallback, 这个函数库函数其实已经声明好了, 就等着用户自己写逻辑, 每次串口接收完我指定的数目后就会自动进入. 进入这个回调函数后, 我就把uart8_Rxdata数据拿出来. 放去我逻辑缓冲区, 我在Freerots里面有个任务就是慢慢去解析这些数据的. 到这里没毛病. * u, u' r+ v7 z: D1 L! D/ H+ b 下面就是把Ringbuffer内的东西打印出来.) X# W2 c! ~8 Z% g 4 T0 R" t3 |5 W# V0 j' } 到这整个过程就结束了. 可是结果很糟糕, 无论我发送什么字符, 都只收到0, 打印0. $ N4 S8 g- r* ]9 j: |4 s( f 开始查资料: H7 DMA 访问空间有要求, 无法访问DTCM 0x2000000区域的RAM, 如果编程环境设置了,我的变量再这个区域, DMA就搬运不了.5 N9 b, J( @: d3 C& i ( A& ~- K3 H0 y 好, 我是CubeMX IDE, 是GCC环境, 查看LD文件, 查看MAP文件 bss段 指定是在 0x24000000区域, map显示我的uart8_RXdata也是在这个区域内, 所以没问题. DMA可以访问. 又折腾半天, 想起来配置LWIP的时候, 就是要配置MPU才能正常进行以太网收发. 由于H7内核达到480Mhz, CPU访问RAM都需要透过cache才能发挥性能. 所以H7芯片做了MPU这个部分来配置内存的访问策略. CPU访问SRAM 中间有CACHE的作用. 而DMA是直接操作SRAM空间. 所以要进行Cache策略配置.5 k3 r- Q: i# a$ E 在MPU设置中加入一个区块, 把整个0x2400000空间取消buffer.4 B6 A m) K! x/ x 生成代码, 串口收发正常了. 之前考虑过这个方面,使用了volatlie关键字, 使用ST提供的函数: SCB_InvalidateDCache_by_Addr((uint32_t *)uart8_Rxdata,2);$ Z3 g( r# `, g# p ! W5 y) L% c0 m9 j 8 T n( q$ p6 n3 [ 5 w9 j$ U# B# j9 N |
【经验分享】STM32_H7_ADC
STM32H7R/S高性能MCU:安全性,大存储和优异图显赋能更多应用创新
Stm32H7XX GCC下分散加载实现
【银杏科技ARM+FPGA双核心应用】STM32H7系列10——ADC
DIY-STM32H750核心板
[nucleo-H7A3ZI-Q]1-点亮一个皮皮灯
DIY-STM32H743核心板
【银杏科技ARM+FPGA双核心应用】STM32H7系列57——MDK_FLM
1月10日有奖直播 | 基于STM32 的CODESYS智能自动化解决方案
STM32的CAN FD位定时设置注意事项