精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

ESP特權隔離機制來了!

Rokr_wireless_t ? 來源:啟明云端科技 ? 2023-02-06 16:13 ? 次閱讀

一般情況下,微控制器上運行的應用程序采用的都是單體式系統,即“用戶-內核”不隔離,這也是 SoC 和 MCU 在軟件架構上的差異之一。

傳統上,任何基于樂鑫芯片和 ESP-IDF 開發的應用程序均為單體式固件,即“內核”組件與“應用程序”或“業務邏輯”之間不相互獨立。因此一旦應用程序出錯就將導致整個系統崩潰。

如今,在 ESP 特權隔離框架下,能夠創建兩個獨立的執行環境:用戶應用程序和內核(或特權)應用程序。

受保護的應用程序不會受到用戶應用程序異常的影響,極大地提高了安全性,用戶應用程序的任何BUG都不會影響到整個系統。

22fddaae-a4d1-11ed-bfe3-dac502259ad0.jpg

ESP 特權隔離的亮點:

支持兩個獨立的執行環境:安全世界和非安全世界。

將單體式固件劃分為兩個獨立的固件:受保護(安全)應用程序和用戶(非安全)應用程序。

受保護的應用程序不受用戶應用程序異常的影響。

提供標準系統調用接口,允許用戶應用程序通過這些接口發起內核服務訪問請求。

保持與 ESP-IDF API 的一致性。

支持可配置的內存訪問權限和外設訪問權限。

支持在受保護的應用程序和用戶應用程序之間靈活分配內存。

分割固件大小,加快OTA完成速度。

技術細節

1. 應用程序的啟動過程

232a63a8-a4d1-11ed-bfe3-dac502259ad0.png

在 ESP 權限隔離框架下,應用程序的啟動流程與 ESP-IDF 一致,即 Boot ROM(一級引導加載程序)首先進行驗證,并從 flash 中加載 ESP-IDF 二級引導加載程序。然后,二級引導加載程序進行驗證,并加載受保護的應用程序。最后,受保護的應用程序在 flash 中尋找有效的用戶應用程序入口 (header)。如找到,則將設置適當的權限,并嘗試驗證并加載用戶應用程序。

2. World 控制器和權限控制

ESP 特權隔離框架的主要目標是實現特權分離和強制權限管理。在 ESP32-C3 中,這是通過 World 控制器和權限管理控制器實現的。具體來說,權限管理控制器管理所有權限,而 World 控制器管理執行環境(世界),且每個世界中均有獨立的權限配置。目前,我們有兩個世界:World0 和 World1。

World0 是安全(受保護)環境,World1 是非安全(用戶)環境。

23462a7a-a4d1-11ed-bfe3-dac502259ad0.png

*World和權限管理

如上圖所示:

安全世界(World0)擁有對地址段 A 的全部訪問權限。

非安全世界(World1)僅擁有對地址段 A 的讀權限。

在這種權限配置下,如果非安全世界試圖向地址段 A 中的任何地址進行寫操作,則將觸發非法訪問中斷。安全世界將處理這個非法訪問中斷,并采取適當措施。

3. CPU 的世界切換

從安全世界切換到非安全世界:CPU 可以從安全世界切換到非安全世界,此時僅需將需要切換的地址配置至 World 控制器的地址寄存器,接著當 CPU 執行至該地址時即可從安全世界切換到非安全世界,此后在非安全世界執行應用程序。

從非安全世界切換到安全世界:CPU 可以從非安全世界切換至安全世界,但只能通過中斷或異常,即系統中發生任何中斷都會導致 CPU 切換到安全世界。

4. 內存布局

在強制執行權限管理后,下一步是分割內存。

內部 SRAM

下圖展示了如何劃分 SRAM,供受保護的應用程序和用戶應用程序使用。SRAM 分為 IRAM 和 DRAM,可以根據應用程序的使用情況進行非常靈活的配置。

2368dd18-a4d1-11ed-bfe3-dac502259ad0.jpg

DRAM 區域包含對應應用程序的 .data 和 .bss 段,其余部分用作堆。在 ESP 特權隔離框架下,每個受保護的應用程序和用戶應用程序均有一個專用的堆分配器。

這種 SRAM 內存分布可以在受保護的應用程序升級后,依然很好地使用內存。此時,一旦受保護應用程序使用的 IRAM 有所增加或減少,我們均可以重新配置 IRAM-DRAM 分割線,且并不用影響用戶內存的劃分情況。

外部 flash:

下圖展示了如何在受保護的應用程序和用戶應用程序之間分割 flash 虛擬內存。與內存分割一樣,flash MMU 地址段也分為 .rodata 和 .text 區域,可進行靈活配置。

