ARM内存映射

寻址空间

ARM处理器为32bit处理器,内部32bit地址总线理论寻址空间为4GB,对于6410来说,寻址空间的高2GB在内部为保留(reserved),低2GB(0x0~0x7FFFFFFF)可划分为2部分:主存储区(main memory area)和外设区(peripheral area)。

 

 

主存储空间(Main memory area)

 

6410内核与主存储空间通过SPINE总线连接,主存储为地址空间0x0~0x6FFFFFFF,大小为1792MB的一片区域;其中主存储空间在6410内部划分为以下几部分:

  • Boot镜像区(Boot image area)
  • 内部存储区(Internal ROM area and internal SRAM area)
  • 静态存储区(Static memory area)
  • 动态存储区(Dynamic memory area)
  • 保留区(Reserved memory area) 

Boot镜像区位于6410寻址空间的0x0~0x07FFFFFF(128MB)位置,这段区域并没有真正的存储设备,实际运行过程中是映射到内部存储区或静态存储区,Boot镜像区固定起始地址为0x00000000。

Boot 镜像区没有实际的存储设备,只是在一些特定区域的“镜像”,之所以有这种位于0x0地址镜像,主要是因为ARM内核启动之后强制PC从0x0地址开始取指有关。至于与哪些特定区域镜像,与系统配置密切相关(关于系统启动配置详见后续章节说明),当系统为:

1)       SROM (8 bit/16 bit)启动(booting)

当系统为SROM booting 配置,Boot镜像区为SROM控制器的第0个bank(128MB),即0x10000000~0x17FFFFFF地址,支持的存储器可以是SRAM、ROM、Nor flash等,对应地址片选引脚Xm0CSn[0]。

2)       MODEM(8 bit/16 bit)启动(booting)

当系统为MODEM Booting配置,Boot镜像区仅地址为0x00000000~0x00007FFF的32KB区域有效,且对应为6410内部的I_ROM区低32KB字节0x08000000~0x08007FFF。

3)       ONENAND 启动(booting)

当系统为ONENAND 模式启动配置,整个Boot镜像区0x0~0x07FFFFFF全部为静态存储器0x20000000~0x27FFFFFF地址镜像,128MB一一对应。

6410支持2 Bank个ONENAND 地址映射区,分别为ONENAND0 和ONENAND1,只有ONENAND0对应的地址才可能在启动时候镜像到Boot镜像区。

4)       IROM启动(booting)

IROM启动设置之后,Boot镜像区仅地址为0x00000000~0x00007FFF的32KB区域有效,且对应为6410内部的I_ROM区低32KB字节0x08000000~0x08007FFF。

顺便提及一下,I_ROM主要实现的功能是在系统启动之后,执行一些内核、外设初始化,搬移启动代码到Stepping stone区域,然后跳转到该区域执行后续的Booting。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值