转载[香水城]使用 STM32F427的CCM RAM时遇到的问题,当堆栈结果出问题了?

 
又搜到香水城的帖子了。
具体可以香看到这个水城子吧 https://bbs.21ic.com/forum.php?mod=viewthread&tid=1656556
 
使'c用 STM32F42h7的CCM RAM时遇到e的问题


前言
想写这篇文章的起因是因为有客户在使用CCM RAM的过程中遇到了问题。客户用的是STM32F427芯片,程序将CSTACK放在CCM RAM中,结果测试过一段时间的板子都出现了不能正常运行的情况。这个现象一度让我们怀疑是否是CCM RAM在测试过程中遭到了破坏,也导致我们在解决问题的道路上浪费了不少时间。事实证明我们的CCM RAM并没有那么脆弱,而解决问题时多从多个角度进行验证,不要放过所有的出问题的可能性也很重要。出问题的原因我会在本文中进行解释。但在具体讨论这个问题之前,我想先介绍一下STM32F427这款芯片上的CCM RAM。

CCM RAM介绍
ST的STM32F303, STM32F358, STM32F328, STM32F334系列和STM32F4的Advanced line系列芯片里都有CCM(Core Coupled Memory) RAM。但仔细看系统架构图会发现F3和F4的CCM RAM还是有不一样的地方。如下面是STM32F303和STM32F427的架构图:
转载[香水城]使用 STM32F427的CCM RAM时遇到的问题,当堆栈结果出问题了?
F3和F4的CCM RAM都只能内核能访问,DMA主设备没有连接到CCM RAM所以不能访问CCM RAM。但是从上图我们还能看到,对于F303的CCM RAM它连接到了数据总线和指令总线上,所以F303的CCM RAM既可以放数据也可以执行代码。但是F427的CCM RAM只连接到了数据总线,所以F427的CCM RAM不能执行代码。这一点需要注意。
数据和代码放在CCM RAM的好处是,访问和执行的速度更快。www.stmcu.com.cn网站上可以下载到AN4296的中文版本,这篇应用手册里详细说明了怎么从F303的CCM RAM里执行代码。在这里,我就不再赘述了。下面就来讲讲前面在F427上遇到的问题。