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

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

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

嵌入式系統(tǒng)里的Boot Loader技術(shù)詳解

開源嵌入式 ? 來源:搜狐網(wǎng) ? 作者:搜狐網(wǎng) ? 2020-09-27 18:08 ? 次閱讀

嵌入式系統(tǒng)當中你可能經(jīng)常聽到 boot loader(引導加載器)這一詞,boot loader是指什么呢?在我們?nèi)粘=?jīng)常接觸的東西中是不是有與boot loader的作用或是概念相似的呢?如果你稍微熟悉計算機的組成,你一定知道BIOS(Basic Input/Output System)。BIOS在計算機中就是用來啟動計算系統(tǒng)的,在完成一定的硬件初始化工作以及人機交互后,它加載位于硬盤中的操作系統(tǒng),并最終運行操作系統(tǒng)。嵌入式系統(tǒng)中的boot loader與BIOS的作用就是相類似的,也是完成對于處理器相關(guān)的硬件資源進行初始化后,最后加載通常是存放在FLASH中的應(yīng)用程序,當然在嵌入式系統(tǒng)當中操作系統(tǒng)與應(yīng)用程序一般是在同一個可執(zhí)行文件中的,這與我們的電腦有很大的不同。
BIOS與boot loader有相同之處,比如:
1)完成處理器正常最小系統(tǒng)的初始化。最小系統(tǒng)的概念通過舉個例比較容易讓人明白,比如對于我們的計算機,通常在初始化時不需要用到以太網(wǎng),因此,在最小化系統(tǒng)中就不包括以太網(wǎng)卡的初始化,對其的初始化完全可以放到操作系統(tǒng)中去做,而不是在BIOS中。相類似的是,在嵌入式系統(tǒng)中,我們通常不需要在初始化的過程中用到USB設(shè)備,那么對于USB設(shè)備的初始化就不需要包含在最小系統(tǒng)中,而可以在被boot loader加載的應(yīng)用程序中去初始化它。

2)兩者在最后都得加載其它的程序,并將運行權(quán)交給被加載的程序。對于BIOS,其所加載的程序通常是操作系統(tǒng),當然,如果你正在安裝系統(tǒng)那么BIOS所加載的可能是位于光盤中安裝程序。對于loader,其加載的是一個可執(zhí)行程序,這一可執(zhí)行程序包括實時操作系統(tǒng)(有的也不是實時操作系統(tǒng))和我們的應(yīng)用程序。

3)如果BIOS或是boot loader程序太大,通常都會采用壓縮技術(shù)對其進行壓縮。對于BIOS,其肯定會采用壓縮技術(shù)進行壓縮,因為BIOS隨著計算機行業(yè)的飛速發(fā)展而越來越復(fù)雜,比如,以前的BIOS不需要支持USB的鼠標和鍵盤,但現(xiàn)在就得支持了,這就意味著BIOS要有USB鼠標和鍵盤的驅(qū)動程序。另一方面計算機的出貨量大,所以BIOS芯片(其實就是一塊FLASH芯片)的容量也就會盡可能的控制得小以提高利潤,比如可能控制其容量在512K字節(jié)。同BIOS相類似的是,如果我們的嵌入式系統(tǒng)中的FLASH緊張時,為了節(jié)省FLASH空間,我們也得對boot loader采用壓縮技術(shù)。可能有人要問,BIOS也好,boot loader也好,如果采用了壓縮技術(shù)對其壓縮,那是誰負責在運行它們時對其解壓縮呢?答案是它們自己,很有趣吧!其實,我們說對它們采用壓縮技術(shù)并不是對于全部的程序(或數(shù)據(jù))都采用壓縮技術(shù)。在它們當中,一定存在一部分不壓縮的部分,這保證處理器啟動時,能直接運行這部分的代碼。技巧在于,沒有壓縮的代碼當中包括了解壓程序(從C程序角度來看是幾個函數(shù)),其將被壓縮了的部分解壓到內(nèi)存中。當然,其中的程序處理很有技巧性,要保證程序在運行的過程中,對于壓縮部分代碼的運行是透明的,這在具體的代碼分析中我們再來看。
BIOS與boot loader除了相同之處外,還有不同之處,它們是:

