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

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

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

u-boot和bootloader的內(nèi)容以及區(qū)別

硬件筆記本 ? 來源:硬件筆記本 ? 作者:硬件筆記本 ? 2022-07-03 15:27 ? 次閱讀

嵌入式軟件工程師聽說過 u-boot 和 bootloader,但很多工程師依然不知道他們到底是啥。

今天就來簡(jiǎn)單講講 u-boot 和 bootloader 的內(nèi)容以及區(qū)別。

Bootloader

比Bootloader從字面上來看就是啟動(dòng)加載的意思。用過電腦的都知道,windows開機(jī)時(shí)會(huì)首先加載bios,然后是系統(tǒng)內(nèi)核,最后啟動(dòng)完畢。那么bootloader就相當(dāng)于手機(jī)的bios,它在手機(jī)啟動(dòng)的時(shí)候根據(jù)基帶初始化硬件,然后引導(dǎo)系統(tǒng)內(nèi)核,直到系統(tǒng)啟動(dòng)。

Bootloader是嵌入式系統(tǒng)在加電后執(zhí)行的第一段代碼,通過這段小程序,進(jìn)行硬件初始化,獲取內(nèi)存大小信息等,調(diào)整手機(jī)到適配狀態(tài)。在它完成CPU和相關(guān)硬件的初始化之后,再將操作系統(tǒng)映像或固化的嵌入式應(yīng)用程序裝在到內(nèi)存中然后跳轉(zhuǎn)到操作系統(tǒng)所在的空間,啟動(dòng)操作系統(tǒng)運(yùn)行 。

對(duì)于嵌入式系統(tǒng),Bootloader是基于特定硬件平臺(tái)來實(shí)現(xiàn)的。因此,幾乎不可能為所有的嵌入式系統(tǒng)建立一個(gè)通用的Bootloader,不同的處理器架構(gòu)都有不同的Bootloader。Bootloader不但依賴于CPU的體系結(jié)構(gòu),而且依賴于嵌入式系統(tǒng)板級(jí)設(shè)備的配置。對(duì)于2塊不同的嵌入式板而言,即使它們使用同一種處理器,要想讓運(yùn)行在一塊板子上的Bootloader程序也能運(yùn)行在另一塊板子上,一般也都需要修改Bootloader的源程序 。

反過來,大部分Bootloader仍然具有很多共性,某些Bootloader也能夠支持多種體系結(jié)構(gòu)的嵌入式系統(tǒng)。例如,U-Boot就同時(shí)支持PowerPC、ARM、MIPS和X86等體系結(jié)構(gòu),支持的板子有上百種。通常,它們都能夠自動(dòng)從存儲(chǔ)介質(zhì)上啟動(dòng),都能夠引導(dǎo)操作系統(tǒng)啟動(dòng),并且大部分都可以支持串口和以太網(wǎng)接口。

uboot

1.硬件管理uboot要能夠進(jìn)行Soc級(jí)(Soc內(nèi)部外設(shè))和板級(jí)(Soc外部外設(shè))硬件管理。

uboot中實(shí)現(xiàn)了一部分硬件的控制能力(uboot中初始化了一部分硬件),因?yàn)閡boot為了完成一些任務(wù)必須讓這些硬件工作。譬如uboot要實(shí)現(xiàn)刷機(jī)必須能驅(qū)動(dòng)iNand,譬如uboot要在刷機(jī)時(shí)LCD上顯示進(jìn)度條就必須能驅(qū)動(dòng)LCD,譬如uboot能夠通過串口提供操作界面就必須驅(qū)動(dòng)串口。譬如uboot要實(shí)現(xiàn)網(wǎng)絡(luò)功能就必須驅(qū)動(dòng)網(wǎng)卡芯片。

2.能夠完成鏡像燒錄(刷機(jī))uboot要能夠被借助完成刷機(jī)操作。參考下SD卡刷機(jī)的步驟:

a.燒錄uboot到SD卡中。有2種燒寫方法:一種是在windows中用刷卡工具去制作啟動(dòng)SD卡;另一種是在linux中用dd命令。制作完SD后將SD卡插入開發(fā)板,然后開機(jī)就可以進(jìn)入uboot界面。

b.使用uboot的fastboot命令,并借助PC中的fastboot軟件完成包括uboot、kernel、rootfs等的鏡像的燒錄。從上面就可以看出,刷機(jī)依靠的是uboot的fastboot命令,將鏡像寫到相應(yīng)的FLASH中。

