99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

Intel PXA255處理器的U-B00t啟動過程、移植分析及下載調(diào)試

電子設計 ? 作者:電子設計 ? 2018-10-17 09:11 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

引 言

Bootloader是操作系統(tǒng)運行之前執(zhí)行的一小段程序,用來初始化硬件設備,建立一個系統(tǒng)空間映射圖和一個適當?shù)南到y(tǒng)軟硬件環(huán)境。最終Bootloader把操作系統(tǒng)內(nèi)核映像加載到RAM中。并將系統(tǒng)控制權交給內(nèi)核。BootLoader就是在操作系統(tǒng)內(nèi)核運行之前運行的一段小程序。通過這段小程序,我們可以初始化硬件設備、建立內(nèi)存空間映射圖,從而將系統(tǒng)的軟硬件環(huán)境帶到一個合適狀態(tài),以便為最終調(diào)用操作系統(tǒng)內(nèi)核準備好正確的環(huán)境。在嵌入式系統(tǒng)中,通常并沒有像BIOS那樣的固件程序(注,有的嵌入式CPU也會內(nèi)嵌一段短小的啟動程序),因此整個系統(tǒng)的加載啟動任務就完全由BootLoader來完成。比如在一個基于ARM7TDMI core的嵌入式系統(tǒng)中,系統(tǒng)在上電或復位時通常都從地址0x00000000處開始執(zhí)行,而在這個地址處安排的通常就是系統(tǒng)的BootLoader程序。

U-Boot被認為是功能最多,最具彈性以及開發(fā)最積極的開放源碼Bootloader。U-Boot已經(jīng)能夠支持PowerPC,ARM,X86和MIPS體系結(jié)構的上百種開發(fā)板,U-Boot還具有通過TFTP,從IDE或SCSI磁盤以及DOc啟動的能力,還提供了JFFS2的只讀功能。正是由于U-Boot較高的可靠性和穩(wěn)定性;高度靈活的功能設置;豐富的設備驅(qū)動程序和豐富的開發(fā)和調(diào)試文檔,因此選擇U-Boot作為目標板的Boot-loader。

對于嵌入式系統(tǒng),Bootloader是基于特定的硬件來實現(xiàn)的,因此建立一個通用的。Bootloader是不可能的,要使Bootloader能在目標板上運行,必須做出相應的修改。

1、目標板

目標板采用Intel PXA255處理器,頻率最高可達400 MHz,配置了32 MB的FLASH(Intel StrataFLASH)和64MB的SDRAM(Samsung),網(wǎng)卡采用LAN91C96。SDRAM:Synchronous Dynamic Random Access Memory,同步動態(tài)隨機存儲器,RAM(隨機存取存儲器)RAM -random access memory 隨機存儲器。存儲單元的內(nèi)容可按需隨意取出或存入,且存取的速度與存儲單元的位置無關的存儲器。這種存儲器在斷電時將丟失其存儲內(nèi)容,故主要用于存儲短時間使用的程序。 按照存儲信息的不同,隨機存儲器又分為靜態(tài)隨機存儲器(Static RAM,SRAM)和動態(tài)隨機存儲器(Dynamic RAM,DRAM)。所謂“隨機存取”,指的是當存儲器中的數(shù)據(jù)被讀取或?qū)懭霑r,所需要的時間與這段信息所在的位置無關。相對的,讀取或?qū)懭腠樞蛟L問(Sequential Access)存儲設備中的信息時,其所需要的時間與位置就會有關系(如磁帶)。同步是指 Memory工作需要同步時鐘,內(nèi)部的命令的發(fā)送與數(shù)據(jù)的傳輸都以它為基準;動態(tài)是指存儲陣列需要不斷的刷新來保證數(shù)據(jù)不丟失;隨機是指數(shù)據(jù)不是線性依次存儲,而是自由指定地址進行數(shù)據(jù)讀寫。SDRAM從發(fā)展到現(xiàn)在已經(jīng)經(jīng)歷了四代,分別是:第一代SDR SDRAM,第二代DDR SDRAM,第三代DDR2 SDRAM,第四代DDR3 SDRAM.(顯卡上的DDR已經(jīng)發(fā)展到DDR5) 板上有JTAG口、串口和網(wǎng)口,可分別完成程序的下載和調(diào)試工作。目標板的主要硬件資源如圖1所示。

