TX2440A与TQ2440A开发板使用核心板完全相同

有过51单片基础的同学应该都会看懂下图,先看下图,对实验板存储器分布有一个整体印象:

s3c2440存储器概述:

1、S3C2440A的存储器管理器提供访问外部存储器的所有控制信号

2、27位地址信号、32位数据信号、8个片选信号、以及读/写控制信号等
3、总共有8个存储器bank(bank0—bank7)
   bank0---bank5为固定128MB
   bank6和bank7的容量可编程改变,可以是2、4、8、16、32、64、128MB
   最大共1GB

4、bank0可以作为引导ROM
   其数据线宽只能是16位和32位,其它存储器的数据线宽可以是8位、16位和32位
5、7个固定存储器bank(bank0-bank6)起始地址
   bank7的开始地址与bank6的结束地址相连接,但是二者的容量必须相等
6、所有存储器bank的访问周期都是可编程的
7、支持SDRAM的自刷新和掉电模式
8、支持大小端(软件选择)

NANDFLASH启动: OM1=0  OM0=0
NORFLASH启动:  OM1=0  OM0=1

开发板硬件:

TQ2440A开发板使用的SDRAM:
  型号:K4S561632(两片)
  大小:
      4M * 16bit * 4banks * 2片= 512 bit = 64M 字节
  数据宽度:32 bit

连接在BANK6上,片选信号nGCS6
  地址范围:0x3000_0000—0x33FF_FFFF

有四个逻辑BANK(L-BANK)
  由BA1、BA0选择
  行地址数:13
  列地址数:9

SDRAM存储区分布:

0x3000_0000~0x3100_0000程序代码区、文字常量区
0x33ff_0000~0x33ff_4800堆区
0x33ff_4800~0x33ff_8000栈区
0x33ff_ff00~0x3400_0000偏移中断向量表

                              SDRAM配置寄存器:

NOR FLASH (EN29LV160AB):
  大小:2M
  数据宽度:16bit
  连接在BANK0上,片选信号nGCS0
  地址范围:0x0000_0000---0x0020_0000
特点:
  线性寻址
  可直接按地址进行读写操作
  写操作之前需进行擦除操作
  写入、擦除速度较慢,读取速度较快,单位密度低、成本较高

NAND FLASH(K9F2G08)
  大小:256M * 8Bit
  数据宽度:8位
  地址范围:有专门的时序控制总线,不占用系统总线资源
特点:
  非线性寻址
  读操作,一次必须读一个扇区(512字节)
  写操作,可按指定地址直接写入
  写之前必须进行擦除操作
  单位密度高、成本低、擦除速度快

存储空间组织:(256M+8M)×8bit
  数据空间: 2planes×1kblocks×64pages×2048Byte
  寄存器空间: 2planes×1kblocks×64pages×64Byte
自动编程和擦除
  页编程:(2048+64)Byte
  块擦除:(128K+4K)Byte
  2112Byte 页读取操作

NAND FLASH 启动方式:

1、2440内部有一个叫做“起步石(Steppingstone)”  的 SRAM缓冲器
2、系统启动时Nand flash存储器的前面4K字节被自动拷贝到Steppingstone中
3、Steppingstone被映射到nGCS0对应的BANK0存储空间
4、CPU在Steppingstone的4-KB内部缓冲器中开始执行引导代码
5、引导代码执行完毕后,自动跳转到SDRAM执行

管脚配置:
D[7:0] : 数据/命令/地址/的输入/输出口(与数据总线共享)
CLE : 命令锁存使能 (输出)
ALE : 地址锁存使能(输出)
nFCE : NAND Flash 片选使能(输出)
nFRE : NAND Flash 读使能 (输出)
nFWE : NAND Flash 写使能 (输出)
R/nB : NAND Flash 准备好/繁忙(输入)

控制寄存器:

NAND FLASH 操作步骤:

1、通过NFCONF寄存器配置NandFlash;
2、写NandFlash命令到NFCMMD寄存器;
3、写NandFlash地址到NFADDR寄存器;
4、写数据到NFDATA,或从NFDATA读数据;
5、在读写数据时,通过NFSTAT寄存器来获得Nand flash的状态信息。应该在读操作前或写入之后检查R/nB信号(准备好/忙信号)
6、在读写操作后要查询校验错误代码,对错误进行纠正

命令字:

寻址:

对于K9F1208(64M)
  Block  Address  块地址  A[25:14]
  Page   Address  页地址  A[13:9]
  Column Address  列地址  A[7:0]
 
A8是halfpage pointer
被读命令00h设为低电平  访问A区(0~255byte)
被读命令01h设为高电平  访问B区(256~511byte)

50h访问C区(512~527byte)

地址传送顺序是:列地址,页地址,块地址

