单片机
返回首页

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

2022-07-07 来源:csdn

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

进入单片机查看更多内容>>
相关视频
  • RISC-V嵌入式系统开发

  • SOC系统级芯片设计实验

  • 云龙51单片机实训视频教程(王云,字幕版)

  • 2022 Digi-Key KOL 系列: 你见过1GHz主频的单片机吗?Teensy 4.1开发板介绍

  • TI 新一代 C2000™ 微控制器:全方位助力伺服及马达驱动应用

  • MSP430电容触摸技术 - 防水Demo演示

精选电路图
  • PIC单片机控制的遥控防盗报警器电路

  • 红外线探测报警器

  • 短波AM发射器电路设计图

  • 使用ESP8266从NTP服务器获取时间并在OLED显示器上显示

  • 开关电源的基本组成及工作原理

  • 用NE555制作定时器

    相关电子头条文章