按照C6747 BOOTLODER文档中的相关介绍,使用AIS BIN文件格式,可以通过配置EMIF CFG/TIM1/TIM2/RFC四个寄存器,正确配置后,即可通过开机引导方式完成SDRAM的初始化工作。
但是现在我已经按照C6747手册及SDRAM芯片手册配置好时序,但是SDRAM访问不成功。求教大侠指点一二啊。
使用的是美光的MT48LC2M32B2 6A3型号SDRAM,最高支持167MHz,目前我们硬件上是通过EMIFB与SDRAM连接,其中EMIFB时钟频率配置为100MHz.
芯片共4个Bank,2K行地址,256列地址,
相关时序如下图:
根据上图中时序的描述和我EMIFB频率为100MHz,我配置寄存器参数如下:
SDRAM SDCFG Reg:
[31--24] [23--16] [15--08] [07--00]
00000000 00000001 10000100 00100000 == 0x00018420
IBANK_POS:0x00, MSDRAM_ENABLE:0x00, BOOT_UNLOCK:0x00, SDREN:0x01, TIMUNLOCK:0x01,
NM:0x00, CL:0x02, IBANK:0x02, EBANK:0x00, PAGESIZE:0x00
--------------------------------------------------------------------
SDRAM SDTIM1 Reg:
[31--24] [23--16] [15--08] [07--00]
00001010 01001001 00100001 01001000 == 0x0A492148
T_RFC:0x05, T_RP:0x01, T_RCD:0x01, T_WR:0x01, T_RAS:0x04, T_RC:0x05, T_RRD:0x01
--------------------------------------------------------------------
SDRAM SDTIM2 Reg:
[31--24] [23--16] [15--08] [07--00]
00111000 00000110 00000000 00000100 == 0x38060004
T_RAS_MAX:0x07, T_XSR:0x06, T_CKE:0x04
//T_RAS_MAX = (tRAS_MAX/ SDRAM refresh rate) - 1) = 120k ns / 15.625us = 7.68 -1 = 7
--------------------------------------------------------------------
SDRAM SDRFC Reg:
[31--24] [23--16] [15--08] [07--00]
00000000 00000000 00000110 00011011 == 0x0000061B
LP_MODE:0x00, MCLKSTOP_EN:0x00, SR_PD:0x00, REFRESH_RATE:0x61B
//REFRESH_RATE=EClk*Tref/4096(rows) = 100Mhz*64/4096 = 1562.5 = 1563
AISgen中,ROMID检查后,读取后为D800K005,CPU输入时钟为25MHz,我配置的DSP工作频率为300MHz,SDRAM连接在EMIFB上面,配置频率为100MHz,其它LPSC、PINMUX主要是配置了一下SPI0、SPI1、EMIFA、EMIFB、GIOP5器件的相关引脚及电源打开。
硬件引导方式为SPI0 NorFlash,已经验证Boot引导成功,在线Debug读取PLL、EMIF等器件寄存器,已经按引导方式配置完成。
EMIB寄存器各参数与AISgen中参数一致。现在通过地址直接访问的方式发现SDRAM读写不正确,通过CCS memory browser发现SDRAM地址中数据为零,直接在CCS memory browser中修改SDRAM地址也不成功。
通过将EMIB地址线等等配置成GPIO方式,拉高拉低的方式验证,CPU与SDRAM管脚连接没有问题。
求教各位,是我在AISgen中参数EMIFB寄存器参数配置不正确?还是什么原因导致SDRAM访问不正确的?还有什么办法可以排查问题出在哪里?
谢谢大家的帮忙!!!
一周热门 更多>