那曲檬骨新材料有限公司

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

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

3天內不再提示

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

麥克泰技術 ? 來源:嵌入式專欄 ? 2023-02-24 11:59 ? 次閱讀

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

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

MPU:Microprocessor Unit,微處理器

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

嵌入式專欄

1

為什么要使用MPU?

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

嵌入式系統中使用內存保護單元(MPU)可以在開發早期及時發現因內存而導致的Bug,節省更多開發時間。

同時,在項目后期修改Bug,或者增加功能,可以減少修改文檔和測試所需的時間。

3aea7120-b3f6-11ed-bfe3-dac502259ad0.jpg

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

2

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區域之一來設置自己對自己的堆棧的訪問權限。

3

使用MPU的好處

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

使用的內存保護單元(MPU)有很多優勢,MPU通常允許你以特權或非特權模式運行,并使用一組“區域”來確定當前正在執行的代碼是否具有訪問代碼和數據的權限。

每個區域都是一個連續的內存塊,具有該內存的一組權限,特權和非特權訪問。與非特權代碼的子集相比,特權代碼往往可以訪問大部分(但不是全部)內存。

在整個系統運行時中,這些區域不必相同。MPU區域可以根據每個任務進行修改,每個任務可以具有自己獨特的區域集,這些區域在任務移至運行狀態時進行配置。

這使你可以僅對需要代碼和數據的任務設置訪問權限,利用MPU的嵌入式操作系統將在每次上下文切換期間管理每個任務的區域和特權級別。

比如設置RTOS兩個任務不同的內存保護區域:

3b148ece-b3f6-11ed-bfe3-dac502259ad0.png

上面這張圖,大家都能看懂吧?Flash和內存區域被分別設置保護。

兩個全局保護區域:Flash開頭、RAM開頭;

在Flash中,一部分僅限任務1訪問,這部分不能被任務訪問;同時,在Flash另外區域,僅限任務2訪問,不能被任務1訪問。如果這兩部分區域被對方訪問,則會生成生成MPU故障。

在RAM區域,同一部分區域,一個只能被讀,一個只能被寫入,如果不按約定操作,同樣也會生產MPU故障。

4

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

一個簡單的項目

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

第1個很簡單:一個非常簡單的應用程序基本上沒必要使用MPU,反而增加了系統的復雜性。不設置內存保護,RAM和外圍設備的MPU區域,你自己一眼就能找到bug。

第2個對性能要求高的項目,在上下文切換時,設置內存保護,堆棧那些操作,有可能影響系統的實時性,從而導致系統異常。這個需要結合項目實際情況考慮用,還是不用MPU功能。




審核編輯:劉清

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

    關注

    10

    文章

    1642

    瀏覽量

    148685
  • RAM
    RAM
    +關注

    關注

    8

    文章

    1369

    瀏覽量

    115025
  • 微處理器
    +關注

    關注

    11

    文章

    2274

    瀏覽量

    82779
  • MPU
    MPU
    +關注

    關注

    0

    文章

    375

    瀏覽量

    48959

原文標題:好文推薦| MPU如何實現內存保護?

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

收藏 人收藏

    評論

    相關推薦

    管理STM32 MCU中的內存保護單元

    本應用筆記介紹如何管理 STM32 產品中的內存保護單元(MPU)。MPU 是用于存儲器保護的可選組件。STM32 微控制器(MCU)中嵌入 MPU
    發表于 12-23 11:04 ?1108次閱讀

    為什么要使MPUMPU實現內存保護原理分析

    簡單來說就是保護與當前執行的代碼不相關的所有數據。 拿RTOS任務A和B來說: 任務A和B不應相互交互數據,但是存在一個錯誤,任務A可能會意外地寫入任務B偶爾使用的某些數據,不會影響任務A的正確操作。
    發表于 02-23 09:17 ?1832次閱讀

    【安富萊】【μCOS-III教程】第6章 內存保護單元MPU

    第6章內存保護單元MPU本期教程帶領大家學習內存保護單元MPU的使用,在前面的幾期教程中曾多次的提到MPU的使用,
    發表于 01-08 18:04

    主要講armv7-m架構下的MPU內存保護單元

    簡介MPU(Memory Protection Unit) 內存保護單元。 本文主要講 armv7-m 架構 架構下的 MPU。在 armv7-m 架構下,Cortex-M3 和 Cortex-M4
    發表于 04-08 11:00

    Armv8-M內存模型與內存保護用戶指南

    本指南概述了Armv8-M內存模型和內存保護單元(MPU)在Cortex-M處理器中實現。本指南使用示例來幫助解釋這些概念 它介紹了。 本章概述以下主題: ?
    發表于 08-02 08:12

    如何管理STM32產品中的內存保護單元(MPU

    本應用筆記介紹如何管理 STM32 產品中的內存保護單元(MPU)。MPU 是用于存儲器保護的可選組件。STM32 微控制器(MCU)中嵌入 MPU
    發表于 09-07 06:23

    MPU是什么Cortex-M內核的MPU內存保護單元詳細講解

    估計大家經常看見MCU、MPU、MMU等這類縮寫詞,你們了解MPU嗎?
    的頭像 發表于 02-03 09:30 ?1.1w次閱讀

    Cortex-M內核的MPU內存保護單元

    講講Cortex-M內核的MPU內存保護單元
    的頭像 發表于 03-04 11:17 ?3757次閱讀
    Cortex-M內核的<b class='flag-5'>MPU</b><b class='flag-5'>內存保護</b>單元

    基于ARM Cortex-M MCU中的MPU所提供的一些特性

    內存保護單元(MPU)是一種硬件機制,通過只允許代碼訪問需要的內存和外設來提高嵌入式設備的安全性。應用程序可以組織為進程(process),每個進程訪問自己的內存和外設。
    的頭像 發表于 07-19 09:47 ?7392次閱讀

    Cortex-M內核的MPU內存保護單元

    的選配件,拿STM32F1來說,STM32F10X_XL系列的芯片才具有這個MPU存儲保護單元,而其他STM32F1芯片沒有。可能很多人都處于簡單知道,或認識MPU的階段,今天就寫點關...
    發表于 12-01 12:21 ?9次下載
    Cortex-M內核的<b class='flag-5'>MPU</b><b class='flag-5'>內存保護</b>單元

    什么是Cortex-M內核的MPU內存保護單元)?

    關注、星標公眾號,不錯過精彩內容作者:strongerHuang微信公眾號:strongerHuang估計大家經常看見MCU、MPU、MMU等這類縮寫詞,但你們了解什么是MPU嗎?1寫在...
    發表于 12-01 12:51 ?10次下載
    什么是Cortex-M內核的<b class='flag-5'>MPU</b>(<b class='flag-5'>內存保護</b>單元)?

    為什么要使MPUMPU如何實現內存保護

    如果你開發的嵌入式項目,因內存溢出,或者內存故障等一些原因,造成了重大經濟損失,或者造成了重大事故,你就能體會為什么要使內存保護單元(MPU
    的頭像 發表于 07-05 17:38 ?6769次閱讀
    為什么<b class='flag-5'>要使</b>用<b class='flag-5'>MPU</b>?<b class='flag-5'>MPU</b>如何<b class='flag-5'>實現</b><b class='flag-5'>內存保護</b>?

    如何管理STM32產品中的MPU

    本應用說明介紹了如何管理STM32產品中的MPU,它是一個內存保護的可選組件。包括STM32中的MPU微控制器使它們更加健壯可靠。必須對MPU進行編程,并且在使用之前啟用。如果
    發表于 09-28 10:40 ?0次下載

    什么是MPUMPU在哪些方面保護內存安全?

    內存保護單元(MPU)是一種硬件機制,通過只允許代碼訪問需要的內存和外設來提高嵌入式設備的安全性。
    的頭像 發表于 06-12 09:06 ?1.1w次閱讀
    什么是<b class='flag-5'>MPU</b>?<b class='flag-5'>MPU</b>在哪些方面<b class='flag-5'>保護</b><b class='flag-5'>內存</b>安全?

    如何管理STM32產品中的內存保護單元(MPU)

    電子發燒友網站提供《如何管理STM32產品中的內存保護單元(MPU).pdf》資料免費下載
    發表于 08-01 09:15 ?0次下載
    如何管理STM32產品中的<b class='flag-5'>內存保護</b>單元(<b class='flag-5'>MPU</b>)
    百家乐玩法的秘诀| 神娱乐百家乐官网的玩法技巧和规则| 真人百家乐官网网络游戏信誉怎么样| 百家乐投法| 六合彩公司| 网络百家乐官网软件真假| 百家乐几点开奖| 大发888 大发国际| 新2百家乐官网现金网百家乐官网现金网| 百家乐视频游戏官网| 大发888游戏论坛| 金臂百家乐官网开户送彩金| 至尊百家乐官网于波| 太阳城申博娱乐城| 百家乐官网十佳投庄闲法| 百家乐视频麻将下载| 456棋牌官网| 百家乐官网与21点| 如何打百家乐的玩法技巧和规则 | 中国百家乐官网游戏| 百家乐平台有什么优势| 凯斯娱乐城| 真人百家乐官网蓝盾| 单机百家乐小游戏| 大城县| 百家乐庄闲多少| a8娱乐城线上娱乐| 在线玩百家乐官网的玩法技巧和规则 | 网上的百家乐官网是真是假| 乐天堂百家乐赌场娱乐网规则| 社会| 澳门百家乐路子分析| 真人在线百家乐| 百家乐代理博彩正网| 豪博| 百家乐棋牌公式| 瑞博国际| 百家乐真人真钱| 圣淘沙娱乐| 桦甸市| 澳门百家乐现场游戏|