chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

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

硬件筆記本 ? 來源:硬件筆記本 ? 作者:硬件筆記本 ? 2022-07-03 15:27 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

Bootloader

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

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

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

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

uboot

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

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

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

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

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

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

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

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

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

bootloader 與 uboot的區(qū)別

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

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

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

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

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

審核編輯:湯梓紅

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

    關(guān)注

    5209

    文章

    20635

    瀏覽量

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

    關(guān)注

    0

    文章

    135

    瀏覽量

    39923
  • bootloader
    +關(guān)注

    關(guān)注

    2

    文章

    245

    瀏覽量

    48286

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    S32G398 u-boot OCOTP 編程保險絲僅在復(fù)位后激活是為什么?

    我需要保險絲編程和驗證(“保險絲程序”和“保險絲 cmp”)方面的幫助。 S32G3 保險絲通過 u-boot 命令行進行編程。要更新保險絲,我需要在 u-boot 中執(zhí)行“重置”。\'fuse
    發(fā)表于 04-08 06:05

    更新 U-boot 時出現(xiàn)的問題求解

    我在嘗試更新 U-boot 時遇到問題。最初我無法啟動 Fedora,但后來我讀到了這并嘗試更新 U-boot。但是,當(dāng)我按照官方文檔我卡在迷你機屏幕上,什么也做不了。我擔(dān)心董事會來了 DOA......
    發(fā)表于 04-01 07:20

    更新固件后 U-boot 不運行怎么解決?

    我刷新了從這里下載的新fw_payload固件(u-boot 和 opensbi):用于 TF 卡兼容性的新 u-boot 二進制文件 -.現(xiàn)在它啟動到 OpenSBI,但無法達到 U-boot。我
    發(fā)表于 03-25 08:17

    更新 SPL 和 U-Boot的提示和技巧

    U-Boot 和 SPL 文件并將它們加載到 U 盤上 7 連接將 USB 記憶棒連接到 VF2 板并將其安裝在文件夾中 8 更新來自終端的固件 9 驗證使用命令 cat /proc/mtd 并檢查如下
    發(fā)表于 03-20 08:15

    如何使 i.MX93 上的 U-Boot SPL 和 ATF/BL31輸出靜音呢?

    到外部網(wǎng)絡(luò)設(shè)備時,U-Boot SPL 和 ATF/BL31 啟動消息會回顯到外部設(shè)備的控制臺。如果外部設(shè)備也在啟動,它可以將這些字符解釋為輸入命令,從而可能損壞其引導(dǎo)加載程序或配置。 我成功靜音的內(nèi)容
    發(fā)表于 03-09 08:28

    深入解析U-Boot image.c:RK平臺鏡像處理核心邏輯

    在瑞芯微(RK)平臺的嵌入式開發(fā)中,U-Boot作為核心的啟動加載程序,負責(zé)完成鏡像解析、校驗、加載等關(guān)鍵流程。而image.c正是U-Boot中處理鏡像(uImage)的核心文件,尤其針對RK平臺
    的頭像 發(fā)表于 02-24 16:46 ?1778次閱讀
    深入解析<b class='flag-5'>U-Boot</b> image.c:RK平臺鏡像處理核心邏輯

    請問在上游 u-boot 上切換到基于 bootstd 的引導(dǎo)流?

    在撰寫本文時,上游 u-boot 現(xiàn)在具有相當(dāng)不錯的 vf2 支持。我已經(jīng)測試過最新版本 (2024.01) 開箱即用,但使用bootstd可以進一步清理到狀態(tài)中: No hardcoded
    發(fā)表于 02-09 07:02

    U-Boot SPL核心文件spl.c深度解析:從啟動流程到調(diào)試優(yōu)化

    在嵌入式系統(tǒng)開發(fā)中,U-Boot 的 SPL(Secondary Program Loader)扮演著至關(guān)重要的角色,它是系統(tǒng)上電后執(zhí)行的第一個軟件組件之一,負責(zé)為后續(xù)啟動過程鋪平道路。本文將深入
    的頭像 發(fā)表于 02-05 14:08 ?420次閱讀
    <b class='flag-5'>U-Boot</b> SPL核心文件spl.c深度解析:從啟動流程到調(diào)試優(yōu)化

    深入解析U-Boot命令處理核心文件:功能、調(diào)試與開發(fā)價值

    在嵌入式系統(tǒng)開發(fā)中,U-Boot 作為主流的引導(dǎo)加載程序,其命令處理、交互邏輯和自動啟動流程是核心功能模塊。本文將圍繞command.c、cli.c和autoboot.c三個關(guān)鍵文件,從核心
    的頭像 發(fā)表于 02-03 15:44 ?986次閱讀
    深入解析<b class='flag-5'>U-Boot</b>命令處理核心文件:功能、調(diào)試與開發(fā)價值

    深入解析U-Boot核心文件board_f.c:知識點、調(diào)試要點與開發(fā)價值

    在嵌入式系統(tǒng)開發(fā)中,U-Boot 作為應(yīng)用最廣泛的引導(dǎo)程序,其底層初始化邏輯直接決定了硬件啟動的穩(wěn)定性與可靠性。
    的頭像 發(fā)表于 02-03 15:38 ?860次閱讀
    深入解析<b class='flag-5'>U-Boot</b>核心文件board_f.c:知識點、調(diào)試要點與開發(fā)價值

    解析Rockchip平臺U-Boot核心文件:boot_rkimg.c到底做了什么?

    在嵌入式開發(fā)中,U-Boot 作為引導(dǎo)程序的 “中流砥柱”,負責(zé)初始化硬件、加載內(nèi)核并啟動系統(tǒng)。對于 Rockchip 平臺的設(shè)備(如常見的開發(fā)板、智能終端),boot_rkimg.c 是 U-Boot 中專門處理啟動流程的核心
    的頭像 發(fā)表于 02-03 15:29 ?933次閱讀
    解析Rockchip平臺<b class='flag-5'>U-Boot</b>核心文件:<b class='flag-5'>boot</b>_rkimg.c到底做了什么?

    深入解析rk平臺Android Bootloader核心代碼:從啟動流程到AVB驗證

    作為Android設(shè)備啟動的第一道“閘門”,Bootloader(以U-Boot為主)承擔(dān)著初始化硬件、加載內(nèi)核、驗證鏡像完整性的核心職責(zé)。今天我們拆解Rockchip平臺
    的頭像 發(fā)表于 01-22 07:06 ?473次閱讀
    深入解析rk平臺Android <b class='flag-5'>Bootloader</b>核心代碼:從啟動流程到AVB驗證

    深入理解?RK3506 U-Boot?重定位:從代碼到原理

    在嵌入式系統(tǒng)中,U-Boot?作為引導(dǎo)加載程序,其啟動流程的核心環(huán)節(jié)之一就是 重定位(Relocation) 。對于?RK3506?這類基于?ARM Cortex-A?架構(gòu)的芯片,重定位的本質(zhì)是將
    的頭像 發(fā)表于 11-28 07:05 ?967次閱讀
    深入理解?RK3506 <b class='flag-5'>U-Boot</b>?重定位:從代碼到原理

    U-Boot 無法識別 NAND怎么解決?

    U-Boot 無法識別 NAND
    發(fā)表于 09-03 06:37

    飛凌嵌入式ElfBoard ELF 1板卡-uboot編譯u-boot/u-boot.bin/u-boot.imx

    u-boot文件就是編譯流程章節(jié)講的,鏈接器將鏈接各.o文件之后生成的.elf文件,該文件中包含了大量的調(diào)試信息、地址信息和注釋信息,不能被直接執(zhí)行,需要轉(zhuǎn)換成為可執(zhí)行的u-boot.bin文件,而
    發(fā)表于 05-22 11:24