共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网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
【笔记】生成报错synthdesignERROR被打赏50分 | |
【STM32H7S78-DK评测】LTDC+DMA2D驱动RGBLCD屏幕被打赏50分 | |
【STM32H7S78-DK评测】Coremark基准测试被打赏50分 | |
【STM32H7S78-DK评测】浮点数计算性能测试被打赏50分 | |
【STM32H7S78-DK评测】Execute in place(XIP)模式学习笔记被打赏50分 | |
每周了解几个硬件知识+buckboost电路(五)被打赏10分 | |
【换取逻辑分析仪】RA8 PMU 模块功能寄存器功能说明被打赏20分 | |
野火启明6M5适配SPI被打赏20分 | |
NUCLEO-U083RC学习历程2-串口输出测试被打赏20分 | |
【笔记】STM32CUBEIDE的Noruletomaketarget编译问题被打赏50分 |