共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电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
stm32f103驱动舵机被打赏20分 | |
汽车+汽车电子电阻解释与分析被打赏5分 | |
STM32F103的I2C驱动OLED动态显示被打赏30分 | |
分享汽车通信和多媒体总线结构被打赏20分 | |
【我踩过的那些坑】结构堵孔导致的喇叭无声问题被打赏50分 | |
NUCLEO-U083RC学习历程38+串口通过队列的方式输出两个字符串被打赏20分 | |
【我踩过的那些坑】分享一下调试一款AD芯片的遇到的“坑”被打赏50分 | |
电流检测模块MAX4080S被打赏10分 | |
【我踩过的那些坑】calloc和malloc错误使用导致跑飞问题排查被打赏50分 | |
分享电控悬架的结构与工作原理(一)被打赏20分 |