bootloader研究最后一关中

2011-03-12 17:04:13

今天的目的是要把bin文件烧录到nandflash中。

其实我有一个问题一直没弄明白。S3C2440自带的RAM和ROM是多大?看了规格书说它能控制1G的8个bank,但是需要外部通道。也就是他没有内部RAM和ROM。

但是关于nandflash启动的时候,由nandflash自动向其前4K放到CPU的内存的0x0地址?0x0不可能是R0等特殊寄存器吧!天哪S3C2440的RAM和ROM的结构我还真没明白。在论坛上查了下,有人回答:2440没有自带的ROM,自带的RAM是4K,也就是加载nboot的那个。

另外还有一个问题,分配地址空间,我本来以为就是rom或ram,现在想想寄存器也都有自己的地址空间,既不是ram也不是rom。这样一来貌似想通了。然后去看了看2440的系统框图。终于想明白了。

bootloader的代码搬移段看懂了,map文件也看懂了。
init.s里面有一句cmp r0, #0   ;if use Multi-ice,关于0就是填写在RO的0.当写0后,程序就可以通过nor中的bootloader下载到nandflash了。但是用jlink是无法直接烧录到nandflash的。为什么呢?
网上查了下资料。看后我觉得要把bin文件下载到flash用jlink是不可以的,但是可以用间接下载bin文件的方法,但是光配置icf文件是不行的。因为icf配置文件针对的是片内的rom和ram空间。所以,需要再增加外部驱动函数来调用。类似于ads版本的2440的函数bl RdNF2SDRAM。下面就开始动手修改iar的bootloader,使其能在下载到nandflash中。

网上参考资料如下:
JLINK支持几乎所有片内flash烧录,以及大部分的Norflash的烧录。但JLINK不支持直接的NANK flash的烧录。
下面主要说一下关于IAR环境调试的主要方式。在嵌入式开发中,由于对flash芯片的烧录速度较慢,读取flash芯片的速度也非常慢,而调试的时候需要频繁修改程序,对程序的读取、写入速度对开发速度影响很大。因此对调试来说,一般讲程序直接烧入片内ram或者是片外的ram中运行的,这样调试速度极快。这在IAR中是通过在linker中所设置的icf文件所实现的,在调试时,我们一般讲icf中RAM ROM都设置为片内ram的地址范围,这样程序在链接时所使用的地址范围都在片内ram中,IAR调试时将程序镜像放于片内RAM中,跳转到入口程序__iar_start就可以对程序进行调试了。但有时片内RAM空间并不够使用,我们需要使用片外的RAM,但是我们需要知道,使用片外RAM的话我们需要首先设置CPU内相应的存储器管理寄存器,告诉CPU如何访问片外RAM(主要有片外RAM 地址、大小、位宽、时序等)这部分工作是需要在程序写入片外RAM之前就完成的,所以将这部分指令实现为IAR下的linker设置中的mac文件,在该文件中完成对CPU相关寄存器的设置后,IAR通过仿真器向片外RAM写入数据。这里需要说明一个问题就是异常向量的访问,我们在片内或者片外RAM中调试程序的时候,是不能够运行正常的异常向量的,我们知道异常向量表是在地址空间0x000000的位置的,一般是flash空间,(不经过Remap,MMU的修改,关于Remap,MMU在这里就不进行展开说明了,改日再讨论)而我们的程序都是写入RAM地址空间的,这就导致我们的程序如果进入异常状态那就肯定会跑飞,就是说程序跳转到异常处理函数,而异常处理函数又指向一个不存在的函数地址,这样就非常不方便调试异常状态了。

