在初始化uboot运行中,有log很奇怪,我就看了一下,之前说了环境变量从哪里来
在main.c中,有个地方会等待在那边等你输入新的环境变量,这里等了三秒
void main_loop (void) {
s = getenv ("bootdelay"); //获取等待的时间,是3s
s = getenv ("bootdelay"); //从哪里启动,这里是emmc
### main_loop: bootcmd="run bootcmd_mmc"
if (bootdelay >= 0 && s && !abortboot (bootdelay)) //这个abortboot 就是等待3s中有输入的情况
run_command (s, 0);没有输入走这个函数
argv[i]=“bootargs_mmc” arg = getenv (argv[i])) == NULL这个函数之前 之后就变成了 setenv bootargs ${bootargs} ip=none root=/dev/mmcblk0p1 rootwait 然后又变成了 "setenv bootargs console=ttymxc0,115200 video=mxcfb0:dev=ldb,CH B_8WVGALVDS_V1,if=RGB666,bpp=16 ldb=sin0 video=mxcfb1:off video=mxcfb2:off video =mxcfb3:off ip=none root=/dev/mmcblk0p1 rootwait" 其实也就是${bootargs} 被填充了,也就是先run_command的参数是bootcmd_mmc,经过循环调用getenv 最后变成了长长的一串,一开始我还没看明白,每次经过 arg = getenv (argv[i])和process_macros (token, finaltoken);这个函数之后,cmdline都会变长 process_macros (token, finaltoken);这个函数负责把${}转化为具体的cmd,其实这两个函数最后都用到了getenv
里面的
return ((char *)env_get_addr(val));其实也是一样到某个地址里去取环境变量
uchar *env_get_addr (int index) { if (gd->env_valid) { return ( ((uchar *)(gd->env_addr + index)) ); gd终于出现了 } else { return (&default_environment[index]); } }
获取到了环境变量之后,执行int do_run (cmd_tbl_t * cmdtp, int flag, int argc, char *argv[])
在此期间也会循环调用rum_command,直到没有任何$[],或者高级环境变量的存在之后,执行
if ((cmdtp->cmd) (cmdtp, flag, argc, argv) != 0) { rc = -1; }
这个cmdtp->cmd是个
struct cmd_tbl_s { char *name;/* Command Name*/ int maxargs;/* maximum number of arguments*/ int repeatable;/* autorepeat allowed?*/ /* Implementation function*/ int (*cmd)(struct cmd_tbl_s *, int, int, char *[]); char *usage;/* Usage message(short)*/ #ifdef CONFIG_SYS_LONGHELP char *help;/* Help message(long)*/ #endif #ifdef CONFIG_AUTO_COMPLETE /* do auto completion on the arguments */ int (*complete)(int argc, char *argv[], char last_char, int maxv, char *cmdv[]); #endif };里面有个对应的执行函数
比如./common/cmd_nvedit.c里
U_BOOT_CMD( run, CONFIG_SYS_MAXARGS,1,do_run, "run commands in an environment variable", "var [...]\n" " - run the commands in the environment variable(s) 'var'" );
U_BOOT_CMD( setenv, CONFIG_SYS_MAXARGS, 0, do_setenv, "set environment variables", "name value ...\n" " - set environment variable 'name' to 'value ...'\n" "setenv name\n" " - delete environment variable 'name'" );
获取到环境变量之后都是去设置,也就是如果环境变量有变化则更新,没有变化则单纯从emmc中读取到内存中。
如果要修改cmdline则在
int run_command (const char *cmd, int flag) {
char *str2="bootargs";
if(strstr(token,str2)) { strcpy(finaltoken,"setenv bootargs console=ttymxc0,115200 video=m\ xcfb0:dev=ldb,CHB_8WVGALVDS_V1,if=RGB24,bpp=24 ldb=sin0 video=mxcfb1:off video=\ mxcfb2:off video=mxcfb3:off ip=none root=/dev/mmcblk0p1 rootwait"); printf ("===============finaltoken1: \"%s\"\n", finaltoken); }
也就是将含有bootargs的改了
然后cat /proc/cmdline查看即可
如果想要修改固定初始值cmdline,则修改
Mx6q_sabresd.h (include\configs): "bootargs_base= Mx6q_sabresd.h(include\configs): " bootargs_base= Mx6q_sabresd_sd.h (include\configs): "bootargs_base=setenv b
这里头的参数即可