1)BIOS往往比boot loader復(fù)雜很多,因為我們的計算機硬件環(huán)境比嵌入式系統(tǒng)復(fù)雜得多。在計算機行業(yè),為了保證操作系統(tǒng)在設(shè)計時盡可能運行在不同的主板上,這需要BIOS的幫助以屏蔽一些硬件信息。操作系統(tǒng)對主板上的一些硬件資源的訪問,需要通過BIOS來完成,即調(diào)用BIOS的功能(或說是函數(shù))來完成。這樣做的好處是非常的明顯的,操作系統(tǒng)的開發(fā)商不用關(guān)心主板上的具體硬件是如何設(shè)計的,而主板的設(shè)計廠商則負責實現(xiàn)BIOS來對主板上的硬件資源進行存取訪問??偟膩碚f,就是將主板上對于復(fù)雜硬件資源的處理任務(wù)交給了主板廠商來完成,而不用操作系統(tǒng)廠商去關(guān)心,因當說這樣做非常的合理和有效。
2)BIOS在加載完了操作系統(tǒng)以后,其還將駐留在內(nèi)存中,以便操作系統(tǒng)在運行的過程中調(diào)用其功能,但boot loader就不需要這樣了。通常,boot loader加載完了程序后,跳轉(zhuǎn)到被加載的程序后就不再存在了,這里所說的跳轉(zhuǎn)有時也稱之為將運行權(quán)交給了被加載程序。
3)boot loader通常采用匯編和C程序相結(jié)合進行編寫,但BIOS為了節(jié)省程序空間往往全部采用匯編進行編寫。
下面我們來看一看boot loader在啟動過程中會做哪些事情。在討論這些之前,我們需要明白嵌入式系統(tǒng)的處理器與我們計算機處理器的區(qū)別是什么。對于嵌入式系統(tǒng)的處理器,準確的說應(yīng)當叫微控制器,即英文的microcontroller,而我們的計算機處理器則應(yīng)稱之為微處理器,即microprocessor。微控制器除了具有微處理器的功能外(即通過運算來處理一定的事務(wù)),往往其中集成了很多的其它硬件功能模塊,比如SDRAM內(nèi)存控制器、I2C控制器、SD卡控制器等等。正如微處理器的名字那樣,它只有處理功能,其它的控制芯片都是通過芯片組(什么是芯片組,我打算后面用另一篇文章來進行解釋)來完成的。雖然,我們對于微處理器和微控制器采用了處理器這么一個簡化詞來描述,但我們需要明白其中的不同之處,這一點非常的重要。下面我們來看一看boot loader做些什么事情,它們有:
1)對PLL時鐘進行初始化。往往處理器一啟動時,為了更好的設(shè)備兼容性,其工作頻率都很低,在boot loader程序的特定位置,需要提高處理器的時鐘頻率,以加快運行速度。速度一旦調(diào)好往往是不會改變的了,之所以說是往往,因為如果處理器支持節(jié)電模式功能,那也會造成PLL時鐘的變化(時鐘越快越耗電)。
2)初始化SDRAM內(nèi)存控制器。通常loader自身也需要用到內(nèi)存,比如,大多boot loader都會將自己加載到內(nèi)存中。內(nèi)存的配置一般是包括行地址和列地址的配置以及自動刷新頻率的配置。一旦配置好了,后面就不用再更改了。
3)初始化中斷控制器和中斷服務(wù)程序。

