你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【经验分享】STM32H7系列使用DMA不能传输数据的问题

[复制链接]
STMCU小助手 发布时间:2022-1-1 20:00
我使用DMA进行SPI传输时发现无数据,还好有个逻辑分析仪,不然有没有信号都不知道

这是总线访问权限的图。

“-”表示不能访问。“D”表示直接访问。其它的都是间接访问。

20190830132727103.png


20190830133103551.png


发现DMA1只有ITCM和DTCM不能访问,问题就出在这。

有句“TCM 接口上的 DTCM-RAM 映射到地址 0x2000 0000,可供 Cortex®-M7 访问......”。(M7是处理器核)

内存分布:

               DTCM-RAM(数据TCM RAM):起始地址:0x2000 0000,大小:0x20000(128KB)。

               AXI SRAM(D1域):起始地址:0x24000000

DTCM虽然和其它的MCU的RAM起始地址一样,但是无法被DMA访问。

也就是通用RAM的地址变了,但是编译器还是会把DTCM的地址作为通用RAM的起始地址。

20190830134309979.png


使用DMA传输时把内存起始地址修改为D1域。也就是把勾打在RAM2上。这是最简单的解决方法。

Makefile工程:

在指定位置创建内存:
                                在ld文件中添加:
                                    .DisplayBuffer : //DisplayBuffer是名字
                                    {undefined
                                        *(.DisplayBuffer)
                                    } >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里就行。


收藏 评论0 发布时间:2022-1-1 20:00

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版