我使用DMA进行SPI传输时发现无数据,还好有个逻辑分析仪,不然有没有信号都不知道 这是总线访问权限的图。* `% @! [7 T3 i1 b; h “-”表示不能访问。“D”表示直接访问。其它的都是间接访问。 2 z- j6 w3 m" U 发现DMA1只有ITCM和DTCM不能访问,问题就出在这。 有句“TCM 接口上的 DTCM-RAM 映射到地址 0x2000 0000,可供 Cortex®-M7 访问......”。(M7是处理器核)8 ]$ ^5 c/ L9 \- N, J* Z" a' M" L# L 内存分布:: g; d* ^4 ~2 [) B DTCM-RAM(数据TCM RAM):起始地址:0x2000 0000,大小:0x20000(128KB)。/ e* @9 `; ~. Q AXI SRAM(D1域):起始地址:0x24000000; @$ T$ F8 t, {5 p. W, i8 O - C7 f1 H" q0 a U" a: D( `. L DTCM虽然和其它的MCU的RAM起始地址一样,但是无法被DMA访问。: s* c) k; [; J% L; F" B& d2 _, J G$ P2 h, l6 _6 t 也就是通用RAM的地址变了,但是编译器还是会把DTCM的地址作为通用RAM的起始地址。0 [) Y$ m( E+ W2 U& u- q+ ~ q$ x - k) e7 s* l7 C0 n) M( @+ v7 q& X. Y E/ J+ H/ \+ t+ X2 P. u. i# c 使用DMA传输时把内存起始地址修改为D1域。也就是把勾打在RAM2上。这是最简单的解决方法。 ' m7 I' ^- T6 B& J Makefile工程:. I/ \9 a7 g4 }; G ' A& p8 F1 z( |. n! _ 在指定位置创建内存:# ]. S! K5 a Z, d4 L 在ld文件中添加:9 K5 s8 m& V# N+ L. D$ | .DisplayBuffer : //DisplayBuffer是名字 {undefined *(.DisplayBuffer), i5 `* D+ Z* B) t" Y: m4 }5 ? } >RAM_D2 //RAM_D2是所在地 使用该内存:__attribute__((section(".DisplayBuffer"))) uint16_t DisplayBuffer[ScreenH][ScreenW];。 也可以直接指定地址:uint16_t DisplayBuffer[100][100] __attribute__((section(".ARM.__at_0x20000000")));。只能在bss段里,bss段所在的内存区域在ld文件里看,看最后指向哪个RAM区域。 只要变量不在DTCM里就行。 : T3 G& H/ J' [3 t9 W, h4 T' @' ^ |
【经验分享】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位定时设置注意事项