4)初始化各地址空間的片選地址寄存器和讀寫時序。
5)初始化堆棧(stack)寄存器。比如,在x86中需要初始化ESP寄存器,在PowerPC中需要初始化r1寄存器。
6)對于boot loader中需要訪問的其它硬件設(shè)備進行初始化。比如,我們通常會有一個串口作為控制臺(console),這就需要在boot loader中初始化相應(yīng)的串口,并接受用戶的命令,以響應(yīng)用戶的請求??梢韵胂?,boot loader中存在一定的命令處理程序。
7)將boot loader自身加載到內(nèi)存中,如果需要解壓,那么還得做解壓操作。前面提到了,將boot loader加載到內(nèi)存是為了更快的運行程序。

8)加載需要運行的應(yīng)用程序并最終運行被加載的應(yīng)用程序。

需要指出的是,在嵌入式系統(tǒng)中我們的應(yīng)用程序當中還得做一部分與boot loader相同的工作。比如,對于中斷服務(wù)程序的重新初始化,因為在boot loader中設(shè)置的是boot loader中的程序作為中斷服務(wù)程序,當應(yīng)用程序加載了以后,boot loader中的程序就不復(fù)存在了,因此,我們需要重新初始化中斷服務(wù)程序以指向被加載程序中的函數(shù)。對于SDRAM內(nèi)存的初始化、PLL的初始化,在應(yīng)用程序中通常不需要重新做。雖然,在此我們沒有對具體的處理器和操作系統(tǒng)進行講解,但是無論對于什么處理器和操作系統(tǒng),其總體過程幾乎相同,只是處理器的指令集不同。最后,我要給讀者您留一個問題,這個問題如下。

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

    關(guān)注

    41

    文章

    3532

    瀏覽量

    128989
  • bootloader
    +關(guān)注

    關(guān)注

    2

    文章

    233

    瀏覽量

    45467

原文標題:開發(fā)嵌入式必須懂的技術(shù)-Boot Loader詳細介紹

