Chinaunix首页 | 论坛 | 博客
  • 博客访问: 66654
  • 博文数量: 19
  • 博客积分: 745
  • 博客等级: 军士长
  • 技术积分: 215
  • 用 户 组: 普通用户
  • 注册时间: 2010-03-09 12:16
文章分类

全部博文(19)

文章存档

2010年(19)

我的朋友

分类: LINUX

2010-05-14 17:34:33

   在开发板上配置UBOOT环境变量时,不小心误把BOOTDELAY设置为0,这样就不能在开发板启动后进入配置环境,也就无法将BOOTDELAY修改回来。
   首先想利用AXD在线下载原始UBOOT镜像到SDRAM,在线运行后来进入配置环境修改参数,但是实际进行后发现,虽然AXD在线在SDRAM中跑正常UBOOT,但是UBOOT启动的时候还是读取了存取在FLASH中的BOOTARGS参数信息,依然时BOOTDELAY为0,所以这样子也行不通。
   这时候我想到去UBOOT源代码中修改关于BOOTDELAY的相关代码功能,以让其在启动过程中不读取FLASH中的BOOTARGS参数。
   PS:在请教师兄后,师兄也提出了和我想的一样的方法,同时还有一个方法就是在AXD中对FLASH进行擦除操作,但是这里就要涉及到FLASH操作的很多内容,也比修改代码要复杂,如果以后要研究FLASH的操作的话,可以考虑尝试下。

   BOOTDELAY参数的功能函数位置在 /common/main.c 中,找到:

static __inline__ int abortboot(int bootdelay)

   注意:在main.c中有两段同名的abortboot函数,通过预处理来进行选择,分析函数内容可以知道是第二个函数。
   首先修改了判断是否自启动的信号变量abort,修改如下:

int abort = 1;        /* wuwei have changed this : the old is "abort = 0" ! */
                      /* The value of abort define autoboot by 0 and unautoboot by 1 */

   然后通过预处理去掉接在后面的bootdelay判断处理函数:

#if 0        /*wuwei closed blow code , let uboot not to juge bootdelay*/

#ifdef CONFIG_MENUPROMPT

……

printf ("\b\b\b%2d ", bootdelay);

#endif

   这样修改后UBOOT就在启动后停着等待用户输入命令,不进行BOOTDELAY的倒计时过程了。

*******************************   更新   *******************************************

   根据师兄的指导,了解到参数的位置在 0x20000 ~ 0x3ffff 之间,也就是接在uboot程序所在的 0x0 ~ 0x1ffff 区间的后面,uboot启动时先读取该区间段的参数,如果没有,就按照源码中 config 文档中的默认配置。
阅读(6263) | 评论(0) | 转发(2) |
给主人留下些什么吧!~~