那曲檬骨新材料有限公司

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

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

3天內不再提示

armv8 u-boot的啟動介紹

麥辣雞腿堡 ? 來源:CSDN博客 ? 作者:內核新視界 ? 2023-12-07 11:09 ? 次閱讀

先看arm官網提供的一張圖:

圖片

上圖詳細概括了arm官方推薦的armv8的啟動層次結構:

官方將啟動分為了BL1,BL2,BL31,BL32,BL33階段,根據順序,芯片啟動后首先執行BL1階段代碼,接著驗簽啟動BL2,BL2根據具體設計啟動BL31或者BL33,BL32只有在有BL31時才可能會存在并被驗簽加載啟動。

armv8分為Secure World和Non-Secure World(Normal World),四種異常級別從高到低分別為EL3,EL2,EL1,EL0。

? Secure World就是可以執行可信的firmware和app,比如密碼支付,指紋識別等一系列依賴安全保證的服務。

? Non-Secure World就是我們常見的u-boot,linux,qnx等裸機程序或者操作系統。

? EL3具有最高管理權限,負責安全監測和安全模式切換。

? EL2主要提供了對虛擬化的支持。

? EL1是一個特權模式,能夠執行一些特權指令,用于運行各類操作系統,在安全模式則是可信任OS。

? EL0是無特權模式,所有APP應用都在EL0。

上圖中的BL1,BL2,BL31,BL32,BL33分別對應如下功能:

? BL1:是一切信任的根,一般就是固化在ROM中的一段啟動加載代碼,用于引導bl2,并對bl2進行驗簽保證可信任執行;

?BL2:一般是在flash中的一段可信安全啟動代碼,它的可信建立在bl1對它的驗證,主要完成一些平臺相關的初始化,比如對ddr的初始化等,并在完成初始化后尋找BL31或者BL33進行執行;如果找到了BL31則不會繼續調用BL33,如果沒有BL31則BL33必須有;

?BL31:BL31不像BL1和BL2是一次性運行的,它作為最后一道可信任固件存在,在系統運行時通過smc指令陷入EL3調用系統安全服務或者在Secure World和Non-Secure World之間進行切換;在完成BL31初始化后會去尋找BL32或者BL33進行驗簽后加載執行;

? BL32:OPTee OS + 安全app,它是一個可信安全的OS運行在EL1并在EL0啟動可信任APP(上述的指紋驗證等app),并在Trust OS運行完成后通過smc指令返回BL31,BL31切換到Non-Seucre World繼續執行BL33;

? BL33:非安全固件,也就是我們常見的UEFI firmware或者u-boot也可能是直接啟動Linux
kernel;啟動BL1,BL2,BL31,BL32則是一個完整的ATF信任鏈建立流程(ARM Trusted Firmware),像常見的PSCI(Power State Coordination Interface)功能則是在ATF的BL31上實現;

最后一張圖完整展示整個調用流程:

圖片

BL2根據是否存在BL31和BL32可選擇性的加載不同firmware;

綜上所述可知u-boot是一個運行在非安全世界的bootloader,負責加載各類操作系統,并提供豐富的驅動接口;

并根據是否存在安全固件還可以進行不同的boot流程,如下。

?u-boot,u-boot-spl,u-boot-tpl的關系:對于一般嵌入式而言只需要一個u-boot作為bootloader即可,但是在小內存,或者有atf的情況下還可以有spl,tpl;

? spl:Secondary Program Loader,二級加載器

? tpl:Tertiary Program Loader,三級加載器

出現spl和tpl的原因最開始是因為系統sram太小,rom無法在ddr未初始化的情況下一次性把所有代碼從flash,emmc,usb等搬運到sram中執行,也或者是flash太小,無法完整放下整個u-boot來進行片上執行。

所以u-boot又定義了spl和tpl,spl和tpl走u-boot完全相同的boot流程,不過在spl和tpl中大多數驅動和功能被去除了,根據需要只保留一部分spl和tpl需要的功能,通過CONFIG_SPL_BUILD和CONFIG_TPL_BUILD控制;

一般只用spl就足夠了,spl完成ddr初始化,并完成一些外設驅動初始化,比如usb,emmc,以此從其他外圍設備加載u-boot,但是如果對于小系統spl還是太大了,則可以繼續加入tpl,tpl只做ddr等的特定初始化保證代碼體積極小,以此再次從指定位置加載spl,spl再去加載u-boot。

從目前來看,spl可以取代上圖中bl2的位置,或者bl1,根據具體廠商實現來決定,有一些芯片廠商會將spl固化在rom中,使其具有從emmc,usb等設備加載u-boot或者其他固件的能力。

當然在有atf的情況下可以由atf加載u-boot,或者由spl加載atf,atf再去加載u-boot。

甚至在快速啟動的系統中可以直接由spl啟動加載linux等操作系統而跳過啟動u-boot;

在上圖中arm官方只是給出了一個建議的啟動信任鏈,具體實現都需要芯片廠商來決定;

后續分析啟動流程中會在具有SPL和TPL的地方拓展它們的分叉執行路徑盡量把SPL和TPL的功能也一并分析;

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

    關注

    456

    文章

    51170

    瀏覽量

    427227
  • ARM
    ARM
    +關注

    關注

    134

    文章

    9165

    瀏覽量

    369176
  • Uboot
    +關注

    關注

    4

    文章

    125

    瀏覽量

    28348
  • 系統
    +關注

    關注

    1

    文章

    1019

    瀏覽量

    21424
