先来一张中文参考手册中的系统架构图,可以看到,STM32H7系列包含两个SDMMC控制器:SDMMC1和SDMMC2。
在这里插入图片描述
在芯片手册中的架构图能够更直观地看出来:
在这里插入图片描述

SDMMC内部集成一个IDMA,H7系列有很多总线主设备,包括DMA1、DMA2、BDMA、MDMA、DMA2D,还包括IDMA和以太网DMA这种专用DMA。
在这里插入图片描述
查看系统架构图和关于总线主设备的描述:
SDMMC1和SDMMC2相比,和SRAM1、SRAM2都没有构成总线矩阵,只能访问AXI SRAM区域的内存。
在这里插入图片描述
在这里插入图片描述
所以我们的使用IDMA进行SD卡的访问时,buffer必须放在AXI SRAM上面。


观察SRAM的分配,可以知道AXI SRAM分布在从0x24000000开始的512K区域上:
在这里插入图片描述
在这里插入图片描述
那么我们第一种情况,在编译器上只描述一部分内存DTCM:
在这里插入图片描述
在进行变量定义的时候强制指定地址:

__attribute__((at(0x24000000))) uint8_t Buffer_Block_Tx[MULTI_BUFFER_SIZE/4];
__attribute__((at(0x24040000))) uint8_t Buffer_Block_Rx[MULTI_BUFFER_SIZE/4];

可以看到指定的两个数组已经存在了AXI内存上,其他的都是DTCM内存上:
在这里插入图片描述


如果我们的工程配置上直接分配好了内存区域,这里使能了DTCM和AXI-SRAM内存:
在这里插入图片描述
这里我们并没有强制指定地址:

uint8_t Buffer_Block_Tx[MULTI_BUFFER_SIZE/4];
uint8_t Buffer_Block_Rx[MULTI_BUFFER_SIZE/4];

但是因为SRAM2的size要大一些,所以优先分配到SRAM2:
在这里插入图片描述
所以也是被分配在了AXI内存区域上。

Logo

开源、云原生的融合云平台

更多推荐