当前位置:首页 > 杂谈 > 正文内容

嵌入式设计须知:MCU怎么在扩展的SDRAM上运行程序?-嵌入式mcu的主要特点

2023-07-19 08:44:40TONY杂谈94

在使用MCU的嵌入式系统设计中,当程序或者数据内存占用太大而无法放入片上闪存或SRAM时,开发者通常

在使用MCU的嵌入式系统设计中,当程序或者数据内存占用太大而无法放入片上闪存或SRAM时,开发者通常考虑使用SDRAM。

别问我为什么你的MCU不支持SDRAM

SDRAM是同步动态随机存取存储器的缩写。在微控制器应用中,微控制器通过使用外部存储控制器(EMC)操作访问SDRAM ,SDRAM时钟频率通常为100MHz或133MHz。

外部存储控制器通常不支持DDR SDRAM, 数据只是单边沿采样,即并行数据总线可以接受一个命令并在每个时钟周期传输一个数据字。

在SDRAM中执行程序是使用SDRAM的一种典型用法, 小编这里就介绍一下SDRAM中执行程序的方法和SDRAM执行程序的性能基准。

SDRAM初始化

SDRAM必须在使用前进行配置,SDRAM初始化分为6个步骤。

配置EMC寄存器的SDRAM时钟频率、字节顺序和时序参数。

SDRAM的时序比较复杂,用户需要通过查阅相关SDRAM芯片的手册获得时序参数(如刷新周期、预充电命令周期、自刷新退出时间、写恢复时间等等)。

发送NOP命令

发送预充电命令

发送两次自动刷新命令

设置SDRAM模式

发送正常运行命令

系统启动时,SDRAM尚未初始化。理论上,程序在系统启动后的任何时刻都可以进行SDRAM初始化。然而,由于SDRAM初始化过程比较复杂,使用的系统资源较多,SDRAM初始化必须在所需的系统资源初始化完成后再进行。

具体上讲,开发者在芯片刚刚启动时(如Reset_Handler中)初始化SDRAM需要留心以下细节:

由于SDRAM初始化函数使用系统堆栈或全局变量,开发者必须确保系统堆栈或全局变量所在的物理内存上电及时钟使能。

在程序跳转到主程序启动之前,全局变量未清零或初始化,如果在主函数之前执行SDRAM初始化,开发者必须手动初始化变量。

举个例子,在LPC5460x中,开发者需要在SystemInit函数中初始化SDRAM,该函数(SystemInit)由Reset_Handler调用。在调用系统初始化之前,要通过设置AHBCLKCTRLSET0寄存器将SRAM时钟使能。

Reset_Handler   PROC

EXPORT  Reset_Handler               [WEAK]

IMPORT  SystemInit

IMPORT  __main

; clock control SRAM1/SRAM2/SRAM3 for stack

LDR     r0, = 0x40000220 ; AHBCLKCTRLSET0

MOV     r1, #0x38

STR     r1, [r0]

LDR     r0, =SystemInit

BLX     r0

LDR     r0, =__main

BX      r0

ENDP

SDRAM存储器布局

当使用SDRAM时,外部存储控制器(EMC)分配SDRAM一定的地址空间。开发者可以使用链接描述文件将代码或数据分配到SDRAM中。值得注意的是,链接器脚本编程在不同IDE之间是不同的。

以LPC5460x系列微控制器为例,SDRAM支持4个片选区,每个片选区最大支持256MB空间。

SDRAM片选

地址范围

0

0xA0000000 - 0xA7FFFFFF

1

0xA8000000 - 0xAFFFFFFF

2

0xB0000000 - 0xB7FFFFFF

3

0xB8000000 - 0xBFFFFFFF

当SDRAM的硬件连接使用SDRAM片选0的情况下,在KEIL平台下,将加载在SPI FLASH的Coremark基准测试程序拷贝到SDRAM中执行需要以下几步。(coremark基准测试程序包括core_list_join.c,core_matrix.c,core_state.c及core_util.c)。

定义SDRAM区域,从0xA0000000开始,大小为0x80000。定义SPI FLASH区域,大小为0x80000(SPI FLASH存储器的起始地址为0x10000000)。

在C源码中使用“SDRAM_Data” 和 “SDRAM_Function”属性,标记放在SDRAM区域中的数据或程序。(SDRAM_Data和SDRAM_Function只是文本名字)。

也可以将整个目标文件的数据和程序段配置到SDRAM

#define m_spifi_start     0x10000000

#define m_spifi_size       0x800000

#define m_sdram_start     0xA0000000

#define m_sdram_size       0x80000

