这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 综合技术 » 基础知识 » load,SDRAM 程序load到外部SDRAM运行跑飞的问题

共2条 1/1 1 跳转至

load,SDRAM 程序load到外部SDRAM运行跑飞的问题

院士
2006-09-17 18:14:16     打赏
load,SDRAM 程序load到外部SDRAM运行跑飞的问题



关键词: SDRAM     程序     外部     运行     跑飞     问题    

院士
2006-12-22 22:43:00     打赏
2楼


我用的是自己坐的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有影响。有些程序行,有些程序不行!DSPCPLD有八跟数据线直接相连,是不是以后应该在它们之间加总线隔离器啊? 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 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]