mini2440的SDRAM分析

  首先是2440的存储控制器:

  暂时不管是从nand启动还是nor启动,因为我现在只关注内存,从上图可以看到由2440的Memory Controller可以寻址的范围是0x0000,0000---0x4000,0000,总共是1G,这1G又分为8个bank,bank0-bank7,每个bank为128M, 8*128M=1G。其中bank0-bank5这6个bank是只能接SROM,那么什么是SROM,2440数据手册的221页说明了,SROM是ROM或者SRAM。

  

通用存储设备:

  内存存储设备的存储方式:ROM,RAM

    ROM(Read-Only Memory):只读存储器,是一种只能读出事先所存数据的固态半导体存储器。其特性是一旦储存资料就无法再将之改变或删除。通常用在不需经常变更资料的电子或电脑系统中,资料并且不会因为电源关闭而消失。如:PC里面的BIOS。

    RAM(Random Access Memory) :随机访问存储器,存储单元的内容可按需随意取出或存入,且存取的速度与存储单元的位置无关的存储器。可以理解为,当你给定一个随机有效的访问地址,RAM会返回其存储内容(随机寻址),它访问速度与地址的无关。这种存储器在断电时将丢失其存储内容,故主要用于存储短时间内随机访问使用的程序。计算机系统里内存地址是一个四字节对齐的地址(32位机),CPU的取指,执行,存储都是通过地址进行的,因此它可以用来做内存。

  RAM按照硬件设计的不同,随机存储器又分为DRAM(Dynamic RAM)动态随机存储器和SRAM(Static RAM) 静态随机存储器。

    DRAM它的基本原件是小电容,电容可以在两个极板上短时间内保留电荷,可以通过两极之间有无电压差代表计算机里的0和1,由于电容的物理特性,要定期的为其充电,否则数据会丢失。对电容的充电过程叫做刷新,但是制作工艺较简单,体积小,便于集成化,经常做为计算机里内存制作原件。比如:PC的内存,SDRAM, DDR, DDR2, DDR3等,缺点:由于要定期刷新存储介质,存取速度较慢。

    SRAM它是一种具有静止存取功能的内存,不需要刷新电路即能保存它内部存储的数据。因此其存取速度快,但是体积较大,功耗大,成本高,常用作存储容量不高,但存取速度快的场合,比如CPU的L1 cache,L2cache(一级,二级缓存) ,寄存器。

  由于价格和存储量的限制,mini2440上作为内存的就是DRAM,从上图看得出,只有bank6,bank7才能接DRAM,那么我猜想控制bank6,7的Memory Controller对应的寄存器肯定有一个控制刷新的部分,其他几个不具备,因为不需要。再看看mini2440上的内存芯片怎么和2440接线的,它使用了2块16位宽的SDRAM:

  

  从上图来看,芯片包括了最基本的地址线,数据线,对比2块芯片,发现它们相同的地址线是连在一起的,都是A0-A12,共13根地址线,而数据线一块是连接2440的LDATA0---LDATA15,一个是LDATA16-LDATA31,再看看2440的引脚:

  可以看出,2440的数据线是DATA0-DATA31,可以接收的数据宽度是32位,而它的地址线是ADDR0--ADDR26,一共是27根,那么2^27就是128M,正好是内存控制器一个bank的大小。再联系SDRAM和2440的接线方式,发现数据线32根分别由2块芯片对接,2块芯片分别用16根,而地址线只用了13根,2^13=8K,那怎么可能做到寻址128M呢?何况SDRAM上居然是从LADDR2开始接线的。那么就得看看SRAM的手册,看看它是怎么被寻址的。

  

  mini2440上SDRAM型号是H57V2562GTR,是一个256Mb的16位位宽的DRAM,注意这里是256Mb,是小b,所有总共是256/8=32MB。看看SDRAM内部的结构功能框图:

这款DRAM内部的存储单元首先是由4个称作BANK的单元组成,然后每个BANK单元上是由一个存储矩阵组成,通过XY轴定位到最小寻址粒度的一个单元,也就是一个16bit的存储单元。然后把这个16bit的单元里面的数据放到数据输出口上。打个比方,假设一块DRAM是一个Excel文件,那么它的bank就是Excel的一个sheet,由横坐标(ABCDEF.......)和纵坐标(12345....)定位一个最基本的单元格,这个单元格就是DRAM的基本存储单元,这款DRAM是16位宽的,所有基本存储单元就是16bit。在看看左下角的Address Buffers,A0-13,地址线,BA1-BA0,bank选择线,首先通过片选信号CS选中这块芯片,然后由BA[0,1]选中bank,再在A0-A12上发出行地址,然后发出列地址,这样一个最小寻址粒度的存储单元就定位下来了,怎么知道地址线上的是行地址还是列地址呢?通过 RAS和CAS这2根信号线。那现在再计算一下128MB怎么来的,行13,列13,bank 2,这样2^13*2^13*2^2 = 2^28 然后是16位宽再乘2,就是2^29MB,521MB,怎么一块就超过了2440的寻址范围,肯定是哪搞错了,再细看DRAM的介绍:

原来只有行地址用了13位,列地址只用了9位,那么通过计算一共是2^(13+9+2+1)=32MB,和芯片的规格一致,那么这样解释就合理了。2440怎么使用这2块SDRAM的呢?首先要确定几个条件,2440芯片本身实际的寻址能力是4G,存储控制器的寻址范围是0x00000000-0x40000000,一共是1G,这1G又分成了8个BANK,每个BANK 128MB,公式表达就是:ADDR = 2*  2 *  227

但是这样寻址这块SDRAM得到的数据是16bit,于是用2块拼接起来,一个来存储低16位,一个存储高16位。假设地址0x30000000,寻址它怎么得到这个存储单元的内容呢?首先它是属于1G这个范围内,然后又是处于bank6,BANK0,行0,列0.

由此可见仅仅需要30位就可以定位一个access cell,这也就是为什么2440地址线只接了A2开始的13位到SDRAm上,由于2440的存储控制器每次只能以4byte对齐访问,一个int的4个byte分别存储在2个芯片上,然后4byte的数据读到存储控制器,地址还未用到的最低2位在存储控制器里面决定是用哪个byte。这就是一个byte的寻址过程。

  2440SDRAM可以使用16位宽的2片拼接,或者8位的4片拼接,32位的1片。显然如果是2片时,这2片的大小必须要一样大的,否则多出来的就会只能存16bit,其他的位会丢失掉,4片也是同样的。

  H57V2562GTR,SDRAM管脚说明


外接管脚名


内接管脚名


全称


描述


A2~A14


A0~A12


Address


地址线


D0 ~D31


DQ0~DQ31


Data Input/Output


数据线


A24,A25


BA0,BA1


Bank Address


L-BANK片选信号


DQM0~DQM3


LDQM, UDQM


Data Input/Output Mask


高,低字节数据掩码信号


SCKE


SCKE


Clock Enable


输入时钟有效信号


SCLK


SCLK


Clock


输入时钟


nSCS0


nSCS


General Chip Select


片选信号(它与nGCS6是同一管脚的两个功能)


nSRAS


nSRAS


Row Address Strobe


行地址选通信号


nSCAS


nSCAS


Column Address Strobe


列地址选通信号


nWE


newnWE


Write Enable


写入有效信号

看2片SDRAM和2440的接线可以看出来,它们只有数据脚和LDQM UDQM引脚不同,这2个引脚来决定数据引脚上高8位和低8位的有效性,由于2440内存控制器只能发出4byte对齐的数据给SDRAM(data线的连接固定了),那么我如果只想存储或者读取一个byte,怎么办?由这2个引脚来控制,它来决定16位宽的高低8位的有效性,确保不想改的byte内容不变。

参考自:

http://blog.csdn.net/mr_raptor/article/details/6555786

时间: 2024-08-12 02:55:37

mini2440的SDRAM分析的相关文章

mini2440之Main分析