LR_m_text2 m_spifi_start m_spifi_size { ; load to SPIFI

LR_m_sdram_text   m_sdram_start    m_sdram_size {

   *(SDRAM_Data)
   *(SDRAM_Function)    core_list_join.o    core_matrix.o    core_state.o

   core_util.o

}

配置MPU

在SDRAM中运行程序,开发者可能需要配置ARM内核内存保护单元(MPU)。

内存保护单元(MPU)是一个可编程单元,用于定义内存访问权限。当MPU没有使能时,内存地址空间具有默认的访问权限。

如ARM Cortex™-M4器件通用用户指南中所述,当程序执行SDRAM中的代码且SDRAM内存影射地址的默认属性为禁止执行时, 内核就会产生HARDFAULT异常,且指令访问冲突标志SCB->CFSR为 1,该异常表示处理器尝试从不允许执行的位置获取指令。

打开凤凰新闻,查看更多高清图片

因此,当SDRAM被影射到默认不可执行的地址空间时(如在LPC5460x中,SDRAM影射到0xA0000000起始的地址),开发者必须配置并使能MPU才能在SDRAM中执行代码。如下例中,代码配置并使能MPU,允许从0xA0000000到0xA0100000的内存区域是可执行的。

MPU->RNR = 0;                    //Region number 0MPU->RBAR = 0xA0000000; //Region base address/* Full Access | TEX:

 000 | S: 0 | C: 0 | B:0 (No cacheable, no shareable)| 1M SIZE | ENABLE */

MPU->RASR = (0 << 28) | (0x3 << 24) | (0x0 << 19) | (0 << 18) | (0 << 17) | (0 << 16) | (0xFF < 8) | (0x13 << 1) | (1 << 0); //Region size and enableMPU->CTRL = MPU_CTRL_ENABLE_Msk | MPU_CTRL_PRIVDEFENA_Msk;

SDRAM性能基准

最后,在LPC5460x经过程序运行CoreMark性能基准测试,总结了一点点经验,分享给大家

SDRAM(16位带宽)中的代码执行效率仅为在内部SRAM中执行效率性能40%,大约是内部FLASH中运行代码性能的50%;

代码在SDRAM中运行时,较高的CPU频率(CPU没有Cache)不能改善执行效率,这时SDRAM带宽成为系统性能的瓶颈。

基于这样的测试结果,建议大家在要求较高性能时,把程序代码放在内部SRAM执行,而用片外大容量的SDRAM存放海量的数据。

“嵌入式设计须知:MCU怎么在扩展的SDRAM上运行程序?-嵌入式mcu的主要特点” 的相关文章

肾脏科 | 最新发表的万篇论文大数据分析:40本SCI期刊投稿指南、研究热点等

肾脏科 | 最新发表的万篇论文大数据分析:40本SCI期刊投稿指南、研究热点等

原标题:肾脏科 | 最新发表的万篇论文大数据分析:40本SCI期刊投稿指南、研究热点等 在pubmed上进行检索,我们可以看到自2000年以来,肾脏科领域相关研究共发表242,042篇。从2020年起,年发表量超过2万篇,其中2021年达历史高峰26233篇,2022年发表253...

知云安装后无法打开,我系统是win7

知云安装后无法打开,我系统是win7

有些win7用户安装知云文献翻译后打不开,可能会提示下面“zhiyuntranslator已停止工作”或“.net framework初始化错误”等错误画面。当然,并非所有win7用户都会出现无法打开的情况,只是少数。原因分析知云文献翻译软件是基于.net编程的,并且其中使用到部分VC运行库,由于w...

还在为论文翻译而发愁?精选4款论文翻译神器,拿走不谢

还在为论文翻译而发愁?精选4款论文翻译神器,拿走不谢

说到写论文,可能最头疼的要数英文论文的写作了吧!词组搭配、文献综述、语法句型...... 论文本就令人令人头大,当它前面还加上了“英文”两字时,其难度级别直接是呈次方的增长。 别担心,今天小编就为大家准备了4个科研翻译利器,大家可以根据自己的需求权衡利弊进行选择~01、CNKI翻译...

剑网三:“盒子翻车了,赶紧入手?”外观盒子衍生出的“生意经”

剑网三:“盒子翻车了,赶紧入手?”外观盒子衍生出的“生意经”

剑网三:“盒子翻车了,赶紧入手?”外观盒子衍生出的“生意经” 一款网游的交易机制对账号保值率有着巨大影响。 在一些内购免费制游戏中,大多数的属性道具,刷图爆出来的极品装备,包括一些内购道具,都是有一定交易限制的。 而在这种限制过程,其实对游戏的交易是有一定影响的。因...

天涯社区官网无法打开!网友掀起“怀念潮”:再见了青春……

天涯社区官网无法打开!网友掀起“怀念潮”:再见了青春……

  近日,有网友发现天涯社区官网已无法打开,相关页面显示“无法访问此网站”。另外,天涯社区APP也无法正常打开,页面显示“无网络连接”。   此前,天涯社区官方微博曾于4月1日发布公告称,近期将进行技术升级和数据重构,在此期间平台将无法访问,“请大家耐心等待”。...

阿里巴巴图标iconfont使用方法

阿里巴巴图标iconfont使用方法

图标库有很多,例如: Font Awesome , bootstrap 等,阿里巴巴也提供了很强大的免费图标库:iconfont,下面就来介绍一下免费的使用方法。 1、登录阿里巴巴矢量图标库,网址:https://www.iconfon...