Intel PXA255處理器的U-B00t啟動過程、移植分析及下載調(diào)試

2 U-Boot啟動過程分析

充分理解代碼的啟動流程,對于準確地判斷出移植過程中出錯的原因和出錯的位置具有重要的作用。

2.1 U-Boot啟動的入口點

一個可執(zhí)行的Image必須有一個入口點,并且只能有一個全局入口。可執(zhí)行Image的入口一般通過鏈接腳本文件來實現(xiàn),腳本簡單地說就是一條條的文字命令,這些文字命令是可以看到的(如可以用記事本打開查看、編輯),腳本程序在執(zhí)行時,是由系統(tǒng)的一個解釋器,將其一條條的翻譯成機器可識別的指令,并按程序順序執(zhí)行。因為腳本在執(zhí)行時多了一道翻譯的過程,所以它比二進制程序執(zhí)行效率要稍低一些。本通??梢杂蓱贸绦蚺R時調(diào)用并執(zhí)行。各類腳本被廣泛地應用于網(wǎng)頁設計中,因為腳本不僅可以減小網(wǎng)頁的規(guī)模和提高網(wǎng)頁瀏覽速度,而且可以豐富網(wǎng)頁的表現(xiàn),如動畫、聲音等。鏈接腳本主要用于規(guī)定如何把文件內(nèi)的section放入輸出映像文件內(nèi),并控制輸出文件內(nèi)各個部分在程序地址空間內(nèi)的分布。

以U-Boot支持的開發(fā)板1ubbock為例,查看鏈接腳本board/lubbock/u-boot.lds,就可以知道各個部分的鏈接順序。這個連接腳本決定了U-Boot的第一階段的代碼是從0xO開始的,入口由_start符號指定(ENTRY(_start)),第一個鏈接的文件是cup/pxa/start.o,那么U-Boot的入口指令一定位于這個程序中。

2.2 U-Boot的啟動步驟

U—Boot的啟動一般分為stagel和stage2兩個部分。依賴于CPU體系結(jié)構的代碼,通常用匯編語言實現(xiàn),放在stagel;而stage2則通常用C語言來實現(xiàn),這樣可以實現(xiàn)復雜的功能,而且有更好的可讀性和移植性。

根據(jù)對鏈接腳本文件和源代碼的分析,U-Boot的啟動過程中函數(shù)調(diào)用的順序如圖2所示。

Intel PXA255處理器的U-B00t啟動過程、移植分析及下載調(diào)試

2.2.1 stagel部分

U-Boot的stagel代碼從人口函數(shù)start.S開始,它用匯編語言寫成,主要完成的工作為:設置異常向量;設置CPu的速度、時鐘頻率及中斷控制寄存器;初始化內(nèi)存控制器;將ROM中的程序復制到RAM中;初始化堆棧;轉(zhuǎn)到RAM中執(zhí)行。RAM(隨機存取存儲器)RAM -random access memory 隨機存儲器。存儲單元的內(nèi)容可按需隨意取出或存入,且存取的速度與存儲單元的位置無關的存儲器。這種存儲器在斷電時將丟失其存儲內(nèi)容,故主要用于存儲短時間使用的程序。 按照存儲信息的不同,隨機存儲器又分為靜態(tài)隨機存儲器(Static RAM,SRAM)和動態(tài)隨機存儲器(Dynamic RAM,DRAM)。

stage1代碼執(zhí)行完以后,就為stage2的運行建立起了基本的硬件環(huán)境,此時的U-Boot的存儲器SDRAM映射圖如圖3所示。

Intel PXA255處理器的U-B00t啟動過程、移植分析及下載調(diào)試

2.2.2 stage2部分

接下來進入到U-Boot stage2,即C語言代碼部分,入口是start_arml300t,位于lib_arm/board.c中。startarmboot是C語言開始的函數(shù),也是整個啟動代碼中C語言的主函數(shù),同時還是整個U-Boot的主函數(shù),該函數(shù)主要完成的操作為:初始化本階段要使用到的硬件設備;檢測系統(tǒng)內(nèi)存映射;將內(nèi)核映像和根文件系統(tǒng)映像從FLASH拷貝到SDRAM中;為內(nèi)核設置啟動參數(shù);調(diào)用內(nèi)核。

在stage2部分,首先初始化全局數(shù)據(jù)表;然后順序執(zhí)行函數(shù)指針數(shù)組init_sequence中的初始化函數(shù);接下來調(diào)用FLAsH_init()函數(shù)初始化CFI FLAsH(針對NOR FLASH);接著調(diào)用env_relocate()函數(shù)初始化環(huán)境變量;然后獲取目標板的網(wǎng)絡地址,包括IP地址和MAC地址;接著調(diào)用commend/console.c中定義的函數(shù)console_init_r()初始化串口控制臺;最后進入main_loop循環(huán),以接收用戶命令。

3 U-Boot的移植

3.1 移植的目標與主要工作

在移植之前,需要清楚移植的目標是什么。為了達到這個目標,需要做哪些工作。一般的開發(fā)板上U-Boot所需的最小功能,包括:串口、FLASH和網(wǎng)卡,由此可得移植目標是:

(1)將U-Boot移植到目標板FLASH上;

(2)U-Boot能夠在目標板上運行起來;

(3)U-Boot能夠讀寫目標板上FLAsH等存儲設備;

(4)U-Boot能夠使網(wǎng)卡正常工作,能通過網(wǎng)卡下載數(shù)據(jù)。

根據(jù)以上的移植目標,所做的主要工作應該包括:

移植U-Boot與目標CPU相應的代碼;移植U-Boot的FLASH驅(qū)動;移植U-Boot,的網(wǎng)卡驅(qū)動。

3.2 參考板的選取

U-Boot本身已經(jīng)支持多種開發(fā)板,所以在移植的過程中一般不需要從零開始,可以選擇一個與自己目標板最接近的參考板,在參考板的基礎上進行修改。所以選擇適當?shù)膮⒖及迨鞘种匾?,選擇參考板的原則是參考板和目標板具有相同的處理器,至少類似的處理器;參考板和開發(fā)板具有相同的外圍接口電路,至少基本接口相同。

這里目標板的CPU為PXA255,在board目錄里選擇lubbock開發(fā)板作為參考板。對于相應的FLASH設備由于Intel FLAsH支持CFI(Common FLAsHInterface),選擇drivers/cfi_FLAsH.c作為FLASH設備驅(qū)動。由于目標板使用LAN91C96網(wǎng)卡,所以選擇drivers/lan91c96.c作為網(wǎng)卡驅(qū)動。

3.3 建立目標板支持文件

選擇好參考板后,就可以依據(jù)參考板按照下面的步驟建立起目標板的支持文件:

在board目錄下,通過“cp-rlubbock xsbase255”建立起目標板的支持目錄,將lubbock.c改名為xsbase255.c,在Makefile里把lubbock.o改名為xsbase255.o。

在inclLlde/configs目錄里。通過“cp 1ubbock.h xs-base255.h”命令建立起目標板的配置文件,這個文件需要經(jīng)常修改。

在U-Boot根目錄里的MakefiIe中加入如下的命令以創(chuàng)建目標板的編譯環(huán)境:

xsbase2 5 5 config:unconfig

@$(MKCONFIG)$(@:_config=)arm pxa xsbase255

注意在@$(MKCONFIG)$(@:_config=)arm

pxa xsbase255前面的空白處是由Tab鍵生成的,千萬不能以空格代替。

3.4 修改相關代碼

從移植U-Boot最小要求U-Boot能正常啟動的角度出發(fā),主要修改如下文件:

incIude/configs/xsbase255.h文件,大多數(shù)的寄存器參數(shù)都是在這一文件中設置完成的。

board/xsbase255/xsbase255.c文件,只需進行基本的配置,包括設置math-type,啟動參數(shù)首地址,獲取系統(tǒng)的RAM信息等。

board/xsbase255/config.mk文件,設置TEXT-BASE,即設置U-Boot:自己啟動時將自己復制到RAM中的起始地址。

驅(qū)動程序文件,主要包括網(wǎng)卡驅(qū)動和FLASH驅(qū)動程序。

3.4.1 目標板配置文件的修改

目標板配置文件inclLlde/configs/xsbase255.h,是移植過程中最重要的文件。

#define CONFIG_PXA255 1

#define CFG_SDRAMBASE O xa0000000

在這個頭文件中,配置相當?shù)闹匾?,里面配置著主要硬件的參?shù),配置時必須結(jié)合相應的硬件手冊才能正確的完成。主要的配置參數(shù)如表1所示。

Intel PXA255處理器的U-B00t啟動過程、移植分析及下載調(diào)試

除了上述表格列舉的以外,還有一些其他的參數(shù)需要修改,例如控制臺串口缺省的通信波特率,缺省的環(huán)境變量設置(包括本地IP地址、以太網(wǎng)接口的掩碼和MAC地址、服務器IP地址、傳遞給內(nèi)核的命令行參數(shù)等),啟動參數(shù)列表配置等。

3.4.2 目標板支持文件的修改

目標板支持文件board/xsbase255/xsbase255.c也需要修改,此文件中的重點是board_init()函數(shù),這個函數(shù)里包含與開發(fā)板密切相關的設備的初始化。bi_arch_number為系統(tǒng)啟動時傳遞給內(nèi)核的MACH號,如果這個參數(shù)與內(nèi)核配置的不相同,則內(nèi)核啟動解壓縮完成后將出現(xiàn)“Error:a”錯誤,提示用戶這個是體系結(jié)構參數(shù)傳遞不正確。bi_boot_params為啟動參數(shù)的地址,一般放在RAM起始的16 Kb處,在此設置為Oxa0000100。

3.4.3 驅(qū)動的移植

在這一部分主要包括閃存和網(wǎng)卡驅(qū)動程序的移植。

(1)FLASH驅(qū)動。這里所使用的目標板采用2片NOR型閃存,閃存(Flash Memory)是一種長壽命的非易失性(在斷電情況下仍能保持所存儲的數(shù)據(jù)信息)的存儲器,數(shù)據(jù)刪除不是以單個的字節(jié)為單位而是以固定的區(qū)塊為單位(注意:NOR Flash 為字節(jié)存儲。),區(qū)塊大小一般為256KB到20MB。閃存是電子可擦除只讀存儲器(EEPROM)的變種,EEPROM與閃存不同的是,它能在字節(jié)水平上進行刪除和重寫而不是整個芯片擦寫,這樣閃存就比EEPROM的更新速度快。由于其斷電時仍能保存數(shù)據(jù),閃存通常被用來保存設置信息,如在電腦的BIOS(基本輸入輸出程序)、PDA(個人數(shù)字助理)、數(shù)碼相機中保存資料等。單片容量16 MB,數(shù)據(jù)線寬度為16 b,2片并作1個32 MB的數(shù)據(jù)寬度為32b的。BANK。U-Boot本身支持CFI接口規(guī)范的閃存,涉及到的文件主要包括drivers/cfi-FLASH.c,comrhand/cmd_FLASH.c。

#define CFG_FLASH_CFI

#defineCFG_FLASH_CFl_DRIVER 1

(2)網(wǎng)卡驅(qū)動。這里使用的目標板上采用的網(wǎng)卡是LAN91C96,U-Boot自帶的驅(qū)動程序drivers/lan91c96.c恰好支持這個網(wǎng)卡,因此只需在include/Configs/xsbase255.h中添加相應的配置即可:

#define CONFIG_DRIVER_IAN91C96

#define CONFIG_LAN91C96_BASE 0x0C000300

CONFIG_LAN91C96_BASE定義的值,應當由網(wǎng)卡的片選地址和I/O基址決定。如果U-Boot固有的驅(qū)動程序沒有對目標板的支持,就需要自行在board/xsbase255目錄下添加驅(qū)動程序,然后將其添加到本目錄的Makefile中進行編譯和鏈接。Makefile文件 Makefile 一個工程中的源文件不計數(shù),其按類型、功能、模塊分別放在若干個目錄中,makefile定義了一系列的規(guī)則來指定,哪些文件需要先編譯,哪些文件需要后編譯,哪些文件需要重新編譯,甚至于進行更復雜的功能操作,因為 makefile就像一個Shell腳本一樣,其中也可以執(zhí)行操作系統(tǒng)的命令。

4 U-Boot的編譯和下載調(diào)試

在U-Boot根目錄里輸入命令:

make xsbase255_config

該命令通過。/mkconfig腳本生成include/config.mk的配置文件,然后運行make命令,完成編譯。如果在編譯過程中出現(xiàn)錯誤,可根據(jù)錯誤的提示逐一排查。完成了錯誤的修改,在重新編譯前,先運行make distclean命令,對先前編譯生成的文件進行徹底的清除。

成功編譯后,會生成3種不同的映像格式,分別是:u-boot:。bin(二進制格式),u-boot(ELF格式)和u-boot.srec(S—Record格式),根據(jù)加載器的不同,選擇合適的格式燒寫到FLASH中進行運行調(diào)試。在此選擇u-boot.bin,直接按照二進制格式下載。

最有效的調(diào)試方法是下載映像到FLASH,使用硬件仿真器進行跟蹤調(diào)試。但是由于硬件仿真器價格高等客觀因素,采用軟件跟蹤的方法,利用目標板上的LED燈做出判斷。一旦可以打印串口信息,就可以利用串口,將調(diào)試信息輸出到屏幕上。

5 結(jié) 語

U-Boot是一個功能強大的:Bootloader開發(fā)軟件,對多種開發(fā)板的支持使得它可以方便地移植到目標板上。首先詳細分析U-Boot啟動流程,然后詳細介紹U-Boot在PXA255目標板上移植的全過程。目前U-Boot已經(jīng)在目標板上穩(wěn)定的運行,為Linux內(nèi)核的移植打下了堅實的基礎。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19896

    瀏覽量

    235265
  • 存儲器
    +關注

    關注

    38

    文章

    7653

    瀏覽量

    167414
  • 操作系統(tǒng)

    關注

    37

    文章

    7152

    瀏覽量

    125595
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    實現(xiàn)PXA255處理器與CF卡的接口設計

    Intel Xscale PXA255處理器是新一代的嵌入式處理器,基于ARMv5TE體系結(jié)構的微處理器,性價比較高、功耗較低,適合于數(shù)字移
    發(fā)表于 04-08 09:36

    U-Boot在PXA255目標板上移植過程

    的,因此建立一個通用的Bootloader是不可能的,要使Bootloader能在目標板上運行,必須做出相應的修改。1目標板目標板采用Intel PXA255處理器,頻率最高可達400 MHz,配置了
    發(fā)表于 06-20 06:38

    如何在Intel XScale PXA255上構建嵌入式Linux應用平臺

    的多媒體手提設備和無線設備越來越受到市場的歡迎,Intel XScale PXA255處理器正是針對這一情況推出的。它采用Intel XScale微結(jié)構體系框架,采用ARMV5TE的7
    發(fā)表于 07-17 08:11

    如何利用PXA255處理器的Sitsang開發(fā)平臺實現(xiàn)紅外模塊的設計?

    本文將詳細講解基于Inte1的PXA255處理器的Sitsang開發(fā)平臺紅外模塊的設計,其中包括Linux下的IrDA驅(qū)動程序的開發(fā)和基于MC68HC908AP64紅外發(fā)射的軟硬件設計兩個部分。
    發(fā)表于 04-27 06:03

    PXA255在CCD圖像采集中的應用

    介紹了Intel 公司的PXA255 處理器的特點及內(nèi)部結(jié)構,并討論了在移動測試領域的具體應用,介紹了基于PXA255 的CCD 圖像的采集,壓縮編碼和傳輸?shù)睦碚?/div>
    發(fā)表于 07-10 15:09 ?21次下載

    應用處理器PXA255上的嵌入式Linux系統(tǒng)開發(fā)

    介紹了Intel公司新近推出的一種嵌入式應用處理器——Plx舵55,研究了PXA255的開發(fā)平臺DBPXA255,著重闡述了如何在基于嵌入式應用處理
    發(fā)表于 11-06 15:10 ?9次下載

    基于PXA255的GPRS圖像傳輸系統(tǒng)設計

    提出了一種基于Intel PXA255 嵌入式微處理器和MC55 無線通訊模塊的圖像采集、壓縮與傳輸?shù)脑O計方案。在PXA255 的平臺上,通過選擇適合的芯片、無線傳輸模塊并利用MPEG
    發(fā)表于 12-29 23:55 ?51次下載

    基于PXA255的嵌入式智能減振系統(tǒng)設計

    以一懸臂梁為例,介紹了一個基于Intel PXA255處理器的嵌入式智能減振系統(tǒng)的硬件與軟件的設計與實現(xiàn),Windows CE操作系統(tǒng)的移植。該系統(tǒng)性能好、功耗低、重量輕,而且可
    發(fā)表于 07-27 15:11 ?25次下載

    PXA255上的嵌入式Linux應用平臺

    PXA255上的嵌入式Linux應用平臺 PXA255IntelPXA250后的第二代XScale處理器,也是一款高檔的
    發(fā)表于 06-25 08:15 ?1183次閱讀

    基于Intel PXA250處理器工作狀態(tài)的功耗仿真模型及分

    基于Intel PXA250處理器工作狀態(tài)的功耗仿真模型及分析 設計了一個基于Intel PXA
    發(fā)表于 08-31 11:34 ?866次閱讀

    Intel Xscale PXA255嵌入式處理器與CF卡的

    Intel Xscale PXA255嵌入式處理器與CF卡的硬件接口設計 以導航設備存儲系統(tǒng)應用為例,本文討論了Intel Xscale PXA2
    發(fā)表于 09-26 17:39 ?1042次閱讀
    <b class='flag-5'>Intel</b> Xscale <b class='flag-5'>PXA255</b>嵌入式<b class='flag-5'>處理器</b>與CF卡的

    PXA255處理器與CF卡的接口設計

    以導航設備存儲系統(tǒng)應用為例,本文討論了Intel Xscale PXA255 嵌入式處理器與 CF卡 的硬件接口設計,并以讀寫CF卡扇區(qū)的程序為例,給出了CF卡軟件編寫的技巧。該設計為基于PX
    發(fā)表于 06-01 15:27 ?29次下載
    <b class='flag-5'>PXA255</b><b class='flag-5'>處理器</b>與CF卡的接口設計

    基于PXA255的自動聚焦及圖像采集模塊設計

    本文介紹了一種基于Intel公司 PXA255嵌入式處理器的自動聚焦圖像采集系統(tǒng)。
    發(fā)表于 09-26 12:02 ?1979次閱讀
    基于<b class='flag-5'>PXA255</b>的自動聚焦及圖像采集模塊設計

    PXA255處理器在WinCE系統(tǒng)下的BootLoader的設計與實現(xiàn)

    PXA255處理器在WinCE系統(tǒng)下的BootLoader的設計與實現(xiàn)
    發(fā)表于 10-25 10:04 ?4次下載
    <b class='flag-5'>PXA255</b><b class='flag-5'>處理器</b>在WinCE系統(tǒng)下的BootLoader的設計與實現(xiàn)

    探究PXA255的VoIP語音傳輸系統(tǒng)

    摘要:文章研究IP語音傳輸系統(tǒng)的總體架構,實現(xiàn)了一個基于PXA255處理器的嵌入式IP電話終端硬件平臺,為該平臺建立
    的頭像 發(fā)表于 04-23 15:23 ?2405次閱讀
    探究<b class='flag-5'>PXA255</b>的VoIP語音傳輸系統(tǒng)