日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導讀]BLOB啟動流程與Bootloader程序可移植性研究

在嵌入式系統(tǒng)應用中,通過引導程序(Bootloader)可以初始化硬件設備、建立內存空間的映射圖、加載內核,從而將系統(tǒng)的軟硬件環(huán)境帶到一個合適的狀態(tài),以便為最終調用操作系統(tǒng)內核準備好正確的環(huán)境[1]。Bootloader依賴于實際的硬件和應用環(huán)境,對于不同的硬件架構以及相同架構的不同電路板,都需要不同的Bootloader。由于單獨開發(fā)Bootloader的工作量較大,因此開發(fā)人員一般針對固定體系構架開發(fā)一種可移植性的Bootloader,使之能夠在少量修改后應用于同一體系構架的其他電路板。BLOB就是一種針對ARM體系定制的可移植性良好的嵌入式Linux引導程序。BLOB支持多種CPU,包括SA1100、SA1110、PXA255、PXA270等,用戶可以根據(jù)目標板的特性進行定制。它能實現(xiàn)以下功能:
  (1)引導嵌入式Linux,它可以把Linux、Kernel等從Flash加載到RAM中執(zhí)行;
 

  (2)命令行下在線更新BLOB、Kernel和ramdisk;

  (3)命令行下可以直接對物理尋址空間進行查看和修改。

  可見BLOB除了引導系統(tǒng)這個基本功能外,還具備板級支持包(BSP)開發(fā)的功能。

  1 啟動流程分析

  系統(tǒng)的啟動通常有兩種方式,一種是可以直接Flash 啟動,另一種是可以將壓縮的內存映像文件從Flash中復制、解壓到RAM,再從RAM啟動。系統(tǒng)上電時,BLOB采用后者,啟動過程分兩個階段進行,其中第一階段在Flash中運行,第二階段在RAM中運行。圖1為BLOB啟動流程圖。

  

 

  1.1 第一階段

  第一階段為從系統(tǒng)上電后在0x00000000 地址開始執(zhí)行的部分。這部分代碼運行在Flash中,其目的是為第二階段(stage 2)的執(zhí)行以及隨后的Kernel的執(zhí)行準備好基本的硬件環(huán)境[2]。

  (1)屏蔽所有的中斷

  為中斷提供服務通常是OS設備驅動程序的責任,因此在Bootloader的執(zhí)行全過程中不必響應任何中斷。中斷屏蔽可以通過寫CPU的中斷屏蔽寄存器或狀態(tài)寄存器(如ARM的CPSR寄存器)來完成。

  (2)設置CPU的速度和時鐘頻率

  (3)RAM初始化

  包括正確地設置系統(tǒng)內存控制器的功能寄存器以及各內存庫控制寄存器等。

  (4)LED初始化

  通過GPIO來驅動LED,其目的是表明系統(tǒng)的狀態(tài)是否正常。如果板子上沒有LED,則可以通過初始化UART向串口打印 Bootloader的Logo字符信息來完成。

  1.2 第二階段

  第二階段是C語言執(zhí)行代碼,具體說明如下。

  (1)UART設置及初始化

  至少初始化一個串口,以便與終端用戶進行 I/O 輸出信息,初始化計時器等。設備初始化完成后,可以輸出一些打印信息、程序名字字符串、版本號等。

  (2)設置系統(tǒng)的內存映射

  內存映射是指在整個物理地址空間中有哪些地址被分配用來尋址系統(tǒng)的RAM單元。具體的嵌入式系統(tǒng)往往只把CPU預留的全部RAM地址空間中的一部分映射到RAM單元上,而讓剩下的部分預留RAM地址空間處于未使用狀態(tài)。因此Bootloader的 stage 2必須在使用它之前檢測整個系統(tǒng)的內存映射情況。在用上述算法檢測完系統(tǒng)的內存映射情況后,BLOB將內存映射的詳細信息打印到串口。

  (3)加載內核映像和根文件系統(tǒng)映像

  在規(guī)劃內存占用的布局時,應包括兩個方面:內核映像所占用的內存范圍;根文件系統(tǒng)所占用的內存范圍。在規(guī)劃內存占用布局時,主要考慮基地址和映像的大小兩個方面。

  對于內核映像,一般將其拷貝到從(MEM_START+0x8000)這個基地址開始的大約1MB大小的內存范圍內(嵌入式Linux的內核一般都不超過1MB)。

  而對于根文件系統(tǒng)映像,則一般將其拷貝到 MEM_START+0x0010,0000開始的地方。如果用Ramdisk作為根文件系統(tǒng)映像,則其解壓后的大小一般是1MB。

  (4)設置Linux內核的啟動參數(shù)。

  (5)可以選擇直接調用內核或者進入下載模式。

  在下載模式下,BLOB將通過串口從主機(Host)下載文件,例如下載內核映像和根文件系統(tǒng)映像等。[!--empirenews.page--]2 Bootloader的可移植性研究

 

  大部分Bootloader的總體結構與BLOB類似,一般分為兩個階段運行。其中第一階段與CPU架構相關,不同架構CPU往往要求不同的Bootloader與之對應[3],只有少數(shù)Bootloader能夠適用于多種架構的CPU,如表1。

  

 

  2.1 相同構架下Bootloader移植

  對于相同的CPU構架,Bootloader移植工作大體上可以分為三部分。

  (1)目標板驅動部分,針對特定CPU、Flash、SDRAM等對驅動程序進行定制。完成處理器各個I/O口的初始化、Flash描述(包括區(qū)塊大小及數(shù)量)和Flash初始化等。一個必要的工作是Flash分區(qū)表的配置,F(xiàn)lash的典型空間分配結構如圖2所示。

  

 

  (2)目標板相關的頭文件,文件中包含了目標板配置的宏定義,主要有系統(tǒng)工作頻率、GPIO定義、Flash 各分塊起始地址及容量、Flash 讀/寫命令字、SDRAM寄存器配置、SDRAM起始地址及容量、內核裝載地址等。其中大部分GPIO設置的目的是在Bootloader下做板載開發(fā),這項功能不是必需的。而CPU頻率及Flash的設置則直接影響到系統(tǒng)能否啟動。對于采用Ramdisk技術的系統(tǒng)開發(fā),SDRAM的配置也直接關系到Kernel的加載。因此,各頭文件的代碼修改是移植過程的重點。

  (3)Bootloader總體配置文件修改,包括目標板聲明、指定目標板頭文件、定制文件關聯(lián)關系等。

  圖3以BLOB在PXA255[4]的目標板上移植為例表現(xiàn)了需要增、改的關鍵文件之間的內在聯(lián)系。

  

 

  圖3中:

  (1)src/blob/PXA255.c:筆者編寫的針對PXA255目標板驅動文件,這里是采用默認設置的最簡情況,必要時還需對文件如Flash.c等進行修改。

  (2)include/blob/arch/PXA255.h:目標板頭文件,它必須通過arch.h及config.h進行指定,最終反映在configure.in中。

  (3)configure.in:添加目標板聲明,如果已有目標板類型,則無需修改該文件;如果沒有,則需要根據(jù)情況添加目標板名稱、CPU型號、必需的.o文件,如:

  PXA255)

  AC_MSG_RESULT(Ipaq PXA255)

  AC_DEFINE(PXA255)

  AC_DEFINE(USE_SERIAL3)

  BLOB_PLATFORM_OBJ=″PXA255.o″

  BLOB_FLASH_OBJS=″nullflash.o″

  use_cpu=″PXA255″

  use_lcd=″no″

  (4)Makefile.am:由于添加了PXA255.c和PXA255.h,所以要在它們所在目錄的Makefile.am中進行登記,保證configure.in和Makefile.am在進行./configure處理時能夠生成正確的Makefile文件,最終在執(zhí)行Make命令后生成BLOB的可執(zhí)行文件。

  需要注意的是Linux內核必須根據(jù)目標板硬件情況作相應的設置[5],這里不展開論述。

   [!--empirenews.page--]2.2 不同構架下Bootloader移植

 

  根據(jù)Bootloader的啟動流程可知,對于不同架構的CPU,盡管處理流程相似,但是實現(xiàn)方法不同,主要體現(xiàn)在啟動的第一階段對CPU的設置上。所以這部分的硬件相關代碼基本上要重新編寫。

  多數(shù)Bootloader在stage1的代碼不易由C語言實現(xiàn),因而大多采用匯編語言實現(xiàn)。以U-boot為例,stage1代碼主要位于start.S、IO.S、Cache.S中,其中最重要的是start.S。該代碼主要針對特定處理器,對其內部各個寄存器進行設置并初始化CPU。主要完成設置處理器工作模式、初始化緩沖區(qū)、設置堆棧、設置中斷向量、內存控制器初始化[6]。

  完成stage1代碼編寫之后,還需要按照相同構架下Bootloader移植的方法對相關代碼進行編寫。

  2.3 提高可移植性的方案設計

  目前影響B(tài)ootloader可移植性的因素主要有:CPU不同架構,同一架構不同CPU型號,目標板硬件不同結構。針對以上問題提出了幾點提高可移植性的方案設計。

  (1)對于遵從GPL協(xié)議的開源Bootloader,可以根據(jù)不同架構和不同硬件定制相應的驅動文件,如各種.c和.h文件。考慮到目前嵌入式硬件種類非常多,需要大量開源軟件開發(fā)者的支持,盡管不能覆蓋所有硬件,但在一定范圍內可以大大減少嵌入式系統(tǒng)開發(fā)的工作量。

  (2)在上一步的基礎上,采用類似Linux內核配置的方法(如make menuconfig或make xconfig),用終端式的配置菜單對具體硬件進行設置,減少移植過程中代碼級的修改。

  在實驗過程中實現(xiàn)了BLOB在PXA255目標板及SA1110目標板的移植。此項研究已經應用在清華大學精密測試技術與儀器國家重點實驗室的嵌入式生物特征識別平臺上,可以實現(xiàn)BLOB、內核鏡像、文件系統(tǒng)鏡像的下載及內核的引導。

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

