共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 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 基于MCP23S17的输入输出功能模块控制被打赏¥20元 | |
| 【S32K3XX】SPD 软件包使用Link文件修改被打赏¥22元 | |
| Switch-Case局部变量定义问题被打赏¥23元 | |
| 基于米尔TIAM62L开发板的串口通信及应用被打赏¥20元 | |
| PCF8574功能模块及其使用被打赏¥20元 | |
| 传感器LSM6DSO及LIS3MDL的功能检测被打赏¥18元 | |
| LPS25HB气压传感器及其检测被打赏¥18元 | |
| HTS221温湿度传感器及其检测被打赏¥18元 | |
| 【S32K3XX】HSE FW 版本更新被打赏¥21元 | |
| 基于ArduinoUNO开发板的AT24C02读写测试被打赏¥16元 | |
我要赚赏金
