1.引导镜像区  0x0000_0000~0x07FF_FFFF

2.内部存储区

(1) 内部ROM      0x0800_0000~0x0BFF_FFFF

(2) 内部SRAM    0x0C00_0000~0x0FFF_FFFF

3.静态存储区  0x1000_0000~0x3FFF_FFFF

4.动态存储区  0x4000_0000~0x6FFF_FFFF

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

3.2内存
Memory,又叫主内存,分为4大区域,分别是启动镜像区、内部内存区、静态内存区、动态内存区。

启动镜像区物理地址为0x00000000~0x07ffffff,共128MB。这个区域的作用正如它的名字所述,是用来启动系统的。但是这个范围内并没有实际的存储 介质与之对应,只能在通过OM[4:0]选择具体的启动介质后再把相应介质的物理地址映射到这个启动区,比如说选择了IROM 启动方式后,就把IROM所占的地址空间映射为0x00000000开始的空间。

内部内存区物理地址为0x08000000~0x0fffffff,共128MB。这个区域对应着内部的内存地址,内部的ROM和SRAM都是分布在这个 区间。其中,0x08000000~0x0bffffff对应着内部ROM,当然实际上内部的ROM也并没有64MB这么多,只有32KB是有实际存储介 质的,这32KB是一个只读区,放的是IROM方式下的启动代码,选择IROM启动的时候首先运行 的 代码就是这一部分,称为BL0,这部分代码由厂家固化。0x0c000000~0x0fffffff对应内部SRAM,实际可用的SRAM按照三星的手册 是4KB,其实这就是用于nand flash启动的Steppingstone(但是这个Steppingstone是8KB,这2者似乎有矛盾,不知道是不是我的理解不对)。

静态内存区物理地址为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的4KB(or 8K?)SRAM被映射到bank2开始的4KB,而在以nand flash方式启动的时候bank2被映射到0x00000000开始的地方,实际上就是把Steppingstone映射到0x0000000了,这和 S3C2410的情况还是相似的。

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

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总线传输。

特殊设备地址空间:

s3c6410存储器映射相关推荐

  1. Cortex-M3中的存储器映射

    文章目录 1 Cortex-M3中的存储器映射 1 Cortex-M3中的存储器映射 Cortex-M3中的预定义的存储器映射,如下图,注意,这里指的是规范,实际厂家并不一定完全按照这个规范做. SR ...

  2. ARM的存储器映射与存储器重映射【转载】2009-12-14 10:29最近在用LPC2148,看到了一篇文章,感觉很有帮助,就转了过来。

    ARM的存储器映射与存储器重映射[转载]2009-12-14 10:29最近在用LPC2148,看到了一篇文章,感觉很有帮助,就转了过来. arm处理器本身所产生的地址为虚拟地址,每一个arm芯片内都 ...

  3. stm32存储结构 存储器映射

    问题: 1   什么是存储器映射?是怎么一个运作过程? 2   stm32总体架构 3   CM3内核结构 1 STM32系统结构 要想深刻理解STM32的存储器,需要首先知道STM32的系统结构. ...

  4. Cortex M3存储器映射

    CortexM3存储器系统 宗旨:技术的学习是有限的,分享的精神是无限的. CM3 只有一个单一固定的存储器映射.这一点极大地方便了软件在各种 CM3 单片机间的移植. 存储空间的一些位置用于调试组件 ...

  5. 【STM32存储器映射-寄存器基地址-偏移】

    前言 在学习STM32的时候,我们看到很多的寄存器编程, 比方说LED灯: //GPIOB.5端口输出高电平GPIOB->ODR|=1<<5; //PB.5 输出高GPIOE-> ...

  6. Cortex-M3存储器映射

    CM3存储器映射概览 CM3的地址空间是4GB,程序可以在代码区.内部SRAM区以及外部RAM区中执行.但是因为ICode总线与DCode总线只能访问代码区,因此最理想的是把程序放到代码区,从而使取指 ...

  7. MKL25Z128 Cortex-M0微处理器架构定义的存储器映射

  8. 蓝桥杯基础模块9:IO口扩展与存储器映射

    一.模块题目 二.原理简述 三.源码 (1)I0扩展 //头文件 #include "reg52.h" //延时函数 void Delay(unsigned int t) {

  9. S3C6410设备时钟源选择、启动方式选择和内存映射

    ********************************LoongEmbedded******************************** 作者:LoongEmbedded(kandi ...

最新文章

  1. 清华成立“脑与智能”和“未来”两大实验室,跨学科AI深度融合
  2. 高并发软件设计的几种方式
  3. 微信小程序界面跳转(2)——按钮
  4. Leecode07. 整数反转——Leecode大厂热题100道系列
  5. 在独立Java应用程序中使用Tomcat JDBC连接池
  6. linux删除文件_Linux删除文件夹用什么命令
  7. access 文本转换数字_LabVIEW访问Access数据库教程
  8. html图片倒角,CSS实例:纯CSS打造斜角
  9. 6-2-JSP基本语法
  10. excel排名_排名数据应该用什么图表?Excel有这样的图表吗?- Excel图表教程
  11. ajax绑值,vue.js使用ajax绑定数据之post方法
  12. Solr7.2.1环境搭建和配置ik中文分词器
  13. Java面试必问!Spring事务扩展机制(2)
  14. 解读灰度直方图的信息
  15. Atitit  循环(loop), 递归(recursion), 遍历(traversal), 迭代(iterate).
  16. 炫酷的时间样式HTML,js动态炫酷数字时钟
  17. 64位驱动 hp630打印机_HP LaserJet1010 打印机驱动win7 64位
  18. 蘑菇街面经(自己的第一次秋招面试)
  19. 科学论文的写作内容与要求
  20. Prisemi芯导充电和保护硬科技亮相亚洲蓝牙耳机展

热门文章

  1. kubernetes ConfigMap和Secret:配置应用程序
  2. Statefulset:部署有状态的多副本应用
  3. Asp.Net Core 轻松学-玩转配置文件
  4. 题解-bzoj3901 棋盘游戏
  5. linux中时间命令详解
  6. video标签 api
  7. 一步一步SharePoint 2007之十五:实现Form认证(5)——更改认证的Provider
  8. 云原生和ServiceMesh主要组件--理解K8s/Istio/Envoy
  9. Spark源码分析之DiskBlockMangaer分析
  10. (125)FPGA面试题-熟悉AXI总线吗,介绍AXI