Arm 控股有限公司(納斯達克股票代碼:ARM,以下簡稱 Arm)今日宣布推出全新 Arm? Lumex? 計算子系統(tǒng) (Compute Subsystem, CSS) 平臺,這是一套專為旗艦級智能手機及下一代個人電腦加...

關鍵字: CPU AI 消費電子

Arm 控股有限公司(納斯達克股票代碼:ARM,以下簡稱 Arm)今日宣布推出全新 Arm? Lumex?計算子系統(tǒng) (Compute Subsystem, CSS) 平臺,這是一套專為旗艦級智能手機及下一代個人電腦加速...

關鍵字: 消費電子 CPU AI

8位單片機在嵌入式設計領域已經成為半個多世紀以來的主流選擇。盡管嵌入式系統(tǒng)市場日益復雜,8位單片機依然不斷發(fā)展,積極應對新的挑戰(zhàn)和系統(tǒng)需求。如今,Microchip推出的8位PIC?和AVR?單片機系列,配備了先進的獨立...

關鍵字: 單片機 嵌入式 CPU

上海2025年8月15日 /美通社/ -- 在數(shù)字化轉型浪潮與數(shù)據(jù)安全需求的雙重驅動下,瀾起科技今日重磅推出第六代津逮? 性能核 CPU (以下簡稱 C6P )。這款融合突破性架構、全棧兼容性與芯片級安全防護的高性能服...

關鍵字: CPU BSP 數(shù)字化 AI

采用分離式架構,充分利用主機 CPU 和 PCIe? 基礎設施,克服傳統(tǒng)存儲瓶頸

關鍵字: CPU 數(shù)據(jù)中心 服務器

受生成式 AI 驅動, RISC-V 芯片市場快速發(fā)展。預計到2030年,RISC-V SoC出貨量將達到1618.1億顆,營收將達到927億美元。其中,用于AI加速器的RISC-V SoC出貨量將達到41億顆,營收將達...

關鍵字: RISC-V CPU AI CUDA ARM 推理

7月21日消息,“全球最佳游戲CPU”銳龍7 9800X3D自去年11月上市以來,價格一直比較堅挺,前期還經常處于缺貨狀態(tài)。

關鍵字: CPU GPU

人工智能 (AI) 正在以驚人的速度發(fā)展。企業(yè)不再僅僅是探索 AI,而是積極推動 AI 的規(guī)模化落地,從實驗性應用轉向實際部署。隨著生成式模型日益精簡和高效,AI 的重心正從云端轉向邊緣側。如今,人們不再質疑邊緣 AI...

關鍵字: 人工智能 CPU GPU

CPU通過將代碼轉換為機器語言、通過指令集架構(ISA)識別代碼、以及利用控制單元(CU)和算術邏輯單元(ALU)執(zhí)行代碼這三種主要方式來認識代碼。CPU首先將編寫的高級語言代碼通過編譯器轉換為低級語言,即機器語言,這是...

關鍵字: CPU 機器語言
關閉