/**************************************************************** NAME: u2440mon.c DESC: u2440mon entry point,menu,download HISTORY: Mar.25.2002:purnnamu: S3C2400X profile.c is ported for S3C2410X. Mar.27.2002:purnnamu: DMA is enabled. Apr.01.2002:pu

am335x uboot启动流程分析

基本指令含义 .globl _start .globl指示告诉汇编器,_start这个符号要被链接器用到,所以要在目标文件的符号表中标记它是一个全局符号 b,bl b是不带返回的跳转  bl带返回的跳转 .word 插入一个32-bit的数据队列.(与armasm中的DCD功能相同) 芯片到uboot启动流程 :ROM → MLO(SPL)→ uboot.img 启动脚本:/u-boot2011.09/arch/arm/cpu/armv7/omap-common/u-boot_spl.lds M

S3C2440 裸机程序之音频

mini2440之Main分析 2012-03-17 20:51:29 分类: 嵌入式 /**************************************************************** NAME: u2440mon.c DESC: u2440mon entry point,menu,download HISTORY: Mar.25.2002:purnnamu: S3C2400X profile.c is ported for S3C2410X. Mar.27.2

基于mini2440的Linux内存布局分析

SDRAM(Synchronous Dynamic Random Access Memory,同步动态随机存储器)也就是通常所说的内存.内存的工作原理.控制时序.及相关控制器的配置方法一直是嵌入式系统学习.开发过程中的一个难点.我们从其硬件的角度来分析其原理,然后再引出SDRAM的驱动编写过程. 内存是代码的执行空间,以PC机为例,程序是以文件的形式保存在硬盘里面的,程序在运行之前先由操作系统装载入内存中,由于内存是RAM(随机访问存储器),可以通过地址去定位一个字节的数据,CPU在执行程序时将

SDRAM操作原理分析

芯片原理图 引脚原理图 指令 ????通过对上面指令的总结,简化出要用到的指令如下: 指令 常量名 CKE CSn RAS CASn WEn 备注 空操作 NOP 1 0 1 1 1 ? 行激活 ACTIVE 1 0 0 1 1 ? 读操作 READ 1 0 1 0 1 ? 写操作 WRITE 1 0 1 0 0 ? 预充电 PR 1 0 0 1 0 ? 自刷新 AR 1 0 0 0 1 ? 设置寄存器 LMR 1 0 0 0 0 ? 突发停止 BURST_STOP 1 0 1 1 0 1 ?

SDRAM读写操作仿真与分析

1.行有效时序图 初始化完成后,要想对一个L-Bank中的阵列进行寻址,首先就要确定行(Row),使之处于活动状态(Active),然后再确定列.虽然之前要进行片选和L-Bank的定址,但它们与行有效可以同时进行. 从图中可以看出,在CS#.L-Bank定址的同时,RAS(Row Address Strobe,行地址选通脉冲)也处于有效状态.此时An地址线则发送具体的行地址.如图中是A0-A11,共有12个地址线,由于是二进制表示法,所以共有4096个行(2的12次方=4096),A0-A11的

u-boot.2012.10——mini2440(二、启动流程分析)

参考资料:https://blog.csdn.net/suiyuan19840208/article/details/7239949 1.第一阶段功能 * 硬件设备初始化 * 加载u-boot第二段代码到RAM空间 * 设置好栈 * 跳转到第二段代码入口 2.第二段代码的功能 * 初始化本阶段使用的硬件设备 * 检测系统的内存映射 * 将内核从Flash读到RAM中 * 为内核设置启动参数 * 调用内核 3 .u-boot第一阶段代码分析 我们在编译完成之后,观察顶层目录有个u-boot.lds

DM9000驱动移植在mini2440(linux2.6.29)和FS4412(linux3.14.78)上的实现(deep dive)篇一

关于dm9000的驱动移植分为两篇,第一篇在mini2440上实现,基于linux2.6.29,也成功在在6410上移植了一遍,和2440非常类似,第二篇在fs4412(Cortex A9)上实现,基于linux3.14.78,用设备树匹配,移植过程中调试和整体理解很重要,一路上幸有良师益友指点,下面详细介绍: 1.物理时序分析相关 DM9000芯片是DAVICOM公司生产的一款以太网处理芯片,提供一个通用的处理器接口.一个10/100M自适应的PHY芯片和4K双字的SRAM.内部框架如下,涉及

【转载】Mini2440启动配置文件说明

对于mini2440,虽然root_qtopia这个文件系统的GUI是基于Qtopia的,但其初始化启动过程却是由大部分由busybox完成,Qtopia(qpe)只是在启动的最后阶段被开启. 由于默认的内核命令行上有init=/linuxrc, 因此,在文件系统被挂载后,运行的第一个程序是根目录下的linuxrc.这是一个指向/bin/busybox的链接,也就是说,系统起来后运行的第一 个程序也就是busybox本身.这种情况下,busybox首先将试图解析/etc/inittab来获取进一