uboot给内核传参的方式——tag
一:tag是什么?
tag 是一個數據結構:stract tag ?這種數據格式在uboot和kernel是一樣的,也就是說uboot在啟動的時候將需要傳給kernel的參數放在了DDR的某個地址處,而存放格式就是tag格式,然后kernel就會到這個地址去讀取這些參數,讀取方式也是按tag格式去讀取的。
簡單來說tag就像是一個數組一樣,是一塊連續的內存,里面存放了uboot需要傳遞給kernel的參數信息,我們通過定義一個指針params(static?struct?tag?*params;),先使其指向tag的存放地址(30000100,uboot也就是說在30000100的地方存放了一條信息,告訴kernel去0x54410001這個地方去讀取tag(也就是uboot傳遞給kernel的參數))
二:分析
(1)CONFIG_SETUP_MEMORY_TAGS:tag_mem,傳參內容是內存的配置信息
(2)CONFIG_CMDLINE_TAG :tag_cmdline,傳參內容是啟動命令參數,也就是uboot環境變量bootargs
(3)CONFIG_INITRD_TAG
(4)CONFIG_MTDPARTITION:傳參內容是iNand/SD卡的分區表
(5)起始tag是ATAG_CORE ?結束tag是ATAG_NONE,其他的ATAG_xxx都是有效信息,傳遞著某些參數
(params?=?(struct?tag?*)?bd->bi_boot_params;這里的bi_boot_params為30000100),然后讓params(遠跳轉)指向tag的開頭(params->hdr.tag?=?ATAG_CORE;這里的ATAG_CORE為0x54410001),讓其繼續指向這個tag中的其他內容,并進行賦值,在這個tag的最后通過params?=?tag_next?(params);將params指向下一個tag,所以當我們操作一個tag時不需要考慮這個時候內存(也就是params指向什么地方)
三:內核如何拿到這些tag信息??
uboot最終通過調用theKernel?(0,?machid,?bd->bi_boot_params);函數來執行linux內核的,uboot調用這個函數(其實就是linux內核)時傳遞了三個參數。這三個參數就是uboot直接傳遞給linux內核,這3個參數是通過寄存器來實現的傳參的,第一個參數就放在r0中,第二個參數(機器碼)放在r1中,第三個參數放在r2中(第三個參數傳遞的就是tag的首地址這里是30000100)
本文轉自 菜鳥養成記 51CTO博客,原文鏈接:http://blog.51cto.com/11674570/1833740
與50位技術專家面對面20年技術見證,附贈技術全景圖
總結
以上是生活随笔為你收集整理的uboot给内核传参的方式——tag的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Hyper-V Server虚拟机快照(
- 下一篇: CentOS安装crontab及使用方法