共2条
1/1 1 跳转至页
load,SDRAM 程序load到外部SDRAM运行跑飞的问题
问
我用的是自己坐的6711的板子,我把程序load到内部ram的时候程序是正常运行的,当我把整个程序全部load到外部SDRAM的时候,程序一运行就跑飞了,根本连GO MAIN都不行。但是我把同样的程序用在TI6711DSk的时候,load到外部SDRAM可以正常运行,请问这是什么问题,望解答,谢谢!! 答 1: 估计板子的稳定性不好,我的也又这个现象啊 答 2: 看看你load之前有没有初始化sdram如果没有,在启动时的gel文件里加入初始化sdram的代码 答 3: gel文件那里有初始化sdram的代码,能细说一下吗? 答 4: 已经GEL初始化了SDRAM了 我现在发现我的6711的板上的CPLD烧写不同程序会对DSP的外部ram有影响。有些程序行,有些程序不行!DSP与CPLD有八跟数据线直接相连,是不是以后应该在它们之间加总线隔离器啊? 答 5: gel的初始化程序如下:menuitem "My function";
/*---------------------------------------------------------------------------*/
/* EMIF REGISTERS */
/*---------------------------------------------------------------------------*/
#define EMIF_GCTL 0x01800000
#define EMIF_CE1 0x01800004
#define EMIF_CE0 0x01800008
#define EMIF_CE2 0x01800010
#define EMIF_CE3 0x01800014
#define EMIF_SDRAMCTL 0x01800018
#define EMIF_SDRAMTIMING 0x0180001C
#define EMIF_SDRAMEXT 0x01800020
hotmenu Intial_6711()
{
/*---------------------------------------------------------------------------*/
/* EMIF REGISTER VALUES - these should be verified with TARGET hardware */
/*---------------------------------------------------------------------------*/
*(int *)EMIF_GCTL = 0x00003300;/* EMIF global control */
*(int *)EMIF_CE1 = 0xFFFFFF03; /* CE1 - 32-bit asynch access after */
*(int *)EMIF_CE0 = 0xFFFFFF30; //CE0 */
*(int *)EMIF_CE2 = 0xFFFFFF23; // CE2 - 32-bit asynch on
*(int *)EMIF_CE3 = 0xFFFFFF23; // CE3 - 32-bit asynch on
*(int *)EMIF_SDRAMCTL = 0x07126000; //SDRAM control register (100
*(int *)EMIF_SDRAMTIMING = 0x0000061A; //SDRAM Timing
} 答 6: 1\ti\cc\gel下面有gel文件的例子,可以以它们为模板修改,比如DSK6211_6711.gel里的init_emif()就有初始化SDRAM的代码(被注释了的)。
为了使用gel文件,你必须在Code Composer Studio Setup Utility里的Board Properties->Startup GEL File(s)选择你的gel文件。这样的话每当启动CCS时,gel文件的内容会被扫描,里面所有的GEL函数会被装载,然后执行StartUp()函数,由于init_emif()在StartUp()内被调用,SDRAM于是得以初始化
你load到sdram里不成功,很可能是电路问题,也可能是初始值与电路配置不符。以前我也遇到过连焊的错误,改了就好了 答 7: 你地板子是否有于扰
我用的是自己坐的6711的板子,我把程序load到内部ram的时候程序是正常运行的,当我把整个程序全部load到外部SDRAM的时候,程序一运行就跑飞了,根本连GO MAIN都不行。但是我把同样的程序用在TI6711DSk的时候,load到外部SDRAM可以正常运行,请问这是什么问题,望解答,谢谢!! 答 1: 估计板子的稳定性不好,我的也又这个现象啊 答 2: 看看你load之前有没有初始化sdram如果没有,在启动时的gel文件里加入初始化sdram的代码 答 3: gel文件那里有初始化sdram的代码,能细说一下吗? 答 4: 已经GEL初始化了SDRAM了 我现在发现我的6711的板上的CPLD烧写不同程序会对DSP的外部ram有影响。有些程序行,有些程序不行!DSP与CPLD有八跟数据线直接相连,是不是以后应该在它们之间加总线隔离器啊? 答 5: gel的初始化程序如下:menuitem "My function";
/*---------------------------------------------------------------------------*/
/* EMIF REGISTERS */
/*---------------------------------------------------------------------------*/
#define EMIF_GCTL 0x01800000
#define EMIF_CE1 0x01800004
#define EMIF_CE0 0x01800008
#define EMIF_CE2 0x01800010
#define EMIF_CE3 0x01800014
#define EMIF_SDRAMCTL 0x01800018
#define EMIF_SDRAMTIMING 0x0180001C
#define EMIF_SDRAMEXT 0x01800020
hotmenu Intial_6711()
{
/*---------------------------------------------------------------------------*/
/* EMIF REGISTER VALUES - these should be verified with TARGET hardware */
/*---------------------------------------------------------------------------*/
*(int *)EMIF_GCTL = 0x00003300;/* EMIF global control */
*(int *)EMIF_CE1 = 0xFFFFFF03; /* CE1 - 32-bit asynch access after */
*(int *)EMIF_CE0 = 0xFFFFFF30; //CE0 */
*(int *)EMIF_CE2 = 0xFFFFFF23; // CE2 - 32-bit asynch on
*(int *)EMIF_CE3 = 0xFFFFFF23; // CE3 - 32-bit asynch on
*(int *)EMIF_SDRAMCTL = 0x07126000; //SDRAM control register (100
*(int *)EMIF_SDRAMTIMING = 0x0000061A; //SDRAM Timing
} 答 6: 1\ti\cc\gel下面有gel文件的例子,可以以它们为模板修改,比如DSK6211_6711.gel里的init_emif()就有初始化SDRAM的代码(被注释了的)。
为了使用gel文件,你必须在Code Composer Studio Setup Utility里的Board Properties->Startup GEL File(s)选择你的gel文件。这样的话每当启动CCS时,gel文件的内容会被扫描,里面所有的GEL函数会被装载,然后执行StartUp()函数,由于init_emif()在StartUp()内被调用,SDRAM于是得以初始化
你load到sdram里不成功,很可能是电路问题,也可能是初始值与电路配置不符。以前我也遇到过连焊的错误,改了就好了 答 7: 你地板子是否有于扰
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 | |
【FRDM-MCXN947评测】核间通信MUTEX被打赏50分 |