www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 單片機 > 單片機
[導讀] 1.最后生成u-boot的過程以下是u-boot Makefile最后連接生成u-boot的過程UNDEF_SYM=`arm-linux-objdump-x lib_generic/libgeneric.a board/EmbedSky/libEmbedSky.a cpu/arm920t/libarm920t.a cpu/arm920

1.最后生成u-boot的過程
以下是u-boot Makefile最后連接生成u-boot的過程

  1. UNDEF_SYM=`arm-linux-objdump-x lib_generic/libgeneric.a board/EmbedSky/libEmbedSky.a cpu/arm920t/libarm920t.a cpu/arm920t/s3c24x0/libs3c24x0.a lib_arm/libarm.a fs/cramfs/libcramfs.a fs/jffs2/libjffs2.a net/libnet.a rtc/librtc.a drivers/libdrivers.a drivers/nand/libnand.a drivers/nand_legacy/libnand_legacy.a drivers/lcd/liblcd.a modules/usb.module modules/wince.module common/libcommon.a|sed-n-e's/.*(__u_boot_cmd_.*)/-u1/p'|sort|uniq`;


  2. cd/root/embed/opt/EmbedSky/u-boot-1.1.6&&arm-linux-ld-Bstatic-T/root/embed/opt/EmbedSky/u-boot-1.1.6/board/EmbedSky/u-boot.lds-Ttext 0x33D80000 $UNDEF_SYM cpu/arm920t/start.o


  3. --start-group lib_generic/libgeneric.a board/EmbedSky/libEmbedSky.a cpu/arm920t/libarm920t.a cpu/arm920t/s3c24x0/libs3c24x0.a lib_arm/libarm.a fs/cramfs/libcramfs.a fs/jffs2/libjffs2.a net/libnet.a rtc/librtc.a drivers/libdrivers.a drivers/nand/libnand.a drivers/nand_legacy/libnand_legacy.a drivers/lcd/liblcd.a modules/usb.module modules/wince.module common/libcommon.a--end-group-L/opt/EmbedSky/crosstools_3.4.5_softfloat/gcc-3.4.5-glibc-2.3.6/arm-linux/lib/gcc/arm-linux/3.4.5-lgcc


  4. -Map u-boot.map-o u-boot

a. UNDEF_SYM的作用

  1. 用objdump-x 列出所有庫的頭

  2. 用sed 將 __u_boot_cmd_.*替換成-u__u_boot_cmd_.*

  3. sort|uniq 去掉重復的部分

  4. 所以執(zhí)行后 UNDEF_SYM=

  5. -u__u_boot_cmd_autoscr

  6. …...

  7. -u__u_boot_cmd_test_zImage

  8. -u__u_boot_cmd_tftpboot

  9. -u__u_boot_cmd_usbslave

b. arm-linux-ld -Tu-boot.lds -Ttext 0x33D80000

  1. u-boot.lds 中有如下:

  2. .=0x00000000;

  3. .=ALIGN(4);

  4. .text:

  5. {

  6. cpu/arm920t/start.o(.text)

  7. board/EmbedSky/boot_init.o(.text)

  8. *(.text)

  9. }

b.1雖然 u-boot.lds 是從0x00000000 開始,但是這兒明確的指定了 -Ttext 0x33D80000, 所以生成的u-boot的代碼段是從0x33D80000開始的。
b.2 另外 UNDEF_SYM中的一系列的 -u__u_boot_cmd_.*提供給ld
但是還有一點不太明白的就是,為什么要這樣做?
參考了這篇文章,對crifan的崇拜有如滔滔江水......
http://www.crifan.com/2010/02/27/detailed_analysis_of_the_make_uboot_final_compile_and_link_the_implementation_process/
以下引自crifan的《詳細分析make uboot 最后的編譯鏈接的具體執(zhí)行過程 v2012-03-29》

  1. “-u symname

  2. ——————————

  3. Enter symname as an undefined symbolinthe symbol table.Thisisusefulforloading entirely from an archive library,since initially the symbol tableisempty,andan unresolved referenceisneededtoforce the loading of the first routine.The placement of thisoptiononthe command lineissignificant;it must be placed before the library that will define the symbol.

  4. —————————————————————————————————————-

  5. 總的意思,就是,在ld的時候,不定義,這些符號,即不定義__u_boot_cmd_asdebug,__u_boot_cmd_base等等這些符號,我的理解是,因為開始需要從某個庫中載入其他的符號,而這個時候,還沒有載入到那個包含此符號定義的庫,所以,暫時先加入這個-u說明,先不定義這些符號,等到所有的庫都加載完了,再去找這些符號的定義,此時已經加載完所有的庫了,也就能找到這些符號的定義了。

  6. (F)接下來的,就是要ld的,那一堆的目標文件,庫文件了:

  7. cpu/arm926ejs/start.o和

  8. –start-group lib_generic/libgeneric.a lib_generic/lzma/liblzma.a cpu/arm926ejs/libarm926ejs.a 。。。。。。 post/libpost.a board/ams/as3536/libas3536.a –end-group

  9. 關于–start-group和 –end-group的含義:

  10. -(archives)或者—start-group archives –end-group 參數(shù)中間的目標文件會被ld反復搜索,對相互交叉引用的目標文件很有用

  11. 所以,我的理解是,如果ld載入了一個庫,發(fā)現(xiàn)該庫中,有UNDF,未被定義的變量,有了這個參數(shù)的指示后,就會在這一堆.a和.o文件里面反復搜索,直至找到為止,否則,如果在已經加載的庫中,找不到,就會報錯?!?br/>


  12. 關于”–start-group和 –end-group”,又去找了相關資料:


  13. Linker order – GCC


  14. GCC:–start-groupand–end-group command line options


  15. 得知確切的含義是:


  16. 鏈接器LD去load對應的庫(lib,module)的時候,可能會遇到這些情況:


  17. (1)A庫,引用了B庫中funcInB(),但是先ld A庫,導致找不到對應的funInB而鏈接報錯


  18. (2)A庫和B庫,互相都包含對應所引用到的函數(shù),即互相引用/循環(huán)引用,ld編譯器會因為找不到A庫中所引用的B庫的中的函數(shù)(或者反過來B庫引用A庫中的函數(shù))而報錯。


  19. 此時,用”–start-group和 –end-group“,通知ld鏈接器,去在–start-group和–end-group中間的這些庫函數(shù),多花點時間,對于這些庫,都從頭到尾,多查幾遍,去找找那些還沒有找到的所引用的函數(shù),是不是在另外的庫中有這些函數(shù),以此解決:


  20. (1)A庫引用到了后來才加載的B庫中的函數(shù)


  21. (2)解決循環(huán)引用


  22. 之類的問題。



本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