收藏 人收藏

    評論

    相關推薦

    U-Boot介紹

    在移植 Linux之前我們需要先移植一個 bootloader 代碼,這個 bootloader 代碼用于啟動 Linux 內核, bootloader有很多,常用的就是 U-Boot。
    的頭像 發表于 10-08 10:50 ?4191次閱讀

    U-boot的基本介紹

    從本文開始,將陸續推送“手把手教你移植U-boot”系列文章,目標是由淺入深地講解U-boot的工作流程、原理、配置方法和移植方法,手把手教你完成U-boot的移植工作,默認硬件開發平臺為ARM,操作系統為Linux。
    發表于 07-14 16:52 ?3130次閱讀
    <b class='flag-5'>U-boot</b>的基本<b class='flag-5'>介紹</b>

    U-BOOT啟動流程分享

    Bootloader移植(下)U-BOOT 啟動流程u-boot啟動三個2啟動步驟(重點)U-boot
    發表于 01-18 10:17

    基于armv8架構對u-boot進行啟動流程分析(一)

    的開發調試文檔與強大的網絡技術支持;基于以上理由本篇文章對現在主流的armv8架構的u-boot啟動流程進行詳細分析,以便所有人快速學習和理解u-boot的工作流程。2
    發表于 05-23 15:59

    基于armv8架構對u-boot進行啟動流程分析(二)

    boot參數,進行地址無關fixed,系統寄存器復位,底層平臺相關初始化等,啟動代碼位于arch/arm/cpu/armv8/start.S,入口地址為_start。1.1 啟動前為后
    發表于 05-23 16:05

    U-Boot啟動及移植分析

    bootloader 開發是嵌入式系統必不可少而且十分重要的部分,U-Boot 為功能強大的bootloader 開發軟件。本文詳細分析了U-Boot啟動流程,并結合其源碼,闡述了U-Bo
    發表于 09-01 16:34 ?27次下載

    嵌入式U-BOOT啟動流程及移植

    摘要:嵌入式系統一般沒有通用的bootloader,u-boot是功能強大的bootloader開發軟件,但相對也比較復雜。文中對u-boot啟動流程作了介紹,詳細給出了
    發表于 02-25 16:00 ?59次下載

    u-boot簡介

    U-Boot,全稱 Universal Boot Loader,是遵循GPL條款的開放源碼項目。U-Boot的作用是系統引導。U-Boot從FADSROM、
    發表于 10-14 11:17 ?3596次閱讀

    fireflyFace-RK3399主板U-Boot模式啟動

    RK U-Boot 基于開源的 U-Boot 進行開發,工作模式有啟動加載模式和下載模式。
    的頭像 發表于 12-04 08:52 ?4619次閱讀
    fireflyFace-RK3399主板<b class='flag-5'>U-Boot</b>模式<b class='flag-5'>啟動</b>

    fireflyAIO-3399C主板U-Boot介紹

    RK U-Boot 基于開源的 U-Boot 進行開發,工作模式有啟動加載模式和下載模式。
    的頭像 發表于 12-04 10:31 ?1481次閱讀

    fireflyAIO-3288C主板U-Boot介紹

    RK U-Boot 基于開源的 U-Boot 進行開發,工作模式有啟動加載模式和下載模式。
    的頭像 發表于 12-16 13:52 ?1192次閱讀
    fireflyAIO-3288C主板<b class='flag-5'>U-Boot</b><b class='flag-5'>介紹</b>

    fireflyAIO-3399J主板U-Boot使用介紹

    RK U-Boot 基于開源的 U-Boot 進行開發,工作模式有啟動加載模式和下載模式。
    的頭像 發表于 12-24 10:00 ?1696次閱讀
    fireflyAIO-3399J主板<b class='flag-5'>U-Boot</b>使用<b class='flag-5'>介紹</b>

    基于armv8架構來對u-boot進行啟動流程分析

    首先引用wiki上的簡介:u-boot 是一個主要用于嵌入式系統的引導加載程序,可以支持多種不同的計算機系統結構。
    發表于 06-09 09:39 ?942次閱讀
    基于<b class='flag-5'>armv8</b>架構來對<b class='flag-5'>u-boot</b>進行<b class='flag-5'>啟動</b>流程分析

    u-boot armv8鏈接腳本

    u-boot armv8鏈接腳本 在進行源碼分析之前,首先看看u-boot的鏈接腳本,通過鏈接腳本可以從整體了解一個u-boot的組成,并且可以在
    的頭像 發表于 12-07 11:19 ?762次閱讀

    u-boot在匯編啟動階段的相關操作介紹

    boot參數, 進行地址無關fixed,系統寄存器復位,底層平臺相關初始化等 ,啟動代碼位于arch/arm/cpu/armv8/start.S, 入口地址為_start。 啟動前為后
    的頭像 發表于 12-07 11:22 ?692次閱讀
    在线百家乐官网大家赢| 稳赢百家乐官网的玩法技巧| 百家乐最新庄闲投注法| 六合彩资料| 飞天百家乐官网的玩法技巧和规则 | 澳门百家乐官网群策略| 百家乐一起多少张牌| 真人百家乐官网宣传| 百家乐官网现金网平台排名| 真人百家乐赌博技巧| 百家乐官网庄家提成| 在线百家乐合作| 百家乐官网总厂在哪里| BB百家乐大转轮| 太阳城百家乐官网168| 送现金百家乐的玩法技巧和规则 | 百家乐官网博彩的玩法技巧和规则 | 高尔夫百家乐官网的玩法技巧和规则 | 博九| 百家乐游戏怎样玩| 抚顺市| 百家乐公式计算| 888真人| 百家乐下注所有组合| 山西省| 卢克索百家乐的玩法技巧和规则 | 百家乐官网必胜绝| 易博全讯网| 电子百家乐假在线哪| 破解百家乐官网游戏机| 大发888官方 截图| 百家乐官网官网| 百家乐官网游戏看路| 喜来登百家乐的玩法技巧和规则| 百家乐官网23珠路打法| 娱乐城体验金| 百家乐太阳城| 百家乐官网免费赌博软件| 德州扑克桌| 百家乐游戏出售| 网上百家|