新手看招 了解UBOOT添加命令的执行流程

转载 2012年03月25日 01:02:57

这个应该对我有帮助,使我能够更好的了解Uboot命令的执行流程

具体内容如下:

U-Boot的命令为用户提供了交互功能,并且已经实现了几十个常用的命令。如果开发板需要很特殊的操作,可以添加新的U-Boot命令

U-Boot的每一个命令都是通过U_Boot_CMD宏定义的。这个宏在include/command.h头文件中定义,每一个命令定义一个cmd_tbl_t结构体。

#define U_BOOT_CMD(name,maxargs,rep,cmd,usage,help) 
cmd_tbl_t __u_boot_cmd_##name Struct_Section = {#name, maxargs, rep, cmd, usage, help}

这样每一个U-Boot命令有一个结构体来描述。结构体包含的成员变量:命令名称、最大参数个数、重复数、命令执行函数、用法、帮助。

从控制台输入的命令是由common/command.c中的程序解释执行的。(这就是我要找的)find_cmd()负责匹配输入的命令,从列表中找出对应的命令结构体。

基于U-Boot命令的基本框架,来分析一下简单的icache操作命令,就可以知道添加新命令的方法。

(1)定义CACHE命令。在include/cmd_confdefs.h中定义了所有U-Boot命令的标志位。

#define CFG_CMD_CACHE       0x00000010ULL   /* icache, dcache       */

如果有更多的命令,也要在这里添加定义。

(2)实现CACHE命令的操作函数。下面是common/cmd_cache.c文件中icache命令部分的代码。

#if (CONFIG_COMMANDS & CFG_CMD_CACHE)
static int on_off (const char *s)
{       //这个函数解析参数,判断是打开cache,还是关闭cache
        if (strcmp(s, "on") == 0) {  //参数为“on”
               return (1);
        } else if (strcmp(s, "off") == 0) {  //参数为“off”
               return (0);
    }
    return (-1);
}
 
int do_icache ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
{     //对指令cache的操作函数
      switch (argc) {
      case 2:               /* 参数个数为1,则执行打开或者关闭指令cache操作 */
             switch (on_off(argv[1])) {
             case 0:     icache_disable();        //打开指令cache
                   break;
             case 1:     icache_enable ();        //关闭指令cache
                   break;
             }
            /* FALL TROUGH */
      case 1:           /* 参数个数为0,则获取指令cache状态*/  
            printf ("Instruction Cache is %sn",
                    icache_status() ? "ON" : "OFF");
            return 0;
      default:  //其他缺省情况下,打印命令使用说明
            printf ("Usage:n%sn", cmdtp->usage);
            return 1;
      }
      return 0;
}
……
U_Boot_CMD( //通过宏定义命令
    icache,   2,   1,     do_icache,  //命令为icache,命令执行函数为do_icache()
    "icache  - enable or disable instruction cachen",   //帮助信息
    "[on, off]n"
    "    - enable or disable instruction cachen"
);
……
#endif

U-Boot的命令都是通过结构体__U_Boot_cmd_##name来描述的。根据U_Boot_CMD在include/command.h中的两行定义可以明白。

#define U_BOOT_CMD(name,maxargs,rep,cmd,usage,help) 
cmd_tbl_t __u_boot_cmd_##name Struct_Section = {#name, maxargs, rep, cmd, usage, help}

还有,不要忘了在common/Makefile中添加编译的目标文件。

(3)打开CONFIG_COMMANDS选项的命令标志位。这个程序文件开头有#if语句需要预处理是否包含这个命令函数。CONFIG_COMMANDS选项在开发板的配置文件中定义。例如:SMDK2410平台在include/configs/smdk2410.h中有如下定义。

/***********************************************************
 * Command definition
 ***********************************************************/
#define CONFIG_COMMANDS 
                 (CONFIG_CMD_DFL  | 
                 CFG_CMD_CACHE     | 
                 CFG_CMD_REGINFO    | 
                 CFG_CMD_DATE      | 
                 CFG_CMD_ELF)

按照这3步,就可以添加新的U-Boot命令

相关文章推荐

新手看招 Unix和Linux下C语言学习指南

引言   尽管 C 语言问世已近 30 年,但它的魅力仍未减退。C 语言继续吸引着众多的开发者,他们为了编写、移植或维护应用程序而必须学习新技能。   本文是为了满足对C语言初学者或想提高自身C语...

linuxc语言-新手看招

  • 2013-11-26 15:33
  • 221KB
  • 下载

Uboot 添加命令的执行流程

BootLoader(引导装载程序)是嵌入式系统软件开发的第一个环节,它把操作系统和硬件平台衔接在一起,对于嵌入式系统的后续软件开发十分重要,在整个开发中也占有相当大的比例。U-BOOT是当前比较流行...

uboot 命令解析流程简析

uboot正常启动后,会调用main_loop(void)函数,进入main_loop()之后,如果在规定的时间(CONFIG_BOOTDELAY)内,没有检查到任何按键事件的发生,就会去加载OS,并...

IMX6Solo启动流程 外传-新建一条Uboot命令

新建一条Uboot命令

在UBOOT中添加自定义命令

uboot命令

uboot源码分析(1)uboot 命令解析流程简析

uboot 命令解析流程简析       uboot正常启动后,会调用main_loop(void)函数,进入main_loop()之后,如果在规定的时间(CONFIG_BOOTDELAY)内,没有...
  • sfrysh
  • sfrysh
  • 2011-10-27 11:00
  • 3923

GNU C中嵌入汇编添加一个自定义uboot命令

二话没用,直接上代码: #include #include /* static inline int __raw_readsb(unsigned int addr, void *data, i...

uboot下用do_run()函数来执行U_BOOT_CMD定义的命令

今天研究了一下uboot中怎么用do_run()函数来执行定义好的一些命令,发现其实也挺简单的,关键是得把do_run函数的几个参数吃透,这几个参数都是由uboot commmod 的cmd_tbl_...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)