`
womendu
  • 浏览: 1474708 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

S3C2440存储控制器和MMU浅析

 
阅读更多

S3C2440存储控制器和MMU浅析

K-Style

转载请注明来自于衡阳师范学院08电2 K-Style http://blog.csdn.net/ayangke,QQ:843308498 邮箱:yangkeemail@qq.com

一、S3C2440存储控制器

如果大家写过S3C2440的ARM裸机程序都应该知道通常SDRAM的起始地址是0X30000000,但是大家有没有想过为什么呢?下面我将给大家做一个简要的介绍。

查S3C2440的手册可知S3C2440可寻址1G的地址范围,但是S3C2440的地址线只有27根,理论上只能寻址2的27次方等于128M的地址范围。于是S3C2440通过一个叫BANK的东东解决了这个问题。S3C2440引出了8根BANK线(对应nGCS0~ nGCS7),通过这个8根线来选通和关闭不同的存储器,这样S3C2440最多就可以连接8个128M的存储器,只要在某一时刻只选通一个BANK就可以实现1G的寻址空间每个BANK有个地址,对该BANK地址的访问实际上就是选通该BANK,于是ARM核只要发出一个地址,然后S3C2440的储存控制器只要把该地址解释成两部分:一部分是BANK地址一部分是连接到该BANK存储器内部的地址就可以访问了。

而作为32位的CPU,可以使用的地址范围理论上可以达到2的32次方等于4G,除去上述的1G地址空间,还有一部分是CPU内部寄存器的地址,剩下的地址空间没有使用。

下面我们来看到S3C2440存储器的地址空间分布图


左边的是表示CPU从NOR FLASH启动时的地址空间图,右边是CPU从NAND FLASH启动时的地址空间图。从图中可以看出SDRAM接在BANK6上面,地址为0X30000000,这就解释了开始最开始的那个问题。问题又来了为什么CPU从NAND和NOR启动时地址空间不同?这是因为NOR是线性结构,跟普通的内存差不多,它接在BANK0上。而NAND则是另外一种结构,S3C2440有专用的NAND控制器和地址线来连接,它不能接在BANK0上。CPU启动时必定从0地址开始执行程序,而从NAND启动时,0地址没有存储器,那CPU怎么办呢?于是就出现了一种叫“起步石”(stepping stone)的东东,它是S3C2440内部的一块4K的存储器,当从NAND启动时,0地址线会连接到起步石上面,同时CPU会通过内部的硬件将NAND FLASH开始的4K数据复制到起步石里面。起步石里面的程序一般设计为对SDRAM进行初始化,然后将NAND里面的部分程序复制到SDARM,然后跳到SDRAM开始执行程序。所以当做U-BOOT移植使其支持从NAND的启动时,需要对NAND的前4K程序做处理。

下面我们再来看看S3C440存储控制器一般所接外设的访问地址和部分寄存器的访问地址




二、S3C2440MMU

1.MMU的作用

我们再第一部分讨论的全部都是物理地址,注意不要与这部分要将的虚拟地址给混淆起来。

内存管理单元(Memory ManagerUnit)简称MMU。它负责将虚拟地址转换成物理地址,然后传给上部分介绍的存储管理器进行寻址。

现代的多用户多进程操作系统通过MMU使各个用户进程都有自己的独立的地址空间:地址映射功能功能使的个进程拥有“看起来”一样的地址空间,而内存访问权限的检查可以保护每个进程所用的内存不会被其他进程破坏。

我来打个蹩脚的例子。甲同学(进程甲)去一个图书管理员那儿去借名为“内存”的一本书,说他7点钟要用。图书管理员给甲同学一个牌子上面写着哪个层楼房哪个房间有这本书,不过这块牌子只能7点钟去取书,且只能借三个小时(权限),而乙同学同样要借这本书不过是12点,图书馆同样给乙同学一块牌子,不同的时这块牌子只能12点钟去取书也只能借三个小时。结果是甲乙同学都借到了这本书,他们都感觉拥有了这本书,在他们拥有这本书的期间不会被其他同学打扰。实际上这里的同学就代表进程,图书管理员代表是内核,牌子代表的是虚拟地址,书代表实际的内存,而MMU完成的工作就是拿到同学的牌子帮同学找到书的过程。

虚拟地址最终要转成物理地址才能读写实际的数据,这通过将虚拟地址空间、物理地址空间划分为一个同样大小的一块块小空间,然后为着两类小空间建立映射空间,有可能多块虚拟地址映射到同一块物理地址空间,或者有些虚拟地址空间映射具体物理地址空间上去。启动MMU后,CPU对外发出虚拟地址,然后MMU将虚拟地址转成物理地址再进行访问。

2.虚拟地址空间到物理空间的转换过程

在ARM CPU中使用页表的方式进行转换。linux内核一般使用两级页表的方式。页表是个什么东东,他就像我们的书上的目录,有主目录,次目录。当我们要找一个知识点的时候先找到主目录,然后再找到次目录再找到相应的知识点。每一个进程都会在内存里面创建一个目录,目录的存放地址保存起来。当需要访问目录时,就会将目录放到CPU的一个专用寄存器里面,然后MMU读取这个寄存器里面的值就会帮我们找到我们要访问的物理地址。

页表是怎样建立的呢?

实际上它就是在内存的一个地址内存放了第一级目录的内存地址,然后在第一个级的目录的内存内又存放了实际的物理地址。

这里我只对MMU进行了粗略的介绍,要想详细了解,就去看韦东山的《嵌入式linux应用开发完全手册》的第7章。

分享到:
评论

相关推荐

    单片机与DSP中的S3C2440存储控制器和MMU浅析

    一、S3C2440存储控制器  如果大家写过S3C2440的ARM裸机程序都应该知道通常SDRAM的起始地址是0X30000000,但是大家有没有想过为什么呢?下面我将给大家做一个简要的介绍。  查S3C2440的手册可知S3C2440可寻址1G的...

    S3C2440存储管理器MMU实现

    S3C2440存储管理器MMU实现 ARM裸机——S3C2440内存管理单元(MMU) http://blog.csdn.net/dengpinbo/article/details/9291695

    MMU.zip_2440 m_mmu_mmu s3c2440_s3c2440 mmu.c_s3c2440 mmudeb

    ARM9 s3c2440 mmu example

    lib_arm.rar_S3C2440 Cac_arm cache_s3c2440_s3c2440 mmu

    源码包括ARM920t的S3C2440的lib_arm源码包,其中有中断 复位 CACHE等等

    S3C2440 MMU driver

    自己写的s3c2440 mmu 库,使用RealView MDK4.22开发环境,硬件平台友善MINI2440。

    S3C2440裸机驱动串口中断带MMU中断向量表重映射

    在JZ2440开发板上写了串口、按键、LED驱动,串口驱动使能接收中断,且S3C2440的中断向量表用MMU重映射到了SDRAM里面

    S3C2440全套中文手册_ljl.PDF

    本手册将介绍 S3C2440A 集成的以下片上功能: ● 1.2V内核供电, 1.8V/2.5V/3.3V储存器供电, 3.3V外部I/O供电,具备16KB的指令缓存和16KB的数据缓存和MMU 的微处理器 ● 外部存储控制器(SDRAM 控制和片选逻辑) ● ...

    MMU.rar_mmu_s3c2440 mmu

    ARM9 S3C2440内存管理mmu代码

    S3C2440_MMU.rar_2440MMU_mmu

    arm2440 MMU控制器,非常详细,容易看懂

    S3C2440完全开发流程

    S3C2440完全开发流程 一.简介 3 二.建立开发环境 4 1、编译器ARM-LINUX-GCC-3.4.1 4 2、JFLASH-S3C2440:S3C2440芯片的JTAG工具 4 3、安装GDB调试工具 5 4、USB下载工具 6 5、UBUNTU开发环境建立 6 三.S3C2440...

    S3C2440 MMU

    JZ2440的MMU使用方式,基于韦东山的开发手册编写,功能较弱

    S3C2440中文手册.PDF

    S3C2440中文手册.PDF 1.2V 内核供电, 1.8V/2.5V/3.3V 储存器供电, 3.3V 外部I/O 供电,具备16KB 的指令缓存和16KB 的数据缓存和MMU 的微处理器 ● 外部存储控制器(SDRAM 控制和片选逻辑) ● LCD 控制器(最大支持...

    s3c2440 头文件

    s3c2440 ads1.2 用jlink 调试时中断必须的虚拟内存映射的头文件mmu.c

    samsung_s3c2440中文手册

    ● 外部存储控制器(SDRAM 控制和片选逻辑) ● LCD 控制器(最大支持4K 色STN 和256K 色TFT)提供1 通道LCD 专用DMA ● 4 通道DMA 并有外部请求引脚 ● 3 通道UART(IrDA1.0, 64 字节发送FIFO 和64 字节接收FIFO) ...

    TQ2440裸机开发试验之Mmu_Nand.rar

    TQ2440裸机开发试验之Mmu_Nand.rarTQ2440裸机开发试验之Mmu_Nand.rar

    三星S3C2440芯片手册

    This user’s manual describes SAMSUNG's S3C2440A 16/32-bit RISC microprocessor. SAMSUNG’s S3C2440A is designed to provide hand-held devices and general applications with low-power, and high-...

    很丰富的ADS1.2环境下S3C2440裸机例程

    F:\ads\myarm\很丰富的ADS1.2环境下S3C2440裸机例程 有mmu+触摸屏+nand flash+interrup

    s3c2440英文手册

    s3c2440英文手册 INTRODUCTION This user’s manual describes SAMSUNG's S3C2440A 16/32-bit RISC microprocessor. SAMSUNG’s S3C2440A is designed to provide hand-held devices and general applications with...

Global site tag (gtag.js) - Google Analytics