再说一下关于片内flash,片外flash的调试方法,首先,我们要明确,只要是flash不管是NAND,还是Norflash,对flash芯片的访问都是需要驱动程序的,这是嵌入式初学者经常糊涂的地方,对Norflash来说,它的地址线、数据线连接与片外SRAM,SDRAM其实是差不多的,为什么对SRAM,SDRAM我们只需要在mac文件中设置寄存器,而flash确一定要使用驱动程序那,这里,主要是对RAM的访问,我们只需要设置地址、大小、位宽、时序就可以访问了,而对flash来说,我们在向其中写入或者读出数据,我们首先要向flash芯片内相应的寄存器写入命令才能都完成后续的读取、写入、设置的操作,这就是flash芯片驱动程序的作用。可能有人发现,IAR下对片内flash并没有设置flash驱动程序啊,其实这部分在我们设置工程中使用的DEVICE名称时就自动设置好啦,如我们使用LM1138的芯片,IAR在将程序写入片内flash时,自动调用LM1138的flash驱动函数向flash中写入程序。这样片外flash又该如何操作那,这里就要说一下啦,只要是flash就必须要有驱动,对flash芯片的烧录过程就是首先,IAR在芯片的片内RAM中运行flash驱动程序,将程序烧录入片内或者片外的flash芯片中。片内非flash驱动IAR已经自动设置好啦,片外的flash就需要我们来写驱动了,这里就有两种方式来调用驱动了,一个是在IAR下编译根据flash芯片的数据手册编写驱动,然后通过IAR的flashloader调用编译好的驱动程序,片外flash芯片写入数据。还有就是功能比较全面的仿真器,可以直接在设置时指定片外flash芯片驱动程序,IAR通过相应的调试接口支持相关的仿真器的在线调试。使用JLINK的话只能通过在IAR下编写片外flash芯片驱动的方式开实现对片外flash芯片读写的需要。

最后说一下程序链接与程序烧录的关系,在程序链接时指定ROM,RAM地址的范围,ROM,RAM其实就相当于程序烧录地址,也就是说,设置链接器地址时需要对应芯片数据手册、开发板的地址空间范围等,设计好程序运行地址空间,设置链接地址。