238173c8-a4d1-11ed-bfe3-dac502259ad0.png

5. 系統訪問接口

受保護的應用程序提供了一個標準的“系統調用”接口,用戶應用程序可以通過該接口請求訪問內核服務。這個過程會使用一個特殊的 CPU 指令生成一個同步異常,并通過這個異常將控制權移交給受保護的應用程序。系統調用處理程序將仔細檢查請求,并相應地執行操作。下圖概述了系統調用接口的實現過程:

23a690c2-a4d1-11ed-bfe3-dac502259ad0.png

*系統調用執行過程

6. API 一致性

對于大多數組件,受保護的應用程序和用戶應用程序均與 ESP-IDF API 保持一致。通過系統調用接口開放給用戶應用程序的組件必須使用系統調用實現,而不是實際功能實現。我們利用鏈接器的特點,使用系統調用定義覆蓋 API 的定義。這種與 ESP-IDF API 的一致性可以確保:

輕松將 ESP-IDF 示例應用程序(僅需少量修改)移植到此框架。

同一個程序可以構建為受保護的應用程序或用戶應用程序。

7. 用戶空間異常處理

在完成權限配置和內存分割后,可能會出現用戶應用程序故意或無意嘗試訪問受保護禁區的情況。此時,權限控制器會觸發一個非法訪問中斷,由受保護的應用程序處理。這種強制執行權限管理的好處是,受保護的空間內存和應用程序不會受到用戶應用程序任何(錯誤)行為的影響。在 ESP 特權隔離框架中,我們允許受保護的應用程序注冊專門的處理程序,以應對用戶應用程序中出現的任何異常。這個處理程序還可以收集一些重要信息,并相應地處理異常。

8. 設備驅動程序

用戶應用程序可能需要通過外圍設備(SPI、I2C 等)才能與外部設備和傳感器通信。在 ESP 特權隔離框架中,我們將設備驅動實現在受保護的應用程序中,并通過標準 I/O 系統調用(open, read, write 等)的方式,將其開放給用戶應用程序。這樣一來,我們可以通過一組公共的系統調用接口,實現多個設備驅動程序。

此外,也可以向用戶應用程序開放對外設寄存器的訪問權限,允許用戶應用程序寫自己的驅動程序。

優勢

ESP 特權隔離框架可以實現一些此前傳統單體式方法通常無法實現的用例和場景,以下為一些例子:

隔離系統和業務邏輯,從而分離維護軟件的責任劃分。

業務邏輯(用戶應用程序)中的任何錯誤都不會影響整個系統。用戶空間中的此類異常由受保護的應用程序捕獲并進行相應處理,并且允許實時收集并傳輸診斷信息(如果需要)。

可以獨立管理受保護應用程序和用戶應用程序的 OTA(空中升級)更新。只要兩者的接口相互兼容,受保護的應用程序和用戶應用程序可以有不同的發布節奏。

認證角度來說,僅需認證一次受保護的應用程序并進行分發,之后的用戶應用程序均可基于此已認證的受保護應用程序進行構建。

設備可同時保留多個用戶應用程序,并使用同個受保護應用程序進行執行。

傳統應用程序與ESP特權分離程序的內存使用對比(Rainmaker Demo)。

23d545f2-a4d1-11ed-bfe3-dac502259ad0.jpg

目前,該項目仍處于 beta 階段,但 ESP 特權隔離框架完全開源。

審核編輯 :李倩

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

    關注

    146

    文章

    17019

    瀏覽量

    350374
  • ESP
    ESP
    +關注

    關注

    0

    文章

    181

    瀏覽量

    33889
  • 應用程序
    +關注

    關注

    37

    文章

    3245

    瀏覽量

    57615

原文標題:官方“空投” — ESP特權隔離機制來了!

