S3C2440—8.读写SDRAM
SDRAM:Synchronous Dynamic Random Access Memory,同步动态随机存储器,同步是指内存工作需要同步时钟,内部的命令的发送与数据的传输都以它为基准;动态是指存储阵列需要不断的刷新来保证数据不丢失;随机是指数据不是线性依次存储,而是自由指定地址进行数据读写
一.内部结构
原理图如下:

存储逻辑结构:

可以看出SDRAM的内部是一个阵列,就像表格一样,其寻址方式是按照块、行、列来的,即先选定SDRAM芯片,然后发出块信号确定那一块,再发出行信号确定哪一行,再发出列信号确定哪一列。
CPU对SDRAM的访问可以分为以下几步:
- CPU对存储控制器发出统一编址
- 内存控制器发出片选信号,选定SDRAM芯片
- 选定哪一个Bank(通过ADDR24、ADDR25信号线选定,总共4个Bank)
- 对选定的Bank进行行列寻址
- 找到对应的地址,通过32根数据线进行数据传输(原理图中是32位)
看起来很简单,但是我们要考虑到,不同规格SDRAM对应着不同的寻址方式,因为不同的SDRAM可能行列数不一样,对时序要求不一样,所以在访问SDRAM之前,我们要配置存储控制器中的一些寄存器来匹配SDRAM!!!
二.相关寄存器
存储控制器一共有13个寄存器,6种寄存器,对BANK0~BANK5进行访问时,只需要配置BWSCON和BANKCONx寄存器,但是对SDRAM访问,不仅仅需要对这俩个寄存器进行配置,还需要额外配置4个寄存器。
下面以访问SDRAM为例子介绍一下这些寄存器(按照芯片手册中的顺序来介绍):
BWSCON
位宽&等待控制寄存器

- ST6:决定是否使用SDRAM的数据掩码,对SDRAM时为0,对SRAM时为1。
- WS6:决定是否使用WAIT信号,一般不使用。(WAIT信号就是在SDRAM没准备好的时候,由SDRAM发给CPU,请求延迟一段时间)
- DW6:决定BANK位宽,自然是32位。
所以,BWSCON寄存器要或运算的值为:0x02000000
BANKCON6
BANK控制寄存器,用来控制外接设备的访问时序的,BANK0~BANK5默认0X0700

对于SDRAM的访问,我们需要配置的就是图中阴影部分的:
MT:决定BANK外接的是SDRAM还是SRAM,SDRAM选择11.
Trcd:行列信号之间的延迟时间,根据芯片手册得知最小为21ns,而我们的HCLK时钟为100MHz,一个clock10ns,所以保险起见选择30ns,即:01。

SCAN:设置列地址位,这里使用的SDRAM列地址一共9位,所以为:01.
所以,BANKCON6寄存器要或运算的值为:0x00018005
REFRESH
刷新控制寄存器,用来控制SDRAM的刷新模式和刷新频率。我们知道,SDRAM中的存储阵列需要不断的刷新来保证数据不丢失,所以就要配置刷新控制寄存器。

REFEN:决定使能刷新功能,当然是开启了,值为:1
TREFMD:刷新的模式,一般自动刷新,值为:0
Trp:根据芯片手册得知20ns保险,对应2clocks,值为:00
Tsrc:默认即可
Refresh Counter:刷新计数的值,查SDRAM的手册可得8192个刷新周期为64ms,则每一个刷新周期为7.8125ns,通过公式计算可得刷新计数的值为:1955

所以,REFRESH寄存器要或运算的值为:0x008c07a3
BANKSIZE

- BURST_EN:决定是否允许突发传输,值为:1。
- SCKE_EN:决定是否使用SCKE信号来决定省电模式,值为:1。
- SCLK_EN:决定SCLK时钟信号的产生模式,值为:1。
- BK76MAP:决定BANK6、BANK7的大小,这里SDRAM是64M,所以值为:001。(BANK0~BANK5的大小是128M固定的,BANK6、BANK7的大小是可以控制的)
所以,BANKSIZE寄存器要或运算的值为:0x000000b1
MRSR
SDRAM模式设置寄存器

只有CL的值是可以修改的,查询芯片手册:

可知,CL可以是2clock或者是3clock,保险起见,值为:011
所以,MRSR寄存器要或运算的值为:0x00000030
/**********************************************************************************************************************/
综上所述,对SDRAM初始化的代码为:
void SDRAM_Init(void)
{
/* 对BANK6进行配置 以访问SDRAM */
BWSCON |= 0x02000000;//对SDRAM使用数据掩码、不使用WAIT信号、设置BANK6位宽32bit
BANKCON6 = 0x00018005;//BANK6外接SDRAM、行列信号间延迟3clocks、设置列地址位数
REFRESH = 0x008c07a3;//配置刷新模式及刷新计数值
BANKSIZE = 0x000000b1;//设置BANK6大小为64MB
MRSRB6 = 0x00000030;//设置CL为3clocks
}
三.读写SDRAM
对SDRAM进行配置之后,进行读写操作,看看写进去的值和读出来的值是否统一。
测试就直接写在main.c中吧:
#include "s3c2440_soc.h"
#include "uart.h"
void SDRAM_Init(void)
{
/* 对BANK6进行配置 以访问SDRAM */
BWSCON |= 0x02000000;//对SDRAM使用数据掩码、不使用WAIT信号、设置BANK6位宽32bit
BANKCON6 = 0x00018005;//BANK6外接SDRAM、行列信号间延迟3clocks、设置列地址位数
REFRESH = 0x008c07a3;//配置刷新模式及刷新计数值
BANKSIZE = 0x000000b1;//设置BANK6大小为64MB
MRSRB6 = 0x00000030;//设置CL为3clocks
}
int SDRAM_Test(void)
{
/* BANK6 基地址0x30000000 */
volatile unsigned char *p = (volatile unsigned char *)(0x30000000);
int n;
/* 写入20Byte数据 */
for( n=0;n<20;n++ )
{
*(p+n) = 0xbb;
}
for( n=0;n<20;n++ )
{
if( 0xbb != *(p+n) )
return 0;
}
return 1;
}
int main(void)
{
SDRAM_Init();
uart0_init();
if( SDRAM_Test() )
puts("OK!!!\n");
else
puts("NOT OK!!!\n");
return 0;
}
代码亲测可以。
S3C2440—8.读写SDRAM的更多相关文章
- 【iCore4 双核心板_ARM】例程三十七:SDRAM实验——读写SDRAM
实验现象: 上电即开始读写SDRAM测试,测试过程中,蓝色LED点亮,如果出现错误,红色LED闪烁,测试成功,绿色LED点亮. 核心代码: int main(void) { /* USER CODE ...
- 【转】S3C2440与SDRAM NorFlash NandFlash连线分析
一.SDRAM(HY57V561620F)连线分析 1. S3C2440 有27根地址线ADDR[26:0],8根片选信号ngcs0-ngcs7,对应bank0-bank7,当访问bankx 的地址 ...
- SDRAM读写一字(下)
SDRAM读写一字 SDRAM控制模块 上电后进行初始化状态,初始化完成后进入空闲状态,在此进行判断如下判断: 如果自刷新时间到,则进行自刷新操作,操作完成后重新进入空闲状态: 如果读使能有效则进行读 ...
- 让LED程序在片外SDRAM中运行
让LED程序在片外SDRAM中运行 一.引子 在前一篇文章中,我们已经成功点亮过LED了,为什么还要再重复一次呢? 我们已经知道,Mini2440开发板有两种启动模式:从NorFlash启动和从Nan ...
- S3C2440的Linux启动过程分析(一)——SC2440处理器结构
1.1. S3C2440处理器结构 S3C2440处理器的结构如下图所示,其核心单元为ARM9TDMI处理器核,主要包括16K的指令Cache和16K的数据Cache,以及分开的指令和数据MM ...
- 基于SDRAM的视频图像采集系统
本文是在前面设计好的简易SDRAM控制器的基础上完善,逐步实现使用SDRAM存储视频流数据,实现视频图像采集系统,CMOS使用的是OV7725. SDRAM控制器的完善 1. 修改SDRAM的时钟到1 ...
- 第26章 FMC—扩展外部SDRAM
本章参考资料:<STM32F76xxx参考手册2>.<STM32F7xx规格书>.库帮助文档<STM32F779xx_User_Manual.chm>. 关于SDR ...
- 第26章 FMC—扩展外部SDRAM—零死角玩转STM32-F429系列
第26章 FMC—扩展外部SDRAM 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/ ...
- 基于JZ2440开发板编写bootloader总结(一)
凡走过必留下痕迹,学点什么都会有用的. 本系列博文总结了自己在学习嵌入式Linux编程过程中的收获,若有错误,恳请指正,谢谢! --参考教材韦东山系列教材 bootloader 是一个用于启动linu ...
随机推荐
- JUnit5参数化测试的几种方式
参数化测试一直是津津乐道的话题,我们都知道JMeter有四种参数化方式:用户自定义变量.用户参数.CSV文件.函数助手,那么JUnit5有哪些参数化测试的方式呢? 依赖 JUnit5需要添加junit ...
- 初步了解Unix系统的I/O模式
I/O模式 对于一次IO访问(以read举例),数据会先被拷贝到操作系统内核的缓冲区中,然后才会从操作系统内核的缓冲区拷贝到应用程序的地址空间. 当一个read操作发生时,它会经历两个阶段: 等待数据 ...
- [Kong] key-auth实现对API请求的密钥认证
目录 1. 配置密钥验证插件 2. 确认插件配置正确 3. 创建cunsumer 4. 给cunsumer提供关键凭证 5. 验证 6. 小结 [前言]: 下面我们将配置key-auth插件以向服务添 ...
- Python----MongoDB数据库
什么是MongoDB ? MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供 ...
- C++ 11 智能指针(shared_ptr)类成员函数详解
C++ 11 模板库的 <memory> 头文件中定义的智能指针,即 shared_ptr 模板类,用来管理指针的存储,提供有限的内存回收函数,可同时与其他对象共享该管理功能. share ...
- PYTHON3.4.4 升级pip
python -m pip install --upgrade pipupgrade 前面是两个 "-"
- Spring Boot入门学习必知道企业常用的Starter
SpringBoot企业常用的 starter SpringBoot简介 SpringBoot运行 SpringBoot目录结构 整合JdbcTemplate @RestController 整合JS ...
- Python语言对Json对象进行新增替换操作
# Json字符串进行新增操作import jsonimport os# os.path.dirname(__file__):表示当前目录path = os.path.join(os.path.dir ...
- 【动画消消乐】HTML+CSS 自定义加载动画 064(currentColor的妙用!)
前言 Hello!小伙伴! 非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出- 自我介绍ଘ(੭ˊᵕˋ)੭ 昵称:海轰 标签:程序猿|C++选手|学生 简介:因C语言结识编程,随后转入计算机专 ...
- 在 Golang 中实现一个简单的Http中间件
本文主要针对Golang的内置库 net/http 做了简单的扩展,通过添加中间件的形式实现了管道(Pipeline)模式,这样的好处是各模块之间是低耦合的,符合单一职责原则,可以很灵活的通过中间件的 ...