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

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

3天内不再提示

关于MCU怎么在扩展的SDRAM上运行程序?

黄工的嵌入式技术圈 来源:21ic电子网 作者:21ic电子网 2020-03-01 13:17 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

写在前面

在使用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
    mcu
    +关注

    关注

    147

    文章

    18618

    浏览量

    387393
  • 控制器
    +关注

    关注

    114

    文章

    17648

    浏览量

    190291
  • SDRAM
    +关注

    关注

    7

    文章

    449

    浏览量

    57288
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    极海APM32系列MCU中如何把代码重定位到SDRAM运行

    在有些情况下,我们想要把代码放到SDRAM运行。下面介绍APM32的MCU中,如何把代码重定位到SDRAM
    的头像 发表于 11-04 09:14 4845次阅读
    <b class='flag-5'>在</b>极海APM32系列<b class='flag-5'>MCU</b>中如何把代码重定位到<b class='flag-5'>SDRAM</b><b class='flag-5'>运行</b>

    MG51FB9AE MCU中,如何使用LDROM中的IAP加载程序MCUAPROM中上传程序

    MG51FB9AE MCU中,如何使用LDROM中的IAP加载程序MCUAPROM中上传程序
    发表于 08-22 06:29

    MCU反复启动运行缓慢怎么解决?

    我们的 XMC4500 遇到了一个奇怪的问题。某种情况下,我发现 MCU 似乎突然运行得更慢了。我观察到以下情况: 1) CAN 消息发送速度大约慢 11.7 倍。 2) 我们的闪烁 LED 频率
    发表于 07-15 06:21

    移植touchgfx之后stm32不运行程序怎么解决?

    MCU:STM32U585CIU6 cubemx:6.14 touchgfx:25 我cubemx配置生成touchgfx的初始化,时基是TIM7,没有用RTOS,生成之后再用designer随便
    发表于 06-06 07:43

    hid usb读取不到扩展按键的问题

    到)以及扩展的两个按键(这两按键的按键码分别为01和02),这两个扩展按键程序接受不到任何信息,通过键盘hook和raw input也只能接受到遥控器的一页、下一页按键的信息,接收不
    发表于 05-20 20:22

    为什么无法运行程序“make”(目录“C:\\?

    FX2LP Build,得到了 14:26:46 **** 为项目 Fx2Test 构建配置调试 **** 全部制作 无法运行程序“make”(目录“C
    发表于 05-15 08:26

    同样的代码官方开发板运行正常,自己板子就跑不起来,怎么办?

    同样的代码Nordic官方开发板可以运行正常,但在自己板子就跑不起来,如果你碰到了上述情况,建议按照如下步骤进行自检: 首先确认用户板元器件焊接良好,功能正常。如果你的板子有LE
    的头像 发表于 05-12 15:26 584次阅读
    同样的代码<b class='flag-5'>在</b>官方开发板<b class='flag-5'>上</b><b class='flag-5'>运行</b>正常,<b class='flag-5'>在</b>自己板子<b class='flag-5'>上</b>就跑不起来,怎么办?

    MCUFlash

        MCUFlash是微控制器内部集成的非易失性存储器,主要用于存储程序代码、常量数据及系统配置信息。其核心特性与功能如下: 一、定义与类型‌ 片Flash采用浮栅晶体管技术
    的头像 发表于 05-06 14:26 867次阅读

    浅谈MCURAM

    MCURAM是微控制单元(MCU)中集成于芯片内部的随机存取存储器,主要用于程序运行时的数据存储与高速读写操作。以下是其核心要点: 一、
    的头像 发表于 04-30 14:47 991次阅读

    DDR3 SDRAM配置教程

    DDR3 SDRAM(Double-Data-Rate ThreeSynchronous Dynamic Random Access Memory)是DDR SDRAM的第三代产品,相较于DDR2,DDR3有更高的运行性能与更低
    的头像 发表于 04-10 09:42 3780次阅读
    DDR3 <b class='flag-5'>SDRAM</b>配置教程

    如何在 树莓派 编写和运行 C 语言程序

    本教程中,我将讨论C编程语言是什么,C编程的用途,以及如何在RaspberryPi编写和运行C程序。本文的目的是为您介绍Raspber
    的头像 发表于 03-25 09:28 942次阅读
    如何在 树莓派 <b class='flag-5'>上</b>编写和<b class='flag-5'>运行</b> C 语言<b class='flag-5'>程序</b>?

    用stsw-link004这个软件配合仿真器写程序后,直接运行程序程序运行不正常是什么原因?

    用stsw-link004这个软件配合仿真器写程序后,直接运行程序程序运行不正常,必须对电路板进行完全重新电,
    发表于 03-07 07:00

    SDRAM控制器的设计——Sdram_Control.v代码解析(异步FIFO读写模块、读写SDRAM过程)

    前言 SDRAM控制器里面包含5个主要的模块,分别是PLL模块,异步FIFO 写模块,异步FIFO读模块,SDRAM接口控制模块,SDRAM指令执行模块。 其中异步FIFO模块解读
    的头像 发表于 03-04 10:49 2192次阅读
    <b class='flag-5'>SDRAM</b>控制器的设计——<b class='flag-5'>Sdram</b>_Control.v代码解析(异步FIFO读写模块、读写<b class='flag-5'>SDRAM</b>过程)

    EE-178:ADSP-TS101S TigerSHARC片SDRAM控制器

    电子发烧友网站提供《EE-178:ADSP-TS101S TigerSHARC片SDRAM控制器.pdf》资料免费下载
    发表于 01-14 15:00 0次下载
    EE-178:ADSP-TS101S TigerSHARC片<b class='flag-5'>上</b><b class='flag-5'>SDRAM</b>控制器

    EE-239:ADSP-BF533 Blackfin处理器运行闪存程序

    电子发烧友网站提供《EE-239:ADSP-BF533 Blackfin处理器运行闪存程序.pdf》资料免费下载
    发表于 01-07 13:58 0次下载
    EE-239:<b class='flag-5'>在</b>ADSP-BF533 Blackfin处理器<b class='flag-5'>上</b><b class='flag-5'>运行</b>闪存<b class='flag-5'>程序</b>