文章出處:【微信號:wireless-tag,微信公眾號:啟明云端科技】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    ESP系統的控制邏輯與響應機制

    在探討現代汽車安全技術時,汽車電子穩定程序系統無疑是一個不可或缺的部分。這種先進的系統通過精確控制車輛的動態表現,顯著提高了駕駛時的安全性和穩定性。 ESP系統的控制邏輯與響應機制 動態方向比
    的頭像 發表于 08-29 11:00 ?386次閱讀

    esp32和esp8266代碼共用嗎

    本文將介紹ESP32和ESP8266兩款流行的微控制器在代碼共用性方面的可能性與差異性。 一、引言 隨著物聯網技術的飛速發展,越來越多的智能設備開始進入我們的生活。其中,ESP32和ESP
    的頭像 發表于 08-19 18:23 ?1003次閱讀

    esp8266和esp32區別是什么

    以下是關于ESP8266和ESP32的主要區別: 處理器和架構 : ESP8266 :使用一個Tensilica L106 80MHz的處理器,屬于Xtensa架構。 ESP32 :使
    的頭像 發表于 08-19 18:16 ?4507次閱讀

    esp32用什么軟件編程

    ESP32是一款由樂鑫(Espressif)推出的低功耗、高性能的Wi-Fi和藍牙雙模微控制器,廣泛應用于物聯網、智能家居、智能穿戴等領域。要對ESP32進行編程,需要選擇合適的編程軟件和開發環境
    的頭像 發表于 08-19 17:24 ?2964次閱讀

    ESP32-WROOM-32E、ESP32-WROOM-32D、ESP32-WROOM-32U 有什么區別?ESP32-WROOM-32 后綴字母代表的意思是?

    相信很多人心里都有這樣的疑問,今天就教大家怎么區分它們。 32D和32U是同一個芯片ESP32-D0WD的模組,主要區別的天線模式,分別是板載和IPEX外接天線。 32E是用的升級版的芯片
    的頭像 發表于 07-17 10:09 ?7958次閱讀
    <b class='flag-5'>ESP</b>32-WROOM-32E、<b class='flag-5'>ESP</b>32-WROOM-32D、<b class='flag-5'>ESP</b>32-WROOM-32U  有什么區別?<b class='flag-5'>ESP</b>32-WROOM-32 后綴字母代表的意思是?

    ESP32用send函數發送數據時,經常出現進到send后就出不來了的情況,為什么?

    在使用ESP32的WIFI發送TCP數據時(模塊做AP,TCP-Server),用send函數發送數據時,經常出現進到send后就出不來了的情況,唯一的解救辦法就是斷開WIFI連接,send才會返回
    發表于 06-26 07:00

    樂鑫ESP-Mesh-Lite智能設備組網方案

    隨著物聯網技術的飛速發展,智能交互生活逐漸成為現代生活的一部分。樂鑫以其ESP-Mesh-Lite網絡技術,為智能設備領域帶來了革命性的變革。ESP-Mesh是基于Wi-Fi協議自主研發的無線
    的頭像 發表于 06-22 08:04 ?620次閱讀
    樂鑫<b class='flag-5'>ESP</b>-Mesh-Lite智能設備組網方案

    esp32自動重連機制怎么做?

    esp32成功連上一個路由器,這個時候斷開路由器電源,再上電,這個esp32自動重連機制怎么做?
    發表于 06-07 07:31

    國產低成本Wi-Fi SoC解決方案芯片ESP8266與ESP8285對比差異

    ESP8266與ESP8285對比差異 ESP8285相當于在ESP8266基礎上多加了1/2MB Flash, ESP8285與
    的頭像 發表于 05-17 11:44 ?1189次閱讀
    國產低成本Wi-Fi SoC解決方案芯片<b class='flag-5'>ESP</b>8266與<b class='flag-5'>ESP</b>8285對比差異

    特權賬號管理的那些坑,芯盾時代PAM幫你踩平!

    特權賬號,是指數據中心內部,分布在主機、網絡設備、數據庫等資產上具有較高訪問權限的賬號,衍生到一切資產上具有可訪問權限的賬號。
    的頭像 發表于 03-21 11:44 ?1140次閱讀
    <b class='flag-5'>特權</b>賬號管理的那些坑,芯盾時代PAM幫你踩平!

    ESP32-PICO系列技術規格書

    ESP32-PICO 系列是基于 ESP32 芯片 的系統級封裝 (SiP) 產品。ESP32-PICO 系列產品包括 ESP32-PICO-D4、
    發表于 12-12 16:56 ?0次下載
    <b class='flag-5'>ESP</b>32-PICO系列技術規格書

    ESP32-WROOM-32開發板教程

    ESP32-WROOM-32開發板。 第一部分:ESP32-WROOM-32簡介 首先,讓我們來了解一下ESP32-WROOM-32的基本信息。它是一款強大的Wi-Fi和藍牙模塊,內置
    的頭像 發表于 12-08 13:55 ?1w次閱讀

    帶顯示的隔離放大器 信號隔離隔離變送器# @黑科技

    信號隔離隔離變送器
    順源科技
    發布于 :2023年12月01日 13:35:20

    客戶案例丨某大型能源集團重構企業身份管理體系 筑牢特權賬號安全防線

    、權限大,缺乏統一的管理平臺和規范的管理機制,導致賬號資源混亂、密碼策略難以落地。其次,特權賬號普遍多人共享,責任難以落實到人,不利于風險監測和追蹤溯源。 面對特權賬號管理難題,某大型能源集團(以下簡稱“A集團
    的頭像 發表于 11-30 10:10 ?588次閱讀