STM32F4芯片CCM RAM异常有妙招 异常测试分析经验总结

发布时间:2017-03-24 阅读量:2961 来源: 我爱方案网 作者: jiangliu

产品开发测试过程中总会出现一些意想不到的异常,本文介绍一个关于使用STM32F4芯片CCM RAM异常的情况,有网友遇到类似情况时可以参考此方法找出原因。我们在开发时用STM32F427芯片,程序将CSTACK放在CCM RAM中,结果测试过一段时间的板子都出现了不能正常运行的情况。这个现象一度让我们怀疑是否是CCM RAM在测试过程中遭到了破坏,导致在解决问题的道路上浪费了不少时间。

事实证明STM32的CCM RAM并没有那么脆弱,而解决问题时尽力从多个角度进行验证,不放过所有可能出问题的环节之心态更为重要。

在具体讨论问题的原因之前,不妨先介绍一下STM32F4/STM32F3系列芯片上的CCM RAM。

CCM RAM介绍

ST的STM32F303, STM32F358, STM32F328, STM32F334系列和STM32F4的Advanced line系列芯片里都有CCM(Core Coupled Memory) RAM。但仔细看系统架构图会发现F3和F4的CCM RAM还是有不一样的地方。如下面是STM32F303和STM32F427的架构图:


 
F3和F4的CCM RAM都只能被内核访问,DMA主设备没有连接到CCM RAM,所以不能访问它。从上图我们还能看到,对于F303的CCM RAM它连接到了数据总线和指令总线上,所以32F303的CCM RAM既可以放数据也可以执行代码。但32F427的CCM RAM只连接到了数据总线,所以F427的CCM RAM不能执行代码。这一点需要注意。

数据和代码放在CCMRAM的好处是,访问和执行的速度更快。stmcu.com.cn网站上可以下载到AN4296的中文版本,这篇应用手册里详细说明了怎么从F303的CCM RAM里执行代码。在这里就不再赘述了。下面接着讲讲前面在32F427上遇到的异常问题。

问题描述

产品做了一段时间的测试后发现一批板子全部出问题。客户方面进行分析后用了一段简单的点灯程序进行测试,发现当CSTACK放在不同的位置时程序表现不一样。CSTACK放在SRAM中时,工作正常,但放在CCM RAM中就不能正常运行。从这个现象看很像是CCM RAM出问题了,且恰好只有经过测试的板子有问题,其他板子都没有问题。

测试过程

拿到板子和测试代码后很容易就重现了客户描述的现象。
首先检查了客户测试代码中的link文件。发现link文件写的没错。【IAR环境】
/*###ICF### Section handled by ICFeditor, don't touch! ****/
/*-Editor annotation file-*/
/*IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
/*-Specials-*/
define symbol__ICFEDIT_intvec_start__ = 0x08000000;
/*-Memory Regions-*/
define symbol ICFEDIT_region_ROM_start= 0x08000000;
define symbol__ICFEDIT_region_ROM_end__ = 0x081FFFFF;
define symbol__ICFEDIT_region_RAM_start__ = 0x20000000;
define symbol__ICFEDIT_region_RAM_end__ = 0x2002FFFF;
define symbol__ICFEDIT_region_CCMRAM_start__ = 0x10000000;
define symbol__ICFEDIT_region_CCMRAM_end__ = 0x1000FFFF;
/*-Sizes-*/
define symbol__ICFEDIT_size_cstack__ = 0x400;
define symbol ICFEDIT_size_heap= 0x200;
/**** End of ICF editor section.###ICF###*/
define memory mem with size = 4G;
define region ROM_region = mem:[from__ICFEDIT_region_ROM_start__ to ICFEDIT_region_ROM_end];
define region RAM_region = mem:[from__ICFEDIT_region_RAM_start__ to ICFEDIT_region_RAM_end];
define region CCMRAM_region =mem:[from ICFEDIT_region_CCMRAM_start to ICFEDIT_region_CCMRAM_end];
define block CSTACK with alignment =8, size = ICFEDIT_size_cstack { };
define block HEAP with alignment =8, size = ICFEDIT_size_heap { };
initialize by copy { readwrite };
do not initialize { section .noinit};
place at addressmem:ICFEDIT_intvec_start { readonly section .intvec };
/*place at addressmem:ICFEDIT_region_CCMRAM_start { block CSTACK };*/
place in CCMRAM_region {blockCSTACK};
place in ROM_region { readonly };
place in RAM_region { readwrite,block HEAP };

首先定义一个CCMRAM_region,然后通过”place in CCMRAM_region{block CSTACK};” 声明将CSTACK放在CCM RAM中。但在接下来的测试中发现了一些新的现象。

测试一:
首先测试过程中发现板子连着ST-LINK在debug状态下时,能正常运行。
只有断开ST-LINK,重新上电后就不能正常工作了。

