这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 综合技术 » 基础知识 » VXWORKS,NUCLEUS,keil,for,arm,01a,ccd,135

共2条 1/1 1 跳转至

,VXWORKS,NUCLEUS,keil,for,arm,01a,ccd,13581980230, 急问,一个2410与NAND FLASH接法的问题

院士
2006-09-17 18:14:16     打赏
,VXWORKS,NUCLEUS,keil,for,arm,01a,ccd,13581980230, 急问,一个2410与NAND FLASH接法的问题



关键词: VXWORKS     NUCLEUS     135819802    

院士
2006-12-22 22:43:00     打赏
2楼
问 2410有专门的nand flash接口,启动时om=00从它启动。
请问若只用nand做存储器,启动完成之后,ngcs0片选需要接到nCE上么(nFCE何去何从),在对它读写的华,2410还是会用nFRE,nFWE来控制,还是用WE,OE。2410怎么知道启动之后我用的还是nand flash。。。? 1: 我觉得是从地址来看的om=00与om=01时,地址排布不一样 2: 急问,一个2410与NAND FLASH接法的问题我知道1dqmoon说的地址map不一样,ngcs0对应steppingstone,但datasheet始终没说,启动以后再读写nand的时候,把它映射到哪去了、、、
3: 感觉是接着执行了steppingstone大小为4k,但一般的引导程序(如vivi,)肯定大于4k,
所以我感觉是接着执行下去了,即0-4k是在steppingstone中执行,执行完后回到nand的4k位置接着执行,steppingstone被映射到nand的0-4k了

如果有仿真器的话,应该可以看出来 4: 大概是这样的    系统上电时,CPU首先检测0M1和0M0两个管脚电平状态,如果OM=00,系统从NAND FLASH启动,如果OM=01或10,系统从NGCS0所接16BIT或32BIT的存储器启动。
    当0M=00时,CPU会检测GPG13/GPG14/GPG15/NCON几个管脚状态,从而确定NAND FLASH的类型,当确定NAND FLASH类型后,CPU会自动的通过NAND FLASH的控制寄存器把NAND FLASH的前4K程序代码映射到CPU内部的4K SRAM空间,然后跳转到SRAM开始执行。使用NAND FLASH BOOT时,我们一般会在前面4K的程序里初始化中断、存储器、时钟频率等,然后使用程序代码把NAND FLASH空间的代码搬移到SDRAM的空间里,然后执行跳转或者重映射指令,跳转到SDRAM的空间执行。当系统启动后,读取NAND FLASH的数据是通过NAND FLASH的控制寄存器进行,NAND FLASH有专门的读写控制端口,不需要普通的总线读写信号,如果没有连接NOR FLASH之类的存储器,NGCS0可以悬空,不用管它。

    当OM=01或10时,系统从NGCS0所接的片选空间启动,因为此空间是线性地址空间,所以程序代码可以直接在此空间运行,不过可能运行速度会比较慢,一般的做法是把程序代码搬移到SDRAM的空间执行。


共2条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]