那曲檬骨新材料有限公司

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

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

3天內不再提示

為什么要使用MPU?MPU如何實現內存保護?

strongerHuang ? 來源:strongerHuang ? 作者:strongerHuang ? 2022-07-05 17:38 ? 次閱讀

先說明一下MPU,MPU有很多含義,我們常見的有:

MPU:Memory Protection Unit,內存保護單元(本文描述的內容);

MPU:Microprocessor Unit,微處理器

還有,可能有人會與MPU-6050這類模塊聯系在一起。所以,大家不要把MPU搞混了。

為什么要使用MPU?

如果你開發的嵌入式項目,因內存溢出,或者內存故障等一些原因,造成了重大經濟損失,或者造成了重大事故,你就能體會為什么要使用內存保護單元(MPU)了。

嵌入式系統中使用內存保護單元(MPU)可以在開發早期及時發現因內存而導致的Bug,節省更多開發時間。 同時,在項目后期修改Bug,或者增加功能,可以減少修改文檔和測試所需的時間。 poYBAGLEBzGABAnVAACn1eYQigc216.jpg

也就是說,使用MPU,會避免因為修改一個bug,而引起多個bug的情況(0生1,1生萬物)。

MPU如何實現內存保護

簡單來說就是保護與當前執行的代碼不相關的所有數據。

RTOS任務A和B來說: 任務A和B不應相互交互數據,但是存在一個錯誤,任務A可能會意外地寫入任務B偶爾使用的某些數據,不會影響任務A的正確操作。但是,當任務B嘗試使用損壞的數據時,任務B可能會意外故障。 如果沒有配置MPU來阻止任務A寫入任務B的數據,則該錯誤可能需要很長的時間供開發人員跟蹤。如果錯誤很小,或者如果任務B很少使用該數據,則將很難解決該bug。但是,如果使用了MPU,則該bug就會及早被發現。 在某些體系結構上,MPU甚至可以幫助你檢測NULL指針引用,因為你可以設置MPU區域以防止非特權代碼訪問內存0x0。 應用程序中一組設計良好的MPU區域可以很好的保護重要的內存區域,以防止出現特定的問題。 一個很好的例子是通過在MPU區域的末尾放置緩沖區來防止緩沖區溢出,你還可以將任務堆棧放置在任何非特權代碼都無法訪問的區域。如果這樣做,則每個任務必須使用自己的MPU區域之一來設置自己對自己的堆棧的訪問權限。

使用MPU的好處

無論是操作系統,還是裸機系統,如果沒有防止惡意訪問錯誤內存的能力,系統將有重大安全問題,以及安全漏洞的雷區。

使用的內存保護單元(MPU)有很多優勢,MPU通常允許你以特權或非特權模式運行,并使用一組“區域”來確定當前正在執行的代碼是否具有訪問代碼和數據的權限。 每個區域都是一個連續的內存塊,具有該內存的一組權限,特權和非特權訪問。與非特權代碼的子集相比,特權代碼往往可以訪問大部分(但不是全部)內存。 在整個系統運行時中,這些區域不必相同。MPU區域可以根據每個任務進行修改,每個任務可以具有自己獨特的區域集,這些區域在任務移至運行狀態時進行配置。 這使你可以僅對需要代碼和數據的任務設置訪問權限,利用MPU的嵌入式操作系統將在每次上下文切換期間管理每個任務的區域和特權級別。 比如設置RTOS兩個任務不同的內存保護區域:

pYYBAGLEBxWACXZ-AAEJCMxikdA848.jpg

上面這張圖,大家都能看懂吧?Flash和內存區域被分別設置保護。 兩個全局保護區域:Flash開頭、RAM開頭; 在Flash中,一部分僅限任務1訪問,這部分不能被任務訪問;同時,在Flash另外區域,僅限任務2訪問,不能被任務1訪問。如果這兩部分區域被對方訪問,則會生成生成MPU故障。 在RAM區域,同一部分區域,一個只能被讀,一個只能被寫入,如果不按約定操作,同樣也會生產MPU故障。

什么時候不使用MPU?

通常有兩種情況可以不使用處理器上的MPU功能:

一個簡單的項目

一個對性能至關重要的項目

第1個很簡單:一個非常簡單的應用程序基本上沒必要使用MPU,反而增加了系統的復雜性。不設置內存保護,RAM和外圍設備的MPU區域,你自己一眼就能找到bug。 第2個對性能要求高的項目,在上下文切換時,設置內存保護,堆棧那些操作,有可能影響系統的實時性,從而導致系統異常。這個需要結合項目實際情況考慮用,還是不用MPU功能。

審核編輯:劉清

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

    關注

    11

    文章

    2274

    瀏覽量

    82779
  • MPU
    MPU
    +關注

    關注

    0

    文章

    375

    瀏覽量

    48959
  • RTOS
    +關注

    關注

    22

    文章

    819

    瀏覽量

    119890

