共2条
1/1 1 跳转至页
,VXWORKS,NUCLEUS,keil,for,arm,01a,ccd,13581980230, 急问,一个2410与NAND FLASH接法的问题
问
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的空间执行。
请问若只用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 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图四被打赏50分 | |
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 |