Blackfin DSP(四):BF533 EBIU之SDRAM
BF533的SDRAM控制器最大支持128M bytes的SDRAM空间;总线宽度可以配置为4位、8位、16位。处理器与SDRAM的连线包括数据总线D[0:15]、地址总线A[1:19]、SDRAM刷新专用信号SA10,时钟信号SCLK、时钟使能信号SCKE、行锁存信号SRAS#,列锁存信号SCAS#,写使能信号SWE#,片选信号SMS#和总线屏蔽信号ABE[1:0].
SDRAM的起始地址为0x0000 0000,尾地址为0x03ff ffff,共64MB;若为32MB SDRAM,则尾地址为0x01ff ffff;
1.如何配置EBIU的寄存器
首先,在所使用的SDRAM的手册中,找到时序参数,如下图所示:
假设SCLK=135M,即7.4ns:
a.配置EBIU_SDRRC:SDRAM刷新率控制器;
- fsclk=135M=135*10^6 Hz----------系统总线频率;
- 查上表得,tREF=64 ms= 0.064 s;-------SDRAM行刷新时间;
- NRA为refresh cycles:NRA=8192----行数
- tRAS=从存储体激活到预充电之间的时间,以时钟周期为单位:44 /7.4=6;
- tRP=存储体从预充电到再次被激活之间的最小时间,以时钟周期为单位:20/7.4=3
RDIV = (135*10^6*0.064)/8192-(6+3)=0x415;
b.配置SDBCTL:存储体控制寄存器
c.配置SDGCTL:SDRAM全局控制器
TWR位:存储器手册上要求1clk+7.5ns,所以需要3个clk;其它位的计算相同;
最后,得到的各个寄存器的值如下:
void Init_SDRAM(void)
{
*pEBIU_SDRRC = 0x00000415; // *pEBIU_SDBCTL = 0x0025; //64 MB,10bit width
*pEBIU_SDBCTL = 0x0013; //32 MB,9bit width *pEBIU_SDGCTL = 0x0099998d; // 0x0091998d;
ssync();
}
为了对SDRAM进行测试,可以用下面的函数对其进行遍历,具体的使用方法如下:
#define pADDR (volatile unsigned short *)0x1000
#define SDRAM_START 0x00000000 // start address of SDRAM
//#define SDRAM_SIZE 0x04000000 // 64 MB
#define SDRAM_SIZE 0x02000000 // 32 MB void ezTurnOnLED(uint16_t led);
int TEST_SDRAM(void);
void main(void)
{
int i; Set_PLL(,); //cclk = 27*22=594M,sclk=594/5=118M
Init_EBIU();
Init_SDRAM();
*pADDR = 0x1234;
i = *pADDR;
printf("addr is %x\n",pADDR);
printf("data is %x\n",i);
*pADDR = 0xaa55;
i = *pADDR;
printf("addr is %x\n",pADDR);
printf("data is %x\n",i); if( == TEST_SDRAM())
{
printf("Test Failed!\r\n");
}
else printf("Test Successed!\r\n"); while(); } /*************************************************************************
*函数功能:测试SDRAM;
*入口参数:无;
*出口参数: 测试正常,返回1,否则返回0
*注意:根据SDRAM的位宽修改nIndex和pDst的类型;
************************************************************************/
int TEST_SDRAM(void)
{
volatile unsigned short *pDst;
unsigned short nIndex = 0xFFFF; //16位位宽
int bPass = ; // returning 1 indicates a pass, anything else is a fail // write all FFFF's
for(pDst = (unsigned short *)SDRAM_START; pDst < (unsigned short *)(SDRAM_START + SDRAM_SIZE); pDst++ )
{
*pDst = nIndex;
} // verify all FFFF's
for(pDst = (unsigned short *)SDRAM_START; pDst < (unsigned short *)(SDRAM_START + SDRAM_SIZE); pDst++ )
{
if( nIndex != (*pDst) )
{
bPass = ;
return false;
}
} // write all AAAAAA's
for(nIndex = 0xAAAA, pDst = (unsigned short *)SDRAM_START; pDst < (unsigned short *)(SDRAM_START + SDRAM_SIZE); pDst++ )
{
*pDst = nIndex;
} // verify all AAAAA's
for(nIndex = 0xAAAA, pDst = (unsigned short *)SDRAM_START; pDst < (unsigned short *)(SDRAM_START + SDRAM_SIZE); pDst++ )
{
if( nIndex != *pDst )
{
bPass = ;
return false;
}
} // write all 555555's
for(nIndex = 0x5555, pDst = (unsigned short *)SDRAM_START; pDst < (unsigned short *)(SDRAM_START + SDRAM_SIZE); pDst++ )
{
*pDst = nIndex;
} // verify all 55555's
for(nIndex = 0x5555, pDst = (unsigned short *)SDRAM_START; pDst < (unsigned short *)(SDRAM_START + SDRAM_SIZE); pDst++ )
{
if( nIndex != *pDst )
{
bPass = ;
return false;
}
} return true;
}
Blackfin DSP(四):BF533 EBIU之SDRAM的更多相关文章
- Blackfin DSP(八):1D DMA与音频处理模板
1.DMA产生的背景 在许多需要使用DSP 的场合,一般都需要大量的数据搬移工作,而如果每次数据搬移都由DSP 内核来参与完成,将大大占用DSP 内核的处理时间,从而严重影响其信号处理能力.因此,Bl ...
- Blackfin DSP(二):寄存器操作与GPIO
BlackfinDSP的寄存器是通过指针操作的,与51.ARM等MCU一样,通过“或”操作来置1,通过“与”操作清零. 在DSP上最简单的外设非IO口莫属,但是由于其功能强大,远非一般IO口可比,因此 ...
- Blackfin DSP(三):BF533 的EBIU接口之flash
上一节谈了GPIO问题,是用BF561 ezkit进行说明的,这是因为561 ezkit上的GPIO是与LED直连的,讲解GPIO时不会涉及到其它问题,降低了复杂性.对于533,也采取同样的操作即可. ...
- Blackfin DSP(五):BF533的SPI接口
533SPI的特性 最高速度可达SCLK/4: 支持主模式和从模式: 可使用8个GPIO口作为从选择线: 1 slave select input pins 7 slave select output ...
- Blackfin DSP(六):BF533的SPORT接口
1.特性 bf533有两个SPORT口(synchronous serial Port),即同步串行接口.完全独立的接收和发送通道,且每个通道都具有缓冲,最高速度可达SCLK/2.最大支持32bit字 ...
- Blackfin DSP(八):BF533的DMA
#include <cdefBF533.h> #include <sys\exception.h> #define POLC 0x00004000 #define PORT_C ...
- TI C66x DSP 四种内存保护问题 -之- CPU訪问corePac内部资源时的内存保护问题
CPU訪问corePac内部资源(L1.L2)时的内存保护(通过设置内存的訪问权限实现)等问题请參考以下两个blog.已经叙述的非常具体. "TI C66x DSP 系统events及其应用 ...
- TI C66x DSP 四种内存保护问题 -之- 针对CPU訪问外存(DDR3 or MSM)时的内存保护问题 - 举例
在代码维护中遇到过这种问题,CPU訪问了corePac的外部内存空间0x75510C55地址,即CPU向corePac的L2内存控制器发起了对该内存的訪问,然后L2内存控制器将该请求发给corePac ...
- TI C66x DSP 四种内存保护问题 -之- 外设訪问corePac内部资源时的内存保护问题
外设訪问corePac内部资源(L1,L2)时的内存保护等问题请參考以下两个blog.已经叙述的非常具体. "TI C66x DSP 系统events及其应用 - 2"," ...
随机推荐
- redis入门指南-安装redis
纸上得来终觉浅 绝知此事要躬行 Redis官方不支持window.微软发布了可在redis的分支.不建议使用 但我确实用了. win7 redis2.8.4 php5.6 apache2.4 ht ...
- jetty启动不能保存
主要原因是jetty缓存的静态页面不能被修改.只需要在web.xml文件中配置如下: <servlet> <!-- Override init parameter to avo ...
- web前端基础篇④
1.BFC-块级元素-块级格式化上下文布局规则:独立区域,与外部毫不相关内部box会在垂直方向,一个个放置box垂直方向距离由margin决定BFC的区域不会与float box重叠计算BFC高度时, ...
- 安装生物信息学软件-R
主要参考http://www.3fwork.com/b211/000091MYM021616/ Step 1 : sudo gedit /etc/apt/sources.list 添加到末尾 deb ...
- hdu 2065
ps:我的天...看网上各种难..对于我这个比较懒得人...我就找规律直接水过去了...前20一个循环,注意跳过第一轮的3个数就行..然后觉得比较坑的是,那个输入N,要用long long型... 代 ...
- BackTrack5-r3硬盘安装
用Universal-USB-Installer-1.9.4.2这个工具,选择系统类型为Backtrack5 R3,选择Backtrack5 R3系统的ISO文件,然后选中U盘盘符,点击”Create ...
- 12-2 mysql 查询
老师提纲 1. create database test2. drop database test3. create table info( code int primary key, name va ...
- 【Avalon】factory
(function(global, factory) { if (typeof module === "object" && typeof module.expor ...
- 修改xubuntu14.04(同适用ubuntu)下Eclipse默认的黑色注释
终端输入:sudo gedit /usr/share/themes/Ambiance/gtk-2.0/gtkrc 第一行将看到如下内容: gtk-color-scheme = "base_c ...
- (实用篇)php通过会话控制实现身份验证实例
会话控制的思想就是指能够在网站中根据一个会话跟踪用户.这里整理了详细的代码,有需要的小伙伴可以参考下. 概述 http 协议是无状态的,对于每个请求,服务端无法区分用户.PHP 会话控制就是给了用户一 ...