s3c2440裸机-内存控制器(五、SDRAM编程实现)

发布时间:2023-08-09  

配置内存控制器-SDRAM编程配置

2440内存控制器共有13个寄存器。


BANK0--BANK5只需要设置BWSCON和BANKCONx(x为0~5)两个寄存器;

BANK6、BANK7外接SDRAM时,除BWSCON和BANKCONx(x为6、7)外,还要设置REFRESH、BANKSIZE、MRSRB6、MRSRB7等4个寄存器。


下面分别说明各个寄存起的设置:


1.位宽和等待控制寄存器BWSCON(BUSWIDTH&WAITCONTROLREGISTER)

我们SDRAM的位宽为32,DW6[25:24]设置成10, 没有使用等待信号,所以WS6[26]=0。 bank7跟随bank6的配置,

因此BWSCON寄存器的值为:0x22000000。

2.BANK控制寄存器BANKCON6(BANKCONTROLREGISTER)


在8个BANK中,只有BANK6和BANK7可以外接SRAM或SDRAM.

MT[16:15]:设置BANK是ROM/SRAM还是DRAM,我们用的SDRAM,属于DRAM。

Trcd[3:2]:行地址和列地址间隔多长时间,看SDRAM芯片手册时间间隔Trcd>18ns,我们HCLK=100MHZ,clocks为10ns,所以设置为2clocks即可。

62cbe534f400a0e4ee569917a4e6c1a9_1876680-20191211173732418-463155778.png

SCAN[1:0]:SDRAM的列地址位数,上面的图片已经查看sdram手册分析过,列地址位数为9。

综上所述,本开发板中BANKCON6设为0x017001

3.刷新控制寄存器REFRESH(REFRESHCONTROLREGISTER)

REFEN[23]:设置开启SDRAM的刷新功能。

TREFMD[22]:SDRAM的刷新模式,0=CBR/AutoRefresh,选择自动刷新。


Trp[21:20]:根据sdram手册Trp>18ns, 设为0(2 clocks)即可。

Tsrc[19:18]: Tsrc = Trc - Trp = Trc-20, 根据sdram手册Trc>=60,我们取Trc =70, 则Tsrc= 50ns(5clocks)即可。

RefreshCounter[10:0]:Refresh period = (211-refresh_count+1)/HCLK,

RefreshCount = 211 + 1 - 100*Refresh period,看SDRAM手册“8192 refresh cycles/64ms”, Refresh period= 64000us/8192 = 7.8us,

RefreshCount取推荐值1269= 0x4f5.

综上,REFRESH寄存器设为0x8404F5。

4.BANKSIZE寄存器REFRESH(BANKSIZEREG ISTER)

BURST_EN[7]:0=ARM核禁上突发传输,1=ARM核支持突发传输(推荐);

SCKEEN[5]:0=不使用SCKE信号令SDRAM进入省电模式,1=使用SCKE信号令SDRAM进入省电模式(推荐);

SCLK-EN[4]:0=时刻发出SCLK信号,1=仅在访问SDRAM期间发出SCLK信号(推荐);

BK76MAP[2:0]:配置banksize成64M

因此,BANKSIZE寄存器设为0xB1。

5.SDRAM模式设置寄存器MRSRBx6(SDRAM MODE REGISTER SET REGISTER)

CL[6:4]:表示发出行、列地址后,等多久才返回收到数据, 看SDRAM手册发现Tcas >=18ns,所以配置成2 clocks即可。

MRSRB6寄存器设置为0x20。

代码如下:

void sdram_init(void)

{

BWSCON = 0x22000000;


BANKCON6 = 0x18001;

BANKCON7 = 0x18001;


REFRESH  = 0x8404f5;


BANKSIZE = 0xb1;


MRSRB6   = 0x20;

MRSRB7   = 0x20;

}


int sdram_test(void)

{

volatile unsigned char *p = (volatile unsigned char *)0x30000000;//sdram base addr

int i;


// write sdram

for (i = 0; i < 1000; i++)

p[i] = 0x55;


// read sdram

for (i = 0; i < 1000; i++)

if (p[i] != 0x55)

return -1;


return 0;

}

int main(void)

{

uart0_init();


sdram_init();


if (sdram_test() == 0)

led_test();

return 0;

}

测试结果:

当进行sdram_init后可已访问0x3000_0000地址的内容,led流水灯闪烁。

不初始化sdram_init,运行程序卡死。


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>