3.uboot的“生命周期”uboot的入口就是開機(jī)自動(dòng)啟動(dòng),uboot的唯一出口就是啟動(dòng)內(nèi)核。uboot還可以執(zhí)行很多別的任務(wù)(譬如燒錄系統(tǒng)),但是其他任務(wù)執(zhí)行完后都可以回到uboot的命令行繼續(xù)執(zhí)行uboot命令,而啟動(dòng)內(nèi)核命令一旦執(zhí)行就回不來了。

4.uboot要提供命令式shell界面shell是用戶操作接口的意思。shell有命令行的shell,如windows下的cmd,如linux下的終端;也有GUI式的shell,比如常用的windows下的各種界面。shell是一種封裝后留出來的接口,uboot也要有這樣的一個(gè)接口。

shell的原理是:由消息接收、解析、執(zhí)行構(gòu)成的一個(gè)死循環(huán)。我之前用過3D打印機(jī)的固件(firmware)也是這樣的模式。

uboot的shell使用的也是行緩沖的模式。也就是以回車鍵(換行鍵)作為一個(gè)命令輸入的結(jié)束。對(duì)應(yīng)的其他緩沖模式還有無緩沖和全緩沖:無緩沖就是輸入一個(gè)字符就當(dāng)做一個(gè)命令處理;全緩沖就是無論輸入什么都緩沖起來知道緩沖區(qū)滿了才做一次處理。

bootloader 與 uboot的區(qū)別

BootLoader是嵌入式設(shè)備中用來啟動(dòng)操作系統(tǒng)內(nèi)核的一段程序。

uboot(universal bootloader)是一種可以用于多種嵌入式CPU的BootLoader程序,換言之,uboot是bootloader的一個(gè)子集。

uboot的核心作用就是啟動(dòng)操作系統(tǒng)內(nèi)核,uboot的本質(zhì)就是一段裸機(jī)程序。

原文標(biāo)題:嵌入式基礎(chǔ)之u-boot和bootloader

文章出處:【微信公眾號(hào):硬件筆記本】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

審核編輯:湯梓紅

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

    關(guān)注

    5046

    文章

    18817

    瀏覽量

    298568
  • u-boot
    +關(guān)注

    關(guān)注

    0

    文章

    119

    瀏覽量

    38136
  • bootloader
    +關(guān)注

    關(guān)注

    2

    文章

    232

    瀏覽量

    45368

原文標(biāo)題:嵌入式基礎(chǔ)之u-boot和bootloader

