uboot自定義命令
U-Boot 是一個主要用于嵌入式系統的引導加載程序,可以支持多種不同的計算機系統結構,包括PPC、ARM、AVR32、MIPS、x86、68k、Nios與MicroBlaze。這也是一套在GNU通用公共許可證之下發布的自由軟件。
U-Boot本質是一個裸機程序,是一種普遍用于嵌入式系統中的開源的Bootloader,作用是用來引導操作系統,以及給開發人員提供測試調試工具。主要負責基本硬件初始化,導啟動內核啟動。
U-Boot命令眾多,通過uboot命令可完成系統環境變量設置。U-Boot本質就是一份裸機程序,這樣可以在U-Boot命令下調試一些硬件設備問題。U-Boot命令行也是可以實現自動補全功能。
1.uboot命令格式分析
??uboot命令存放在uboot目錄下的common目錄下。
??do_help命令功能實現如下:
extern cmd_tbl_t __u_boot_cmd_bdinfo; extern cmd_tbl_t __u_boot_cmd_showvar; int do_help(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[]) { // return _do_help(&__u_boot_cmd_start, // &__u_boot_cmd_end - &__u_boot_cmd_start, // cmdtp, flag, argc, argv); return _do_help(&__u_boot_cmd_bdinfo, &__u_boot_cmd_showvar - &__u_boot_cmd_bdinfo + 1, cmdtp, flag, argc, argv); } U_BOOT_CMD( help, CONFIG_SYS_MAXARGS, 1, do_help, "print command description/usage", "\n" " - print brief description of all commands\n" "help command ...\n" " - print detailed usage of 'command'" ); /* This does not use the U_BOOT_CMD macro as ? can't be used in symbol names */ cmd_tbl_t __u_boot_cmd_question_mark Struct_Section = { "?", CONFIG_SYS_MAXARGS, 1, do_help, "alias for 'help'", #ifdef CONFIG_SYS_LONGHELP "" #endif /* CONFIG_SYS_LONGHELP */ };
U_BOOT_CMD為命令參數傳遞:
help 命令標志符;
CONFIG_SYS_MAXARGS命令傳遞的最大參數個數;
1 命令重復執行次數;
do_help命令實現函數;
“alias for ‘help’”命令用法說明;
最后一個參數為命令用法詳細說明;
int do_help(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])函數參數說明:
cmd_tbl_t * cmdtp結構體指針。
struct cmd_tbl_s { char *name; /* 命令名字*/ int maxargs; /*命令傳遞的最大參數個數*/ int repeatable; /*命令重復執行次數*/ /*命令功能實現函數*/ int (*cmd)(struct cmd_tbl_s *, int, int, char * const []); char *usage; /*命令基本用法說明*/ #ifdef CONFIG_SYS_LONGHELP char *help; /*命令詳細用法說明*/ #endif #ifdef CONFIG_AUTO_COMPLETE /* do auto completion on the arguments */ int (*complete)(int argc, char * const argv[], char last_char, int maxv, char *cmdv[]); #endif };
??argc 命令傳入的參數個數,和main函數argc相同;
??argv 存放命令參數內容,和main函數argv相同;
2.tiny4412下編寫uboot命令控制蜂鳴器
2.1 tiny4412開發板beep硬件接口
??配置寄存器:GPD0CON_ADDR = 0x1140_0000 + 0x00A0
2.3 參考help命令模板實現beep命令
#include #include /*蜂鳴器*/ #define GPD0_CON *((volatile unsigned int *)0x114000A0)//控制寄存器 #define GPD0_DAT *((volatile unsigned int *)0x114000A4)//數據寄存器 int do_beep(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[]) { /*蜂鳴器*/ GPD0_CON&=0xfffffff0;//清除當前GPD0_0的配置 GPD0_CON|=0x00000001;//設置為輸出模式 //beep on 或者 beep off if(argc!=2) { printf("格式:beep on/off\n"); return 0; } if(strcmp(argv[1],"on")==0)//開蜂鳴器 { GPD0_DAT|=1<<0;//開蜂鳴器 } else if(strcmp(argv[1],"off")==0)//關蜂鳴器 { GPD0_DAT&=~(1<<0);//關蜂鳴器 } return 0; } U_BOOT_CMD( beep, CONFIG_SYS_MAXARGS, 1, do_beep, "beep ", "\n" "beep用法\n" "開蜂鳴器:beep on\n" "關蜂鳴器:beep_off" );
2.4 程序編譯
??1. 將cmd_beep.c拷貝到u_boot目錄下的common目錄下
[wbyq@wbyq common]$ cp /mnt/hgfs/ubuntu/cmd_beep.c ./
??2. 修改common目錄下的Makefile文件。
[wbyq@wbyq common]$ vim Makefile

??3.在uoot頂層目錄下執行make,重新編譯uboot
[wbyq@wbyq uboot_tiny4412-sdk1506]$ make
??4.燒寫uboot
[wbyq@wbyq uboot_tiny4412-sdk1506]$ cd sd_fuse/ [wbyq@wbyq tiny4412]$ sudo ./sd_fusing.sh /dev/sdb
??beep命令編寫成功。
??5. beep命令運行測試
TINY4412 # beep 格式:beep on/off TINY4412 # ? beep flag=0 beep - beep Usage: beep beep用法 開蜂鳴器:beep on 關蜂鳴器:beep_off TINY4412 # beep on TINY4412 # beep off
3.分析uboot保存環境變量位置
??在Linux操作系統啟動前,uboot需要完成系統環境變量配置。在uboot目錄下有tiny4412.h中保存的系統的默認環境變量參數。
?1.當我們修改了系統環境變量,執行了saveenv命令后,則環境變量將寫入到磁盤中,接下來我們將分析一下uboot源碼中環境變量寫入磁盤的扇區位置。
在uboot命令中,并沒有直接腳cmd_save.c的函數,因此,我們可以根據saveenv命令執行后的提示信息來分析。在uboot命令行下執行saveenv命令時,會看到有輸出提示信息,這樣我們可以直接在uboot工程中搜索一下輸出信息的位置。
TINY4412 # save Saving Environment to SMDK bootable device... done



??2.接下來跳入saveenv函數,查看一下該函數執行過程。
??當我們跳到定義處時會看到有多重位置,要想準確跳轉到正確位置,我們可以再查找參考saveenv命令的后半段提示信息賦值位置。
?3.經過查找參考我們發現,后半段提示信息的定義位置是在env_auto.c中,而我們saveenv函數右鍵跳到定義處時在env_auto.c中也有定義,說明我們要跳轉的文件即為env_atuo.c文件。
在 saveenv函數中,并沒有看到有關于mmc寫扇區的函數,說明我們還需要進一步跳轉到對應的子函數中去分析。
??4.我們可以再次根據saveenv命令的打印提示,在最后還會打印“done”這個信息,這樣我們就可以更新這個信息,對當前函數中的三個子函數進行分析,看下哪一個子函數中有這個字符串的打印。經過查看代碼可知最終調用的函數即為saveenv_movinand()函數。
??5.再次跳到movi_write_env()函數中查看一下寫入到mmc中的地址。
??6.在這個函數中即為實現環境變量寫入作用,再次跳到movi_write()函數中查看一下這個函數參數作用。
??可以看到,movi_write()函數參數作用分別為:mmc設備編號、寫入mmc的起始扇區、寫入的扇區個數、寫入的環境變量內容。
??我們可以在這個函數中加入printf函數打印一下寫入的扇區地址和扇區數量。然后再重新編譯uboot,燒寫到SD卡中再次啟動查看效果。
TINY4412 # save Saving Environment to SMDK bootable device... start=1025,blkcnt=32 done TINY4412 #
-
Linux
+關注
關注
87文章
11469瀏覽量
212895 -
Uboot
+關注
關注
4文章
128瀏覽量
28920
發布評論請先 登錄
HarmonyOS應用自定義鍵盤解決方案
如何使用Linux映像在IMX8ULP上啟用自定義logo?
如何添加自定義單板
如何快速創建用戶自定義Board和App工程

think-cell:自定義think-cell(四)

智能語音識別照明解決方案,平臺自定義,中英切換

think-cell;自定義think-cell(一)

如何創建TestStand自定義步驟

評論