色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

    文章

    50965

    瀏覽量

    424829
  • ARM
    ARM
    +關注

    關注

    134

    文章

    9111

    瀏覽量

    368034
  • Uboot
    +關注

    關注

    4

    文章

    125

    瀏覽量

    28259
  • 系統
    +關注

    關注

    1

    文章

    1017

    瀏覽量

    21376
收藏 人收藏

    評論

    相關推薦

    U-Boot介紹

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

    U-boot的基本介紹

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

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

    RK U-Boot 基于開源的 U-Boot 進行開發,工作模式有啟動加載模式和下載模式。
    的頭像 發表于 12-04 08:52 ?4568次閱讀
    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 ?1457次閱讀

    fireflyAIO-3288C主板U-Boot介紹

    RK U-Boot 基于開源的 U-Boot 進行開發,工作模式有啟動加載模式和下載模式。
    的頭像 發表于 12-16 13:52 ?1163次閱讀
    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 ?1672次閱讀
    fireflyAIO-3399J主板<b class='flag-5'>U-Boot</b>使用<b class='flag-5'>介紹</b>

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

    首先引用wiki上的簡介:u-boot 是一個主要用于嵌入式系統的引導加載程序,可以支持多種不同的計算機系統結構。
    發表于 06-09 09:39 ?894次閱讀
    基于<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 ?719次閱讀

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

    boot參數, 進行地址無關fixed,系統寄存器復位,底層平臺相關初始化等 ,啟動代碼位于arch/arm/cpu/armv8/start.S, 入口地址為_start。 啟動前為后
    的頭像 發表于 12-07 11:22 ?659次閱讀
    主站蜘蛛池模板: 午夜精品久久久久久久爽牛战| 亚洲免费网站在线观看| 中文字幕一区在线观看视频| 久久yy99re66| 99热6精品视频6| 色小说在线| 国产亚洲免费观看| 在线亚洲中文字幕36页| 青娱乐视觉盛宴国产视频| 国产区精品综合在线| 征服艳妇后宫春色| 日本护士hd| 狠狠人妻久久久久久综合九色| 最新国自产拍 高清完整版| 人妻系列合集| 黑人 尺寸 强行害怕 痛哭| 69国产精品人妻无码免费| 手机在线免费| 老师真棒无遮瑕版漫画免费| 穿着丝袜被男生强行啪啪| 亚洲国产精品99久久久久久| 奶水四溅54p| 国产午夜小视频| 99久久国产综合精品国| 亚洲成人免费| 全文都是肉高h文| 久久精品亚洲| 国产精品无码久久久久不卡| 最近更新2019中文字幕国语| 午夜aaaa| 秋霞电影网午夜一级鲁丝片| 精品夜夜澡人妻无码AV| 高清观看ZSHH96的视频素材| 中文字幕高清在线观看| 亚洲 欧美 日韩 国产 视频| 嗯 用力啊 嗯 c我 啊哈老师| 狠狠色综合久久婷婷| 动漫美女被到爽了流| 91涩涩视频| 一品探花论坛| 午夜伦伦电影理论片费看|