S3C6410存储映射

1 存储系统块图

       我们以行为单位来看,在每一行中,最前面的两列表示的是地址范围,后面的几列则是不同的存储控制器。在每一行中用粗边框标示出来的部分表示最前面两列的地址范围映射到这个区域当中。例如:最后两行的地址范围:0x50000000~0x5FFFFFFF和0x60000000~0x6FFFFFFFF分别映射到了DRAM控制器。用6410芯片的人应该对0x50000000这个内存地址比较熟悉。当然,我们注意到了,出现了单个地址映射到了多个存储控制器,例如:0x28000000~0x2FFFFFFF这个地址范围映射到了SROM控制器和One NAND控制器上。这是为什么呢?看下面的注解就知道了。
注解)6410X PoP A类型的不支持NAND Flash。所以此时我们可以忽略掉NAND Flash控制器这一列。6410X PoP D类型的不支持OneNANF Flash控制器,此时可以忽略OneNAND Flash控制器这一列,这样就不会冲突了。
表格中还有上脚标为1和2的符号,他们的含义分为别:
上脚标1代表在这个地方的内容在存储子系统这一节中有详细说明。

上脚标2代表这个地址可以同时被映射到SROM控制器和OneNAND控制器。详细的信息也在存储子系统这一节中介绍。


官方解释:

   S3C6410X支持32位的物理地址,这些地址域可以被分为两个部分,一个部分用于存储,另外一个用于外设。

  我们可以通过SPINE总线来访问主要存储区域,它的地址范围是0x0000_0000~0x6FFF_FFFF.这个主要的存储区域被分为四个区域:引导镜像区、内部存储区/静态存储区和动态存储区。
   引导镜像区的地址范围是0x0000_0000~0x7FFF_FFFF,但是这里没有实际映射的存储。引导镜像区在内部存储区或者是内部镜像区中有一个镜像区域。引导镜像的地址固定为0x0000_0000.
   内部存储区用来访问内部ROM和用于boot loader的内部SRAM这两个区域的。其中,用于boot loader的内部SRAM区域也被称作Steppingstone。每一个内部存储区的起始地址都是固定的。内部ROM的地址范围是0x0800_0000~0x0BFF_FFFF,但是实际的存储大小只有32KB。这个区域是只读的,并且当选择内部ROM启动方式时,这个区域可以被映射到引导镜像区。内部SRAM的地址范围是0x0C00_0000~0x0FFF_FFFF,但是实际的存储大小只有4KB。
   静态存储区的地址范围是0x1000_0000~0x3FFF_FFFF.我们可以通过这个地址访问到:SROM、SRAM、NOR Flash、异步NOR接口的设备、OneNAND Flash和Steppingstone。每一个区域都代表一个芯片被选择,例如:地址0x1000_0000~0x17FF_FFFF代表Xm0CSN[0].每一个被选择的芯片的起始地址都是固定的。我们不能通过静态存储区来访问NAND Flash和 CF/ATA,因此,如果任何的Xm0CSn[5:2]被映射到了NFCON或者CFCON,相关的地址区域是不能被访问到的。但是有一个例外,那就是当Xm0CSn[2]用于NAND Flash时,Steppingstone就镜像到了区域0x2000_0000~0x27FF_FFFF.
   动态存储区域的范围是0x4000_0000~0x6FFF_FFFF.DMC1有权利使用0x5000_0000~0x6FFF_FFFF这个地址范围。每一个被选择的芯片的起始地址都是可以配置的。

   我们可以通过PERI这个总线来访问外设,它的地址范围是0x7000_0000~0x7FFF_FFFF.所有的SFRs都可以通过这个地址范围访问到。当然,如果我们需要从NFCON或者是CFCON来传输数据,那么这些数据也必须通过PERI总线来传输。
学者总结:

S3C6410的物理内存分成Memory和Pheriperal两部分,地址范围分别为0x0~0x6fffffff和0x7fffffff~0xffffffff。系统通过 SPINE总线访问Memory空间,通过PERI总线访问Pheriperal空间。而为了适应不同外设的访问速度,又分别通过AHB总线访问LCD、 Camera、Accelerator等高速外设,通过APB总线访问iic、watchdog等低速外设。  

Memory:


(1)启动镜像区物理地址为0x00000000~0x07ffffff,共128MB,是用来启动系统的。但是这个范围内并没有实际的存储介质与之对应,只能在通过OM[4:0]选择具体的启动介质后再把相应介质的物理地址映射到这个启动区,比如说选择了IROM 启动方式后,就把IROM所占的地址空间映射为0x00000000开始的空间。引导镜像区反映一个镜像,这个镜像指向内存的一部分区域或者静态存储区。引导镜像的开始地址是0x0000_0000。

 

(2)内部内存区物理地址为0x08000000~0x0fffffff,共128MB。这个区域对应着内部的内存地址,内部的ROM和SRAM都是分布在这个区间。其中,0x08000000~0x0bffffff对应着内部ROM,当然实际上内部的ROM也并没有64MB这么多,只有32KB是有实际存储介质的,这32KB是一个只读区,放的是IROM方式下的启动代码,选择IROM启动的时候首先运行的代码就是这一部分,称为BL0,这部分代码由厂家固化。0x0c000000~0x0fffffff对应内部SRAM,可读可写,当NAND 闪存启动被选择时能映射到引导镜像区。  。

 

(3)静态内存区物理地址为0x10000000~0x3fffffff,共6*128MB。这个区域用于访问挂在外部总线上的设备,比如说SRAM、NOR flash、oneNand等。这个区域被分割为6个bank,每个bank为128MB,数据宽度最大支持16bit,每个bank通过 Xm0CS[5:0]来划定。和S3C2410 不一样的是,bank2~bank5能映射到nand flash、CF等非线性存储器,这并不是说可以通过bank2~bank5的地址段就能直接访问nand flash、CF内部的地址,相反,当映射到这些器件的时候这些bank的地址也不能再使用了,访问这些非线性存储器还是得通过Pheriperal空间的AHB总线进行,和S3C2410中的访问方式是一样的。不过有一个特例是,当Xm0CS2被映射到nand flash的时候,Steppingstone的SRAM被映射到bank2开始的4KB,而在以nand flash方式启动的时候bank2被映射到0x00000000开始的地方,实际上就是把Steppingstone映射到0x0000000了,这和 S3C2410的情况还是相似的。

 

(4)动态内存区物理地址为0x40000000~0x6fffffff,共3*256MB。其中第一个256MB为保留区,实际使用的动态内存区为 0x50000000~0x6fffffff,又分为2个区间,分别占256MB,可以通过DMC的Xm1CS[1:0]来进行着2个区间的选择。这个内存区主要是扩展DRAM,最大可以扩展512MB的DRAM。

2.Pheriperal外设区域通过PERI 总线被访问,它的地址范围是0x7000_0000~0x7FFF_FFFF。这个地址范围的所有的SFR能被访问。而且如果数据需要从NFCON或CFCON 传输,这些数据需要通过PERI总线传输。



 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/30108475/viewspace-1713689/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/30108475/viewspace-1713689/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值