|
|
|
|
 sdram初始化为什么还是不对? - buynail [ 2005-07-24 13:49 | 2,493 byte(s)]
 Re: sdram初始化为什么还是不对? - buynail [ 2005-07-24 17:36 | 29 byte(s)]
|
|
|
|
[Original]
[Print]
[Top]
|
我使用的CPU是MPC8250,用的内存芯片是SAMSUNG的K4S643232F-TC60
ppboot可以正常从FLASH启动,relocate_code()函数也执行了,用BDI2000查看了内存内容也是PPCBOOT的内容(说明搬运代码已经正确)。但是relocate_code()函数之后,系统的“printf”函数就不能执行了。relocate_code()函数之后,
在console.c这个子程序中有下面一段程序:
#ifndef CFG_CONSOLE_INFO_QUIET
puts("console line 497
"); /*用于测试,说明程序进入到这一行了*/
/* Print informations */
printf ("In: ");
if (stdio_devices[stdin] == NULL) {
puts("no input devices
"); /*用于测试,说明程序进入到这一行了*/
printf ("No input devices available!
");
} else {
puts("find output devices
"); /*用于测试,说明程序进入到这一行了*/
printf ("%s
", stdio_devices[stdin]->name);
}
printf ("Out: ");
if (stdio_devices[stdout] == NULL) {
printf ("No output devices available!
");
} else {
printf ("%s
", stdio_devices[stdout]->name);
}
printf ("Err: ");
if (stdio_devices[stderr] == NULL) {
puts("no output devices
"); /*用于测试,说明程序进入到这一行了*/
printf ("No error devices available!
");
} else {
puts("find output devices
"); /*用于测试,说明程序进入到这一行了*/
printf ("%s
", stdio_devices[stderr]->name);
}
#endif /* CFG_CONSOLE_INFO_QUIET */
执行的时候出了问题。
puts("console line 497
");
puts("find input devices
");
puts("find output devices
"); 这3条语句在串口中有打印信息出来,那么说明这些语句肯定执行了,但是下面的
printf ("In: ");
printf ("Out: ");
printf ("Err: ");这些打印消息都没有出来,请问这是什么原因啊?
请问有谁知道,给指点一下。
整个console函数执行之后,后面的函数也都执行了,并且出现了ppcboot启动成功的提示符“=>”
敲入命令之后,没有任何反应。
网上有人说是内存burst mode的问题,是这样吗?那位高人碰到过类似的问题或者给一些建议吗?
我尝试了很多中不同的SDRAM初始化时序,结果都是一样。
|
|
|
[Original]
[Print]
[Top]
|
|
|