原文標題:為什么RTOS系統要使用MPU?

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    常見MPU接口類型及特點

    微處理器單元(MPU)是計算機系統中的核心組件,負責執行程序指令和處理數據。MPU接口是連接MPU與其他系統組件(如內存、輸入/輸出設備等)的橋梁。以下是一些常見的
    的頭像 發表于 01-08 09:43 ?183次閱讀

    如何優化MPU的能耗

    優化MPU(微處理器單元)的能耗是一個綜合性的任務,需要從硬件設計、軟件優化以及系統集成等多個方面入手。以下是一些具體的優化策略: 一、硬件設計優化 選擇低功耗MPU : 在設計之初,應根據應用需求
    的頭像 發表于 01-08 09:41 ?159次閱讀

    MPU的性能評估方法

    Testing) 基準測試是通過運行一組預定義的測試程序來評估MPU的性能。這些測試程序通常涵蓋了處理器的主要功能,如計算能力、內存訪問速度、浮點運算等。通過比較不同MPU在相同基準測試下的得分,可以直觀地了解它們的性能差異。
    的頭像 發表于 01-08 09:39 ?153次閱讀

    MPU數據傳輸協議詳解

    在現代電子系統中,微控制器(MPU)扮演著核心角色,負責處理各種任務和數據。為了實現這些功能,MPU需要與其他設備進行數據交換。數據傳輸協議就是規定這些數據交換如何進行的一套規則。 MPU
    的頭像 發表于 01-08 09:37 ?163次閱讀

    MPU的故障排除技巧

    MPU(微處理單元)的故障排除技巧涉及多個方面,包括硬件連接、軟件配置、通信協議以及系統集成等。以下是一些詳細的故障排除技巧: 一、硬件連接檢查 接口兼容性 : 確保MPU與其他設備的接口兼容
    的頭像 發表于 01-08 09:36 ?155次閱讀

    MPU與數字信號處理的關系

    在數字化時代,微處理器單元(MPU)和數字信號處理(DSP)技術已經成為實現復雜計算和數據處理任務的關鍵技術。MPU作為計算機系統的大腦,負責執行程序指令和處理數據,而DSP則專注于高效地處理信號
    的頭像 發表于 01-08 09:29 ?183次閱讀

    MPU在嵌入式系統中的應用

    一、MPU的基本功能 微處理器單元(MPU)是嵌入式系統中的大腦,負責執行程序指令、處理數據和控制其他硬件設備。MPU的基本功能包括: 指令執行:MPU能夠從存儲器中讀取指令,解碼這些
    的頭像 發表于 01-08 09:26 ?209次閱讀

    MPU與MCU的區別

    和應用上存在顯著差異。 MPU與MCU的定義 微處理器單元(MPU) : MPU是一種通用的中央處理單元,它主要設計用于執行復雜的計算任務。MPU通常包含一個或多個核心,能夠處理廣泛的
    的頭像 發表于 01-08 09:25 ?336次閱讀

    什么是MPU控制器及其應用

    MPU控制器是現代電子系統中不可或缺的組成部分,它們在各種設備中扮演著核心角色,從簡單的嵌入式系統到復雜的計算機和服務器。MPU控制器的設計旨在提供高效、可靠的數據處理能力,同時保持較低的功耗和成本
    的頭像 發表于 01-08 09:23 ?203次閱讀

    MPU微處理器的工作原理

    在現代電子設備中,微處理器(MPU)扮演著至關重要的角色。從個人電腦到智能手機,再到嵌入式系統,MPU都是實現復雜計算任務的關鍵。 MPU的基本結構
    的頭像 發表于 01-07 18:08 ?507次閱讀

    瑞薩RZ/T系列MPU的中斷重入實現

    基于Arm的RZ/T系列MPU通過工業以太網通信提供高性能和高速實時控制,為自動化市場構建高性能系統。RZ/T MPU和RZ/N MPU均基于類似的硬件架構開發而成,并共享相同的軟件環境,可
    的頭像 發表于 07-23 14:47 ?664次閱讀
    瑞薩RZ/T系列<b class='flag-5'>MPU</b>的中斷重入<b class='flag-5'>實現</b>

    硬件i2c讀寫MPU6050

    本資料為MPU6050
    發表于 07-15 11:45 ?4次下載

    產品簡介 | RZ/A系列MPU

    產品簡介 | RZ/A系列MPU
    的頭像 發表于 05-24 08:06 ?486次閱讀
    產品簡介 | RZ/A系列<b class='flag-5'>MPU</b>

    STM32H750使能內存保護后DMA異常的原因?怎么解決?

    STM32H750 在使能內存保護后啟用cache 導致SPI+DMA傳輸不準確,具體就是調用HAL_SPI_TransmitReceive_DMA 這個函數,讀到的數據全是0,但是拿邏輯分析儀看上面顯示的數據是正確的。
    發表于 05-24 07:53

    AUTOSAR內存分區和MPU關系簡述

    MPU保護與當前執行的代碼“不相關“的所有數據。
    的頭像 發表于 03-18 11:15 ?1354次閱讀
    AUTOSAR<b class='flag-5'>內存</b>分區和<b class='flag-5'>MPU</b>關系簡述
    大发888冲值| 百家乐官网注册送彩金平台| 做生意摆放的招财物件| 二八杠玩法| 百家乐官网玩法最多的娱乐城| 百家乐娱乐平台网77scs| 赌百家乐官网的体会| 澳门百家乐海星王娱乐城| 泾阳县| 百家乐平台要多少钱| 墨竹工卡县| 二代百家乐破解| 百家乐官网百家乐官网游戏| 电子百家乐技巧| 百家乐官网电子路单下载| 发中发百家乐的玩法技巧和规则| 百家乐官网编单短信接收| 试玩百家乐帐| 真人百家乐官网软件云南景| 免费棋牌游戏| 百家乐的打法技巧| 百家乐官网好不好玩| 网络百家乐程序| 新百家乐官网.百万筹码| 大发888真人真钱网址| 24山辅星水法分阴阳| 黄平县| 山西百家乐用品| 百家乐官网群html| 太阳城公司| 百家乐官网筹码币套装| 体球网比分| 赌场百家乐欺诈方法| 超级百家乐官网2龙虎斗| 大发888 大发888官网| 百家乐稳赚的方法| 澳门百家乐官网心得玩博| 太阳城团购| 百家乐官网游戏大厅下| tt娱乐城clega| 百家乐双筹码怎么出千|