搜索
bottom↓
回复: 4

有关S3C2440启动的问题(新手)

[复制链接]

出0入0汤圆

发表于 2011-2-26 11:18:14 | 显示全部楼层 |阅读模式
三星S3C2440用nand flash启动方式的起始地址是0x30000000.bootloader是不是要下载到地址为0x30000000??如果是的话。。那不是一掉电就清楚了吗。。那是内存地址。。nand flash的存储什么的?

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2011-2-26 11:32:45 | 显示全部楼层
可以把nand falsh想象成pc硬盘,sdram相当于pc的内存

无论是nand启动还是nor启动,启动时程序计数器(pc)都是指向0x00000000的,也就说从cpu地址总线地址0x000000000处的存储单元读取指令并译码执行。

由于程序可以在nor中运行,而nor又是映射到地址0x00000000开始的一段空间的,所以此时不需要其他特殊处理即可一直运行。

程序无法直接在nand中运行,而nand启动时pc又是指向0x000的,这就造就了一个矛盾,为了解决这个矛盾,2440在内部提供了一个4k的缓冲区,启动时,cpu会自动把nand开始4k的内容复制到缓冲区中,此时映射到地址0x0的存储器则是这段4k的缓冲区,cpu从缓冲区中提取指令并译码执行,4k总是有限的,需要找到某种措施将nand中剩余的代码复制到sdram然后将pc的值指向sdram所在的地址(在大多数2440开发板中是0x30000000).


对于烧入内存的程序,掉电后是会丢失的,如果要烧入nand,则需要在程序中加入从nand拷贝
数据到内存的代码

出0入0汤圆

发表于 2011-2-26 11:57:04 | 显示全部楼层
回复【1楼】luo496724812
-----------------------------------------------------------------------

楼上讲得很清楚,我也有个问题,就是那个4KB的SRAM中的.S启动代码,可不可以调用其他的.C中的函数?看到有些人移植的UBOOT有那样用,不知道链接的时候会不会出问题呢?

出0入0汤圆

发表于 2011-2-26 12:07:56 | 显示全部楼层
回复【2楼】yeahmen  
回复【1楼】luo496724812
-----------------------------------------------------------------------
楼上讲得很清楚,我也有个问题,就是那个4kb的sram中的.s启动代码,可不可以调用其他的.c中的函数?看到有些人移植的uboot有那样用,不知道链接的时候会不会出问题呢?
-----------------------------------------------------------------------

启动代码总大小不大于4k 应该没有问题

出0入0汤圆

 楼主| 发表于 2011-2-26 12:37:02 | 显示全部楼层
回复【1楼】luo496724812
-----------------------------------------------------------------------

谢谢了。。总算清楚多了。。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-23 23:29

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表