STM32H7系列SDMMC1中的IDMA 和 ARM Cortex-M的分散加载

先来一张中文参考手册中的系统架构图,可以看到,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内存区域上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值