TQ2440开发板存储器的更多相关文章

  1. 运行在TQ2440开发板上以及X86平台上的linux内核编译

    一.运行在TQ2440开发板上的linux内核编译 1.获取源码并解压 直接使用天嵌移植好的“linux-2.6.30.4_20100531.tar.bz2”源码包. 解压(天嵌默认解压到/opt/E ...

  2. 基于TQ2440开发板的WiFi模块的使用经验总结

    一.软.硬件资源准备: 内核版本:linux-2.6.30.4 交叉编译器版本:4.3.3 wpa_supplicant工具:wpa_supplicant-0.7.3.tar ; openssl-0. ...

  3. TQ2440开发板挂载U盘出现乱码

    解决方法:配置内核 make menuconfig File Systems --->      DOS/FAT/NT Filesystems  --->         (utf8) D ...

  4. tq2440开发板基本配置

    时钟配置及分配 tq2440的晶振频率是12MHz,在uboot中有如下语句:   #define S3C2440_CLKDIV 0x05 /* FCLK:HCLK:PCLK = 1:4:8, UCL ...

  5. 【转】深度分析NandFlash—物理结构及地址传送(以TQ2440开发板上的K9F2G08U0A为例)

    K9F2G08U0A是三星公司生产的总容量为256M的NandFlash,常用于手持设备等消费电子产品.还是那句话,搞底层就得会看datasheet,我们就从它的datasheet看起. 这就是 K9 ...

  6. 在TQ2440开发板上ping 127.0.0.1不通

    问题:在TQ2440上ping 127.0.0.1,提示错误 ping: sendto: Network is unreachable   解决方法:ifconfig lo 127.0.0.1 up ...

  7. TQ2440开发板网络配置方式

    一.命令行模式 1.设置IP.子网掩码(netmask) #ifconfig eth0 <IP地址> netmask <子网掩码> up up 表示开启网卡eth0,可以不加 ...

  8. 把Linux目录挂载到开发板、设置开发板从NFS启动、取消开发板从NFS启动

    声明:文中"PC虚拟机Linux"是指在PC上安装了虚拟机,然后在虚拟机中装的Linux. 关于NFS的详细介绍可参考:http://www.cnblogs.com/nufangr ...

  9. AC6102开发板USB3.0测试和使用说明

    AC6102开发板USB3.0测试和使用说明 概述 AC6102上集成了一颗Cypress 推出的高性能USB3.0传输芯片CYUSB3014,Cypress称之为EZ-USBFX3.该芯片性能强劲, ...

随机推荐

  1. 第7月第27天 c++11 boost

    1. #include <boost/asio.hpp> #include <cstdlib> #include <memory> namespace asio = ...

  2. CF258D Little Elephant and Broken Sorting (带技巧的DP)

    题面 \(solution:\) 这道题主要难在考场上能否想到这个思路(即如何设置状态)(像我这样的蒟蒻就想不到呀QAQ)不过这一题确实很神奇! \(f[i][j]:\)表示第 \(a_i\) 个数比 ...

  3. 非常有助于理解二极管PN结原理的资料

    https://www.zhihu.com/question/60053574/answer/174137061 我理解的半导体 pn 结的原理,哪里错了? https://blog.csdn.net ...

  4. 解决UnicodeDecodeError: 'ascii' codec can't decode byte 0xcf in position 7: ordinal not in range(128)

    在Windows下同时装了Python2和Python3,但是在使用命令给pip更新的时候,出现了以下错误: 解决办法:修改mimetypes.py文件,路径位于python的安装路径下的Lib\mi ...

  5. Python常见面试(习题)——水仙花数

    今天,给大家分享一个习题. 用python输出100到1000以内的水仙花数. 相信很多小伙伴都听到过,或者遇到过这个题目. 那么今天就来带大家做一做这道题. 首先,我们要知道什么是水仙花数, (@_ ...

  6. nio--自己总结

    阻塞/非阻塞  +  同步/异步 其实,这两者存在本质的区别,面向的对象是不同的. 阻塞/非阻塞:进程/线程需要操作的数据如果尚未就绪,是否妨碍了当前进程/线程的后续操作. 同步/异步:数据如果尚未就 ...

  7. 切换Intellij ieda 调试为Visual Studio风格

  8. js中call与apply用法

    call和apply,它们的作用都是将函数绑定到另外一个对象上去运行 两者的格式和参数定义: call( thisArg [,arg1,arg2,… ] ); // 参数列表,arg1,arg2,.. ...

  9. Webpack按需加载一切皆模块

    前言 在学习 Webpack 之前,我们需要了解一个概念:模块. 何为模块? 如果你曾学过 Java , C# 之类的语言,一定会知道 Java 中的 import 或 C# 中的 using 吧? ...

  10. 008 jquery过滤选择器-----------(子元素过滤选择器)

    1.介紹 2.程序 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> < ...