原文地址:https://www.cnblogs.com/AppleCai/p/10777952.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


  译序:JWMediaPlayer是开源的网页使用的Flash播放器。本文采摘于JWPlayer的官方文档,讲解了JWPlayer对于RTMP的使用方法,我们可以从JWPlayer客户端的角度来了解RTMP协议。以下是官方原文:      简介    RTMP(RealTimeMessagingProtocol
    Flash编程原理都是只能将1写为0,而不能将0写成1.所以在Flash编程之前,必须将对应的块擦除,而擦除的过程就是将所有位都写为1的过程,块内的所有字节变为0xFF.因此可以说,编程是将相应位写0的过程,而擦除是将相应位写1的过程,两者的执行过程完全相反.一、Nor和NandFlash
 上传setenvgatewayip192.168.1.1;setenvserverip192.168.1.7;setenvipaddr192.168.1.156;mw.b0x820000000xff0x1000000sfprobe0sfread0x8200000000x1000000tftp0x82000000test.bin0x1000000 下载mw.b82000000ff1000000tftp82000000test.bi
Error:FlashDownloadFailed-"Cortex-M3"出现一般有两种情况:1.SWD模式下,Debug菜单中,Reset菜单选项(Autodetect/HWreset/sysresetReq/Vectreset)默认是AutoDetect,改成SysResetReq即可。2.Jtag模式下,主要是芯片大小选错。Flash->ConfigureFalshTools配置窗口,切换到“Utilities"
jPlayer是一个用于控制和播放mp3文件的jQuery插件。它在后台使用Flash来播放mp3文件,前台播放器外观完全可以使用XHML/CSS自定义。支持:有一点比较好的是,在支持html5的浏览器上会使用html5的标签audio或者video,而不支持的浏览器上使用swf来播放选择需要播放的Mp3文件。播放、暂停
#ifndef__FONTUPD_H__#define__FONTUPD_H__#include"sys.h" //字库信息结构体定义33字节__packedtypedefstruct{u8fontok;//字库存在标志,0XAA,字库正常;其他,字库不存在u32ugbkaddr;//unigbk的地址u32ugbksize;//unigbk的大小u32f12addr;//gbk12地址u32g
ROM(ReadOnlyMemory)和RAM(RandomAccessMemory)指的都是半导体存储器。ROM在系统停止供电的时候仍然可以保持数据,而RAM通常都是在掉电之后就丢失数据,但是访问速度快。典型的RAM就是计算机的内存。RAM有两大类,一种称为静态RAM(StaticRAM/SRAM),SRAM速度非常快,是目前读写最快的存储
JSpc端和移动端实现复制到剪贴板功能实现在网页上复制文本到剪切板,一般是使用JS+Flash结合的方法,网上有很多相关文章介绍。随着HTML5技术的发展,Flash已经在很多场合不适用了,甚至被屏蔽。本文介绍的一款JS插件,实现了纯JS方法复制文本到剪切板。插件名是Clipboard.js,该插件不依
例子:R0=1R1=1R2=10R3=e000ed10R12=0LR=fffffff9(中断返回值)PC=0PSR=60000013或60000016或60000036(Z、C、EXCEPT_NUM:RTC_WKUP_IRQn、EXTI0_IRQn、USART2_IRQn)BFAR=e000ed38(不关心)CFSR=20000(INVSTATE:Invalidstateusagefault thePCvaluestackedf
 内存接口概念首先来分析下操作GPIO控制器和操作UART控制器两者的区别如图是S3C2440是个片上系统,有GPIO控制器(接有GPIO管脚),有串口控制器(接有TXDRXD引脚)配置GPIO控制器相应的寄存器,即可让引脚输出高低电平;配置UART控制器相应的寄存器,即可让引脚输出波形。前者相对简单,类
小编导语:    近几年来,网页游戏成为了游戏界关注的焦点,由于其制作简单,成本低并且收益率较高,因此成为了众多游戏厂商追逐的对象,但是除了商家夸张的炒作宣传外,很少有页游佳作出现。然而,随着Unity3D游戏引擎的出现,网页游戏的3D化成了页游冲出重围的杀手锏,那么在flash网页游戏称
1.指定数组到特定的Flash单元#pragmalocation=0x000FFF00 __rootconstcharFlash_config[]={0x0,0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xA,0xB,0xC,0xD,0xE,0xF,0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,0x18,0x19,0x1A,0x1B,0x1C,0x1D,0x1E,0x1F,0x20,0x21,0x22,0x23,0
继续研究发现,计算机的固件真的很有趣。参考了一些重要的资料,比如http://donovan6000.blogspot.com/2013/06/insyde-bios-modding-advanced-and-power-tabs.html等,对于IDA的使用也了解了一些。最后,总结一下目前看来可行性的方案:0.基础知识储备,包括UEFIBIOS的概念,InsydeBIOS的
<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>navigator对象<itle></head><body><buttononclick="checkFlash()">检测</button>
修改网上流传的flash-marker.js(function(global,factory){typeofexports==='object'&&typeofmodule!=='undefined'?module.exports=factory():typeofdefine==='function'&&define.amd?define(factory
shareObject本地缓存存储位置:win7系统用户到C:\Users\[你的用户名]\AppData\Roaming\Macromedia\FlashPlayer\#SharedObjects\XP或2003用户到:C:\DocumentsandSettings\用户名\ApplicationData\Macromedia\FlashPlayer\#SharedObjects\ ---------------------作者:iteye_
安装谷歌浏览器之后经常遇到Flash崩溃或者浏览器在浏览Flash内容时卡死的情况。在网上查找资料大多都认为应该是浏览器自带的Flash插件工作模式引起的问题,解决方法如下:首先在地址栏输入chrome://plugins/显示浏览器使用的插件。点击右上角的详细信息,可以看到Flash插件为进程外
之前一直使用的W25Q16spiflash都没问题,换了一款W25Q80后发现工作不正常,经过测试,初步定位到问题在于初始化SPI后是否将CS拉高。于是又去查看了一下原厂代码:发现原厂的代码初始化SPI接口时是专门拉高CS的。结论:网上很多代码初始化SPI接口时没有专门拉高CS,对某些型号可能确实
======================================================NANDFlash最小存储单元:写数据操作:通过对控制闸(ControlGate)施加高电压,然后允许源极(SOURCE)和汲极(RRAIN)间的N信道(N-Channel)流入电子,等到电流够强,电子获得足够能量时,便会越过浮置闸(FloatingGate)底下的二氧化硅层(S
安装CnarioPlayer3.8.1.156或其他版本时,有时会出现如下提示:Warning4154.AdobeFlashPlayer13...notcorrectlyinstalled:请前往AdobeFlash网站,并选择下图示的版本下载安装: