s3c2440裸机-内存控制器4-SDRAM编程实现

发布时间:2024-07-08  

配置内存控制器-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即可。



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都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>