测试二:
为了确认CCM RAM是不是真的坏了。另外写了一个程序,将CSTACK放在SRAM中,然后在程序运行的时候对CCM RAM地址空间进行遍历,对地址0x10000000 到0x1000FFFF空间逐次进行读写操作。发现程序正常运行,CCM RAM的读写正常。
实验做到这里,基本可以确定CCM RAM没有损坏。但为什么CSTACK不能放到CCM RAM中呢?
然后我们又做了第三个实验。

测试三:
对比拿到的坏板子的Optionbytes的值与默认值。逐个检测不同的位是否和问题相关。发现BFB2这位的状态会影响程序的运行。如果清除该位,即使将CSTACK放在CCM RAM中,程序也能正常运行。

原因分析

从上面的测试结果,发现问题跟Option bytes中的BFB2的状态有关。查询BFB2位的作用后搞清了问题的原因。我们先来说说BFB2做什么用。STM32F427的Flash支持双Bank. BFB2可以用来切换启动时从Bank2启动。我们来看看参考手册中的描述:



如果想从Flash Bank2启动,必须将BFB2位置1。如果此时boot引脚的配置是从用户Flash启动,芯片将先从系统bootloader启动,然后跳转到Bank2执行。
然后在应用笔记AN2606中,我们看到BFB2置1时的启动流程,发现了问题所在。见下图:



当BFB2置1时,在跳转到用户代码(Bank2或者Bank1)之前,系统bootloader会检查栈顶的位置是否在SRAM区域,也就是检查是否落在0X20000000开头的地址。如果不是,就会一直停在bootloader中,不继续执行。这也就是我们前面看到的程序不能正常运行的原因。

当将BFB2位清除后,问题马上解决了。而且对比当CSTACK设置在CCM RAM时还能正常工作的板子,发现这一位都是没有置1的。

找到程序不能正常运行原因后,我们就从错误的方向回到正途,开始寻找Option bytes被修改的原因了。

相关资讯
消费电子补贴效应凸显,中小尺寸驱动IC需求三连增

全球显示面板核心元器件市场呈现企稳态势。根据TrendForce最新研究报告显示,2023年第一季度面板驱动IC产品均价环比下降幅度收窄至1%-3%区间,第二季度虽仍存在价格下行压力,但降幅预计将控制在2个百分点以内。这标志着自2020年疫情引发的剧烈市场波动后,驱动IC价格曲线首次出现明显筑底信号。

成本直降40%!易飞扬硅光模块如何重构DCI市场格局?

在全球5G网络部署与边缘计算需求井喷的背景下,易飞扬创新推出基于O波段的100G QSFP28 DWDM光模块,直击城域网络升级痛点。该产品通过零色散传输架构与硅光集成技术,突破传统C波段方案在中短距场景下的性能瓶颈,以低于3.5W的功耗实现30km无补偿传输,同时兼容开放光网络架构。据行业测算,其部署成本较同类方案降低40%,为5G前传、分布式AI算力互联及绿色数据中心建设提供了高性价比选择,或将成为运营商边缘网络改造的关键技术引擎。

充电效率94.8% vs 国际竞品:国产IC技术路线图全解析

在全球能源转型与欧盟新电池法规(EU 2023/1542)的驱动下,旭化成微电子(AKM)于2025年2月正式量产AP4413系列充电控制IC,以52nA超低功耗、94.8%充电效率及多电压适配等核心技术,重新定义小型设备供电逻辑。该产品通过电容器预充电机制破解完全放电恢复难题,并凭借动态电压调节算法兼容光能、振动等微瓦级能源输入,显著优于TI、ADI等国际竞品。面对国产替代窗口期,AP4413依托BCD工艺与专利壁垒抢占先机,有望在智能家居、工业传感等千亿级市场替代传统一次性电池方案,成为环保供电赛道的标杆级解决方案。

新能源汽车与工业4.0双重驱动:全球电子分销巨头技术布局揭秘

作为全球电子元器件分销领域的领军者,贸泽电子始终以"技术赋能创新"为核心战略,通过构建覆盖1200余家原厂的供应链网络,为工业自动化、汽车电子、智慧农业等前沿领域提供关键技术支持。2025年第一季度,公司新增物料突破8,000项,其中多项产品体现了行业技术演进的三大方向:

工业级高灵敏度振动传感器V112E的核心竞争力与市场价值

V112E高精度振动传感器以1V/g超高灵敏度与纳米级分辨率为核心突破,重新定义了工业设备健康监测的技术边界。通过钛合金激光密封工艺与陶瓷剪切传感技术,该传感器兼具IP67防护等级与-55~120℃极端环境适应性,攻克了传统产品在高温、潮湿场景下的信号失真与寿命短板。其覆盖半导体制造、能源安全、医疗设备等高价值领域,精准捕捉微米级振动能量,为工业4.0智能化运维提供硬核数据支撑,有望在千亿级传感器市场中占据高端技术制高点。