一个关于使用STM32F4芯片CCM RAM时的异常分析

发布者:WhisperingWaves最新更新时间:2018-06-07 来源: eefocus关键字: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的好处是,访问和执行的速度更快。www.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被修改的原因了。


关键字:STM32F4芯片  CCM  RAM 引用地址:一个关于使用STM32F4芯片CCM RAM时的异常分析

上一篇:STM32F407的RAM调试
下一篇:STM32内存分布学习

推荐阅读最新更新时间:2024-03-16 16:05

旗舰Android手机在国内为什么必须6G内存
eeworld网晚间报道:随着三星在韩国正式开启了Galaxy S8/S8+的预售,搭载有6GB RAM的“皇帝版”Galaxy S8+也被官方正式确认存在。对于国内的三星粉丝而言,着实是一个天大的好消息。韩版的发售,意味着国行的“皇帝版”Galaxy S8+已经在“骑马来的路上了”。 机皇定位 在全面屏,Bixby语音助手等众多黑科技的加持下,Galaxy S8/S8+已经稳座当今安卓机皇王位。然而,尽管有众多黑科技加持,4GB RAM却让机皇之名略有遗憾。 如何评价现在安卓手机的硬件性能呢?想来大部分消费者会说,硬件性能过剩。但硬件性能过剩这一判断,却始终是一个伪命题。硬件的运算能力在飞速发展的同时,软件也一定会通过不同的
[手机便携]
彭博:三星计划明年降低内存芯片产量增幅 可能推高芯片
    9月21日消息,据彭博社报道,知情人士表示,在预期需求放缓的情况下,三星电子计划明年降低内存芯片产量增幅,以确保供应紧缩。 上述知情人士表示,此举将有助于维持或推高芯片价格。目前,三星预计,DRAM内存的产能位元增长率(bit growth)将低于20%,而NAND闪存的产能位元增长率将为30%。 今年早些时候,三星曾预计,2018年DRAM内存和NAND闪存的位元增长率分别为20%和40%。位元增长率指的是内存的产量,是衡量内存芯片市场需求的关键指标。 本月,芯片设备制造商KLA-Tencor Corp曾警告,芯片销量将迎来“旱灾”,这引发了人们的担忧,即芯片行业长达两年的超级周期也许将中止。” 三星是全球最大的DR
[手机便携]
消息称三星电子将从明年 1 月开始向英伟达供应 HBM3 内存,此前已向 AMD 供货
11 月 13 日消息,韩国日报称,三星电子打破了 SK 海力士为 NVIDIA 独家供应 HBM 3 的局面,该公司计划从明年 1 月开始向英伟达提供 HBM3。 有分析师预测称,今年以来一直低迷的三星电子半导体业务业绩将在明年迅速复苏。一些猜测认为,三星电子可能会在明年下半年在 HBM 市场份额上超过 SK 海力士。 此前,三星电子已成功向美国 AMD 供应 HBM3 内存,但由于 AMD 在该市场的主导地位并不大,因此据说供应有限。 市场研究公司 Trend Force 预测,SK 海力士和三星电子今年将争夺全球 HBM 市场 46-49% 的份额,但分析师们认为 SK 海力士的实际市场份额大幅领先于三星电子。 如果三星电子
[半导体设计/制造]
内存控制器与SDRAM
内存接口概念: 通常ARM芯片内置的内存很少,要运行Linux,需要扩展内存。ARM9扩展内存使用SDRAM内存,ARM11使用 DDR SDRAM。S3C2440通常外接32位64MBytes的SDRAM,采用两片16位32M的SDRAM芯片,SDRAM芯片通过地址总线、数据总线、若干控制线与S3C2440芯片相连。 芯片资源: S3C2440有ADDR0~ ADDR26共27根地址线(128M),其中ADDR0,ADDR16~ ADDR26为GPIO/地址线复用,GPIO只能是输出,DDR1~ADDR15为专用地址线,就只能是当地址线用。有32根数据线DATA0 ~DATA31全部都是专用数据线。虽然是32位的芯片,CPU
[单片机]
<font color='red'>内存</font>控制器与SDRAM
STM32CubeMX系列 | 外部SRAM
1.外部SRAM简介 本例程使用的STM32F103ZET6本身有64K字节的SRAM,一般应用已经足够;不过在一些对内存要求高的场合,比如跑算法或者GUI等,就需要外扩SRAM来满足大内存使用的需求。这里我们使用了一颗256K字节容量的SRAM芯片:IS62WV12816,利用STM32F1的FSMC控制该SRAM芯片,实现对该SRAM芯片的访问控制 IS62WV12816是一种16位宽128K(128*2,即256K字节)容量的CMOS静态内存芯片,它有高速访问、低功耗、兼容TTL电平接口、全静态操作(不需要刷新和时钟电路)、三态输出和字节控制(支持高/低字节控制)等特点 IS62WV12816的引脚以及对应的引脚功能如下图示
[单片机]
麦格纳 CLEARVIEW™视觉系统装载于福特RAM 皮卡投放市场
● 首次面市的完整视觉系统 ● 结合内部和外部视镜、摄像头、电子设备和软件 ● 装载于福特Ram 2500和3500重型皮卡面世 近日,麦格纳先进的ClearView™视觉技术已在福特Ram 2500 和3500重型皮卡上首次投产,该技术旨在使车辆更智能、更安全。该系统的独特性在于结合了摄像头和后视镜技术,可通过提高车辆周围的能见度来减少盲点事故并提升安全性。ClearView™其他功能还包括更易停车及操控车辆。 ClearView™系统包括一个车内后视视频镜、集成摄像头的车外后视镜和一个中央高位制动灯摄像头。附加一个可选配的拖车摄像头,便于在拖车时提供无障碍视野。所有摄像头数据都通过麦格纳的软件在中央电子控制单
[汽车电子]
麦格纳 CLEARVIEW™视觉系统装载于福特<font color='red'>RAM</font> 皮卡投放市场
OPPO A9 2020:8+128GB大内存 5000mAh电池
有外媒曝光了OPPO新机OPPO A9 2020的参数配置信息与渲染图,让人得以提前一窥这款新机的真面目。   具体来说,OPPO A9 2020将搭载后置四摄,分别是4800万像素主摄+800万像素+200万像素+200万像素的四摄组合,前置则是1600万像素单摄。   配置上,OPPO A9 2020将会配备骁龙665处理器,内置8GB内存,128GB存储,6.5英寸水滴屏,电池5000mAh。   外观上,OPPO A9 2020的三围为163.6mm x 75.6mm x 9.1mm,重195g,后置指纹识别,背部相机居中摆放,有墨绿有紫蓝两色可选。   至于价格尚未曝光,不过单从配置上看,OPPO A9 2020
[手机便携]
C51和MDK的ROM大小及变量绝对地址初始化
#1. C51的ROM大小 Keil编译完之后,显示的Program Size: data=9.0 xdata=8 const=15 code=180,则 The Total ROM(const + code + code-gap + const-gap) is 199BYTE 实际生成的bin文件大小: 在.MAP中的C O D E M E M O R Y 中 code-gap为0,cosnt-gap为4,则const + code + const-gap=15 + 180 + 4 = 199,刚好和实际生成的bin文件大小一致。 #2. C51的ROM大小优化 如果实际编译显示的const + code远小于实际的Bi
[单片机]
C51和MDK的<font color='red'>ROM</font>大小及变量绝对地址初始化
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved