分类: 嵌入式
2010-07-23 13:15:12
用友善之臂的板子已经有一段时间了.对于存储系统和I/O空间的认识也渐渐淡忘了,原因是在做其他开发时,一直用着自带的启动代码,从不关心板子的储存空间配置.最近在做网卡驱动,突然间就不知道网卡的地址是什么了,于是花点时间总结一下.废话少说.开始吧.
1,板上的存储资源
两个
一个
一个
以上这些资源看原理图便知.
2,板上的I/O资源
这块板子上(准确的说是S
3,各种存储器的区别与各自的用途
为什么这块板子上有那么多存储设备呢?原因很简单.每种存储设备的用途都不一样,而且为了兼顾广大用户的需要,也必须有不同的存储设备.首先说SDRAM.(写到这突然想起忘了说SRAM了.SRAM是静态随机存储器,它具有掉电不丢失数据且不必频繁刷新的特点,存储速度快,相当于PC的内存,看来这块相当于内存的东西很重要,可是刚刚怎么没说有这块东西呢?原因很简单.因为本来就没有.其实,如果需要随机存储器,SDRAM就是随机存储器啊,只是它需要不断的刷新以保持里面的数据(电平)。说到这,SDRAM的作用同学们也应该了解了.也就说我们这块板子就是有
其次说说NOR FLASH.NOR FLASH是具有SRAM接口特性的ROM。记住,是ROM,也就说,它相当于PC里的硬盘,可是NOR FLASH才
再说说NAND FLASH,NAND FLASH可以做的很大,但是速度却比不上NOR FLASH,NOR FLASH能做快却不能做的大,所以,速度和容量是一对矛盾.为了克服这对矛盾,这板子上两种FLASH都有了.各有用途.另外,初学者一定要知道NAND FLASH 与NOR FLASH启动的不同吧.这是跟他们的特性有关的,接下来谈谈.
4,NOR FLASH 启动与NAND FLASH 启动
开发板上有一个S2开关,当它打在NOR一端是就是NOR启动.相反,打在另一端就是NAND FLASH启动了.先说这两种启动的不同,再说说硬件上是如何启动的,空间又是如何分配的。
当S2打在NAND FLASH启动,那么程序就是在NAND FLASH上跑起来。其实,在内部还有一个4K字节的steppingstone的缓冲器(其实这是一个SRAM),当选择NAND FALSH 启动时,这个缓冲器映射在地址0x0000_0000上,而它负责将NAND FLASH上的代码复制到SDRAM上(大家都知道,程序运行时都是在RAM上运行的,怎么可能是在FLASH上运行呢,其实就是将FLASH上的代码复制了而已)而负责复制这段代码的东西就是传说中的BIOS啦.
当S2打在NOR FLASH一端时,又有什么区别呢?当选择用NOR FLASH启动时,
4,S
大家都知道,32位可以寻址
(途中只显示最低的
0~0x4000_0000(只有
还有
OM[1:0]=01或者是10 时(NOR FLASH):
0x4000_0000-0x4000_0fff
-----这4K字节的就是前面说的stepingstone的啦。0x4000_0fff_0x4800_0000是没用到的。
0x4800_0000-0x6000_0000
-----这空间是特殊功能寄存器的.你发现,所有的寄存器都是在这个范围内的。
0x6000_0000—0Xffff_ffff
-----还是未用到的。
OM[1:0]=00时(NAND FLASH):
这个时候如上图所示。刚刚说的steppingstone映射到0x000_0000那里,也即是图中的BOOT INTERNAL SRAM。其他的一样.
其实,S
刚刚说S
说的差不多了.应该有很多需要完善的,但是这对于初学者来说还是有一定的帮助吧?