0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

SDRAM初始化分为6个步骤及SDRAM存储器布局

GReq_mcu168 来源:未知 2019-11-23 11:38 次阅读

写在前面


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

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

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

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

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

SDRAM初始化

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

  1. 配置EMC寄存器的SDRAM时钟频率、字节顺序和时序参数
    SDRAM的时序比较复杂,用户需要通过查阅相关SDRAM芯片的手册获得时序参数(如刷新周期、预充电命令周期、自刷新退出时间、写恢复时间等等)。

  2. 发送NOP命令

  3. 发送预充电命令

  4. 发送两次自动刷新命令

  5. 设置SDRAM模式

  6. 发送正常运行命令

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

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

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

  2. 在程序跳转到主程序启动之前,全局变量未清零或初始化,如果在主函数之前执行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)。

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

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

  3. 也可以将整个目标文件的数据和程序段配置到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 0 MPU->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 enable MPU->CTRL = MPU_CTRL_ENABLE_Msk | MPU_CTRL_PRIVDEFENA_Msk;

SDRAM性能基准

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

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

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

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


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • mcu
    mcu
    +关注

    关注

    146

    文章

    16016

    浏览量

    343620
  • SDRAM
    +关注

    关注

    7

    文章

    409

    浏览量

    54729

原文标题:MCU怎么在扩展的SDRAM上运行程序?

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    【开源骚客】《轻松设计SDRAM控制》第四讲—SDRAM 理论基础讲解

    的。对于初始化过程,首先需要有200us的一延时,在延时满足之后,给一次Precharge命令,之后再给两次Auto-refresh命令,最后进行模式寄存配置。当然对于这些命令与命令之间的延时参数
    发表于 05-08 22:20

    SDRAM理论基础讲解

    SDRAM的引脚,就必须要看SDRAM的datasheet。 三、学习SDRAM初始化的配置过程对于的初始化,也是需要参考官方文档的。 对于
    发表于 03-26 14:35

    多路读写的SDRAM接口设计

    SDRAM的主要操作可分为初始化操作、读操作、写操作、自动刷新操作。(1)初始化操作SDRAM上电一段时间后,经过
    发表于 12-03 15:20

    裸机SDRAM实验屏蔽SDRAM初始化函数能读取SDRAM地址的内容吗

    在做新一期裸机SDRAM实验时,屏蔽SDRAM初始化函数,还能读取SDRAM地址的内容
    发表于 03-07 07:45

    SDRAM裸机用C初始化跳转失败

    SDRAM裸机参考mmu那章的C初始化,编译成功后运行灯不亮,感觉head.S中ldr pc, =on_sdram没跳转成功,请问是什么原因,谢谢!文件:head.S@
    发表于 05-09 07:45

    嵌入式存储器的应用:sDRAM硬件连接方案以及软件接口的实现

    分为静态随机存储器(SRAM)、动态随机存储器(DRAM)及SDRAM。1SRAM单元通常由4~6
    发表于 08-12 00:00

    SDRAM它是怎么工作的?

    结构体一、SDRAM 同步动态随机存储器(也是一芯片)问题:它出什么地方来的呢?为什么会用到它?它怎么工作的?stm32控制芯片内部有一定大小的SRAM和FLASH作为内存和程序储存空间,但是有时候后可能程序比较大,内存就不够
    发表于 01-20 08:22

    嵌入式裸机之汇编初始化SDRAM实现过程

    1.SDRAM引入1.1 常见存储器介绍:DRAM介绍同步动态随机存取内存(synchronous dynamic random-access memory,简称SDRAM),有一
    发表于 05-16 15:03

    SDRAM存储器部分电路图

    SDRAM存储器部分电路
    发表于 05-07 18:41 21次下载

    SDRAM存储器相关资料下载

    SDRAM存储器相关资料下载
    发表于 05-02 11:46 49次下载
    <b class='flag-5'>SDRAM</b><b class='flag-5'>存储器</b>相关资料下载

    SDRAM存储器模块的简介

    SDRAM与 Flash不同,它不具有掉电保持数据的特性,但其存取速度大大高于 Flash存储器,且具有读/写的属性,因此 SDRAM在系统中主要用作程序的运行空间,数据及堆栈区。当系统启动
    发表于 12-18 16:13 12次下载
    <b class='flag-5'>SDRAM</b><b class='flag-5'>存储器</b>模块的简介

    如何使用Verilog设计Altera的DE2板上SDRAM存储器

    本文档的主要内容详细介绍的是如何使用Verilog设计Altera的DE2板上SDRAM存储器
    发表于 01-22 15:34 10次下载
    如何使用Verilog设计Altera的DE2板上<b class='flag-5'>SDRAM</b><b class='flag-5'>存储器</b>

    STM32H750_FMC_SDRAM 初始化流程总结

    STM32H750_FMC_SDRAM使用STM32CUBEMX 初始化FMC部分,SDRAM 关于延时部分参数模式寄存器#define SDRAM
    发表于 12-29 18:49 2次下载
    STM32H750_FMC_<b class='flag-5'>SDRAM</b> <b class='flag-5'>初始化</b>流程总结

    STM32H7实现BootLoader内SDRAM初始化注意事项

    Function Implementation:在 ArtPi 的环境下,实现一个简单的 BootLoader,该 BootLoader 实现了 QSPI 和 SDRAM 功能的初始化
    的头像 发表于 06-07 15:51 2214次阅读
    STM32H7实现BootLoader内<b class='flag-5'>SDRAM</b>的<b class='flag-5'>初始化</b>注意事项

    SDRAM工作原理 SDRAM布局布线说明

    SDRAM全称Synchronous Dynamic RAM,同步动态随机存储器。首先,它是RAM,即随机存储器的一种。
    发表于 08-08 15:10 1039次阅读
    <b class='flag-5'>SDRAM</b>工作原理 <b class='flag-5'>SDRAM</b><b class='flag-5'>布局</b>布线说明