文章出處:【微信號:KY_QRS,微信公眾號:開源嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    什么是嵌入式?一文讀懂嵌入式主板

    在現(xiàn)代科技浪潮中,嵌入式技術(shù)已成為支撐各種智能設(shè)備和系統(tǒng)運行的核心力量。那么,究竟什么是嵌入式?嵌入式
    的頭像 發(fā)表于 10-16 10:14 ?204次閱讀

    嵌入式系統(tǒng)的未來趨勢有哪些?

    (ML)技術(shù)的快速發(fā)展,嵌入式系統(tǒng)將更多地整合這些先進技術(shù),以支持智能決策和自動化。在設(shè)備上直接運行AI和ML模型,進行圖像識別、自然語言處理、預(yù)測分析等任務(wù),將極大提升
    發(fā)表于 09-12 15:42

    RT-Thread出席第六屆中國嵌入式技術(shù)大會,共話嵌入式操作系統(tǒng)與智能工業(yè)

    第六屆中國嵌入式技術(shù)大會將于8月27-28日在深圳會展中心(福田)1號館舉行。本屆大會以“AI與開源,開啟嵌入式系統(tǒng)智能新時代”為主題,聚焦人工智能與
    的頭像 發(fā)表于 08-03 08:35 ?307次閱讀
    RT-Thread出席第六屆中國<b class='flag-5'>嵌入式</b><b class='flag-5'>技術(shù)</b>大會,共話<b class='flag-5'>嵌入式</b>操作<b class='flag-5'>系統(tǒng)</b>與智能工業(yè)

    嵌入式系統(tǒng)怎么學?

    嵌入式系統(tǒng)怎么學? 隨著物聯(lián)網(wǎng)、智能制造等新技術(shù)的興起,嵌入式系統(tǒng)的應(yīng)用范圍更加廣泛。包括但不限于工業(yè)控制、汽車電子、醫(yī)療設(shè)備、智能家居、
    發(fā)表于 07-02 10:10

    深度詳解嵌入式系統(tǒng)專用輕量級框架設(shè)計

    MR 框架是專為嵌入式系統(tǒng)設(shè)計的輕量級框架。充分考慮了嵌入式系統(tǒng)在資源和性能方面的需求。通過提供標準化的設(shè)備管理接口,極大簡化了嵌入式應(yīng)用開
    發(fā)表于 04-27 02:32 ?836次閱讀
    深度<b class='flag-5'>詳解</b><b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>專用輕量級框架設(shè)計

    嵌入式fpga是什么意思

    嵌入式FPGA是指將FPGA技術(shù)集成到嵌入式系統(tǒng)中的一種解決方案。嵌入式系統(tǒng)是一種為特定應(yīng)用而設(shè)
    的頭像 發(fā)表于 03-15 14:29 ?1121次閱讀

    fpga是嵌入式

    FPGA(現(xiàn)場可編程門陣列)不是嵌入式系統(tǒng),但FPGA在嵌入式系統(tǒng)中有著重要的應(yīng)用。
    的頭像 發(fā)表于 03-14 17:19 ?2011次閱讀

    嵌入式工程師需要掌握哪些技術(shù)?

    嵌入式工程師需要掌握哪些技術(shù)? 嵌入式系統(tǒng)是當今科技領(lǐng)域中的重要組成部分,它們存在于我們生活的方方面面,從智能手機到汽車控制系統(tǒng),從家電到
    發(fā)表于 03-04 16:38

    嵌入式系統(tǒng)發(fā)展前景?

    應(yīng)用領(lǐng)域。隨著汽車電子化和智能化程度的不斷提高,嵌入式系統(tǒng)將在汽車控制、安全系統(tǒng)、自動駕駛等方面發(fā)揮更為重要的作用。 工智能和機器學習技術(shù)的發(fā)展為
    發(fā)表于 02-22 14:09

    嵌入式系統(tǒng)的應(yīng)用實例

    嵌入式系統(tǒng)的三個基本要素是嵌入性、專用性與計算機系統(tǒng)。
    的頭像 發(fā)表于 01-22 09:57 ?945次閱讀

    什么是嵌入式系統(tǒng)嵌入式系統(tǒng)的具體應(yīng)用

    嵌入式,一般是指嵌入式系統(tǒng)。用于控制、監(jiān)視或者輔助操作機器和設(shè)備的裝置。
    的頭像 發(fā)表于 12-20 13:33 ?2275次閱讀

    嵌入式系統(tǒng)原理與設(shè)計

    電子發(fā)燒友網(wǎng)站提供《嵌入式系統(tǒng)原理與設(shè)計.zip》資料免費下載
    發(fā)表于 11-17 14:10 ?0次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>原理與設(shè)計

    嵌入式系統(tǒng)的定義與發(fā)展歷史簡述

    簡介:嵌入式系統(tǒng)誕生于微型機時代,經(jīng)歷了漫長的獨立發(fā)展的單片機道路。給嵌入式系統(tǒng)尋求科學的定義,必須了解嵌入式
    發(fā)表于 11-09 08:31 ?0次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>的定義與發(fā)展歷史簡述

    基于嵌入式技術(shù)的網(wǎng)絡(luò)開票系統(tǒng)的設(shè)計方法

    電子發(fā)燒友網(wǎng)站提供《基于嵌入式技術(shù)的網(wǎng)絡(luò)開票系統(tǒng)的設(shè)計方法.pdf》資料免費下載
    發(fā)表于 11-06 10:18 ?0次下載
    基于<b class='flag-5'>嵌入式</b><b class='flag-5'>技術(shù)</b>的網(wǎng)絡(luò)開票<b class='flag-5'>系統(tǒng)</b>的設(shè)計方法

    嵌入式Linux學習-BIOS和Boot loader詳解筆記

    為桌面計算機擁電后,一種叫作BIOS的軟件系統(tǒng)會立即接管對系統(tǒng)處理器的控制.
    的頭像 發(fā)表于 10-27 14:20 ?1526次閱讀
    <b class='flag-5'>嵌入式</b>Linux學習-BIOS和<b class='flag-5'>Boot</b> <b class='flag-5'>loader</b><b class='flag-5'>詳解</b>筆記