文章出處:【微信號(hào):gh_a6560e9c41d7,微信公眾號(hào):硬件筆記本】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    zynq7000 BSP無法在u-boot加載運(yùn)行,為什么?

    1、硬件配置zynq7000 zedboard 2、下載git,回退到支持zynq7000 的bsp包 3、采用xilinx sdk工具可以運(yùn)行thread-zynq7000.elf 4、采用u-boot tftp下載到板子thread-zynq7000.elf, 執(zhí)行g(shù)o 0x100000后無打印。
    發(fā)表于 09-13 07:06

    飛凌全志T527開發(fā)板U-Boot添加自定義菜單

    有趣的是,板子上電,按任意鍵進(jìn)入U-Boot會(huì)自動(dòng)列出一個(gè)功能菜單,有切換屏幕等功能: 基于此,本文將分析如何在U-Boot添加自定義菜單。 一、實(shí)驗(yàn)環(huán)境介紹 硬件:飛凌OK-T527開發(fā)板
    發(fā)表于 07-15 09:42

    STM32MP157 u-boot能加速嗎?

    芯片啟動(dòng),能加速嗎,目前速度有點(diǎn)慢,啟動(dòng)首先打印了一些信息,到U-BOOT啟動(dòng),中間有2-3秒時(shí)間,能否加速呢 NOTICE:Model: STMicroelectronics
    發(fā)表于 05-31 06:36

    stm32u545 spi帶boot的和不帶boot的有什么區(qū)別

    stm32u545 spi帶boot的和不帶boot的有什么區(qū)別?
    發(fā)表于 05-23 07:08

    STM32MP135移植U-Boot 2022.10-stm32mp-r1提示No serial driver found的原因?

    STM32MP135移植U-Boot 2022.10-stm32mp-r1提示No serial driver found
    發(fā)表于 03-11 08:13

    【米爾-TIAM62開發(fā)板-接替335x-試用評(píng)測(cè)】+(五)手把手玩轉(zhuǎn)U-Boot控制CPU管腳

    接上四篇: 【米爾-TIAM62開發(fā)板-接替335x-試用評(píng)測(cè)】+(一)手把手配置Yocto 【米爾-TIAM62開發(fā)板-接替335x-試用評(píng)測(cè)】+(二)配置U-Boot步驟實(shí)戰(zhàn) 【米爾
    發(fā)表于 01-08 10:02

    u-boot對(duì)系統(tǒng)寄存器進(jìn)行初始化代碼

    在完成地址無關(guān)fixup后,u-boot開始對(duì)一些系統(tǒng)寄存器進(jìn)行初始化。 第一段代碼如下: pie_fixup_done: #endif #ifdef CONFIG_SYS_RESET_SCTRL
    的頭像 發(fā)表于 12-07 11:34 ?624次閱讀

    u-boot在匯編啟動(dòng)階段的相關(guān)操作介紹

    u-boot在匯編啟動(dòng)階段對(duì)系統(tǒng)的一些初始化 當(dāng)cpu交由u-boot接管進(jìn)入u-boot后, 首先會(huì)到_start符號(hào)處開始執(zhí)行初始化, 并在此期間完成一些必要的系統(tǒng)寄存器相關(guān)的初始化,包括保存
    的頭像 發(fā)表于 12-07 11:22 ?414次閱讀

    u-boot armv8鏈接腳本

    u-boot armv8鏈接腳本 在進(jìn)行源碼分析之前,首先看看u-boot的鏈接腳本,通過鏈接腳本可以從整體了解一個(gè)u-boot的組成,并且可以在啟動(dòng)分析中知道某些邏輯是在完成什么工作。 在
    的頭像 發(fā)表于 12-07 11:19 ?451次閱讀

    u-boot源碼的編譯配置方式

    u-boot使用了同Linux一樣的編譯配置方式,即使用kbuild系統(tǒng)來管理整體代碼的配置和編譯,通過defconfig來定制各種不同廠商的芯片bootloader二進(jìn)制程序。 編譯只需要注意通過
    的頭像 發(fā)表于 12-07 11:12 ?726次閱讀

    uboot命令的執(zhí)行過程是什么

    U-boot是通過執(zhí)行u-boot提供的命令來加載Linux內(nèi)核的,其中 命令bootm的功能 即為從memory啟動(dòng)Linux內(nèi)核映像文件。 在講解bootm加載內(nèi)核之前,先來看看u-boot
    的頭像 發(fā)表于 12-04 17:31 ?590次閱讀

    【米爾-TIAM62開發(fā)板-接替335x-試用評(píng)測(cè)】+(二)配置U-Boot步驟實(shí)戰(zhàn)

    啟動(dòng)信息等。創(chuàng)建這個(gè)文件需要深入理解U-Boot的配置選項(xiàng)以及你的硬件環(huán)境。 然后,創(chuàng)建新的板子的頭文件也是重要的一步。這個(gè)頭文件通常包含了一些硬件相關(guān)的宏定義和配置。確保這些配置與你的硬件環(huán)境相符
    發(fā)表于 11-13 12:36

    簡(jiǎn)單講講u-bootbootloader有啥區(qū)別

    搞嵌入式軟件開發(fā),掌握u-bootbootloader應(yīng)該是必備的技能之一,但很多工程師依然不知道它們到底是啥。
    的頭像 發(fā)表于 11-09 12:24 ?973次閱讀

    RZ/G2L開發(fā)板使用指南(下)

    首先恭喜你參考‘使用指南-上’方法,已經(jīng)成功燒寫flash_writer到G2L的片上RAM。接下來將介紹如何將bootloaderU-boot燒寫到QSPI或EMMC,以及如何制作SD卡鏡像并啟動(dòng)系統(tǒng)。
    的頭像 發(fā)表于 11-03 12:20 ?977次閱讀
    RZ/G2L開發(fā)板使用指南(下)

    STM32F09x不使用BOOT腳實(shí)現(xiàn)System Bootloader升級(jí)代碼

    電子發(fā)燒友網(wǎng)站提供《STM32F09x不使用BOOT腳實(shí)現(xiàn)System Bootloader升級(jí)代碼.pdf》資料免費(fèi)下載
    發(fā)表于 09-25 15:08 ?2次下載
    STM32F09x不使用<b class='flag-5'>BOOT</b>腳實(shí)現(xiàn)System <b class='flag-5'>Bootloader</b>升級(jí)代碼