《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 其他 > 入門:為什么要使用MPU?MPU如何實現內存保護?

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

2023-02-26
來源:嵌入式專欄
關鍵詞: MPU 微處理器 RAM Flash

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

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

  MPU:Microprocessor Unit,微處理器

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

  嵌入式專欄

  1

  為什么要使用MPU?

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

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

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

217.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兩個任務不同的內存保護區域:

216.JPG

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

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

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

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

  4

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

  一個簡單的項目

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

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

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



更多信息可以來這里獲取==>>電子技術應用-AET<<

mmexport1621241704608.jpg

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 亚洲欧美日产综合在线看 | 日韩三级观看 | 日韩欧美精品综合一区二区三区 | 国产一区二区三区精品久久呦 | 全部免费的毛片视频观看 | 久久精品国产国产精品四凭 | 114一级毛片免费观看 | 日韩美女一级片 | 亚洲最黄视频 | 91精品久久久久亚洲国产 | 亚洲日韩中文字幕天堂不卡 | 韩国一级黄色大片 | 六月丁香久久丫 | 长腿嫩模打开双腿呻吟 | 国产欧美曰韩一区二区三区 | 国产精品亚洲四区在线观看 | 羞羞一区二区三区四区片 | 18在线 | a级性生活视频 | 久久99国产精一区二区三区! | 亚洲天堂男 | 九九99久久精品国产 | 日本一区二区三区不卡视频中文字幕 | 亚洲haose在线观看 | 精品视频免费在线观看 | 毛片中文字幕 | 亚洲在线网站 | 真正免费一级毛片在线播放 | 美国黑人特大一级毛片 | 天堂一区二区在线观看 | 呦女精品视频 | 美女视频永久黄网站免费观看国产 | 亚洲精品国产第一区二区三区 | 最新国产三级在线不卡视频 | 国产短视频精品一区二区三区 | 在线观看免费黄色网址 | 亚洲视频精品在线 | 中文字幕一区二区三区视频在线 | 国产v片成人影院在线观看 国产v片在线播放免费观 | 日韩精品在线一区 | 99视频免费观看 |