6410超过片内内存程序的解决办法 DDR
来源:互联网 发布:vue安装sass淘宝镜像 编辑:程序博客网 时间:2024/06/11 16:26
当在S3C6410跑操作系统的时候,我们不太会注意S3C6410的内存使用情况,但是,当我们做裸板测试时,该处理器的8K的片内内存的使用就不得不注意,一旦编写的程序大小超过了片内内存的大小,我们就不能得到正确的结果,究其原因,我们先看一下S3C6410的启动过程。
本文引用地址:http://www.eepw.com.cn/article/203124.htmS3C6410如果选用NANDflash启动,在我们烧写裸板程序是,先将程序烧写至NANDflash中,S3C6410通过硬件将NANDflash中前8K的程序完整复制到S3C6410片内内存中。若裸板程序较小,程序可以正常运行,若果程序超过了8K,那么裸板测试程序不能完整的复制到片内内存,使得程序出现未知的结果。这时,我们需要关注S3C6410的各种内存的使用情况了。
我们知道,在一个程序文件中,拥有代码段、数据段和bss段,而一个程序的bin文件中是没有bss段,因此,在程序的bin文件中主要完成:
①硬件的初始化
②DDR的初始化
③S3C6410程序的重定位
④拷贝程序至DDR中
⑤清除DDR中bss段
⑥程序链接至DDR中
为进一步说明启动过程,现在进行详细的说明:
S3C6410为NANDflash启动,同时S3C6410外挂DDR,这样,就能解决程序超过8K之后的正常运行。三者之间的连接示意图如下图所示:
我们知道,S3C6410启动的时候,将NANDflash中前8K的程序完整拷贝至S3C6410片内内存中,在这8K程序中,必须完成硬件初始化、DDR初始化和程序从NANDflash中拷贝到DDR中,这样才能保证S3C6410cpu程序可以跳转到DDR,保证程序的顺利进行。在这过程中会涉及到程序的链接地址和程序的重定位方面的知识,如果你对这方面知识不熟悉,请查阅该方面的知识。
三者之间的操作步骤如下:
1、系统上电,S3C6410为NANDflash启动,硬件自动将NANDflash中前8k的程序复制到S3C6410片内内存中;
2、系统从S3C6410片内内存0地址开始执行,此时程序需要完成DDR初始化、将bin程序从S3C6410片内内存或者NANDflash拷贝到DDR链接地址起始位置;
3、将NANDflash程序拷贝到DDR中,通过程序重定位和链接到DDR链接地址开始位置(此时注意,在程序的编写中需要用位置无关跳转指令进行编写,否则程序会因为跳转后找不到链接起始地址和变量而出现错误)
4、当系统完成以上操作后,通过位置相关指令将PC值链接到DDR重定位位置,完成程序的运行(注意此时应使用位置相关指令完成PC值的跳转,若使用位置无关指令,则程序一直循环在S3C6410片内内存中)。
- 6410超过片内内存程序的解决办法 DDR
- DDR 内存的速度
- 加载大图片内存溢出的解决办法
- 钟爱STM32的理由:强大的片上内存调试功能,不改写芯片内原有程序
- DDR内存的布线经验
- DDR内存的布线经验
- DDR内存的布线经验
- DDR内存
- 浅析user用户态程序如何访问kernel空间的物理内存DDR和物理寄存器
- 32位程序使用超过4G的内存
- 32位程序使用超过4G的内存
- 32位程序使用超过4G的内存 实例
- mcu的片内flash
- Nikita Ivanov谈GridGain的Hadoop内存片内加速技术
- Hadoop跑程序报超过内存错误
- 通过内嵌汇编实现模拟时间片轮转多道程序的内核代码分析
- F2812 DSP程序运行在片内RAM和FLASH的区别
- DDR2与DDR的区别|如何区分DDR内存一代与二代?
- 【Android开发经验】Android Studio1.0正式版初体验——Mac/Window双平台安装指南 【转载】
- synchronized的深刻认识
- 猜系统随机数(1-100)
- 使用org.eclipse.xsd.XSDEnumerationFacet生成枚举类型的Schema
- 设计模式之模板方法浅析
- 6410超过片内内存程序的解决办法 DDR
- 4.安卓中get和post的简单实现
- codeforce
- 一句代码实现gzip压缩解压缩
- Service初步认识
- makefile学习
- 【工程数学】若干种插值算法
- 读取drawable文件夹的图片(根据文件名)
- 如何用 OS X 的 Xcode 写 C 语言程序