91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

3天內不再提示

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

strongerHuang ? 來源:strongerHuang ? 作者:strongerHuang ? 2022-07-05 17:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

MPU:Microprocessor Unit,微處理器;

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

為什么要使用MPU?

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

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

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

MPU如何實現內存保護

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

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

使用MPU的好處

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

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

pYYBAGLEBxWACXZ-AAEJCMxikdA848.jpg

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

什么時候不使用MPU?

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

一個簡單的項目

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

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

審核編輯:劉清

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

    關注

    11

    文章

    2431

    瀏覽量

    85835
  • MPU
    MPU
    +關注

    關注

    0

    文章

    454

    瀏覽量

    51321
  • RTOS
    +關注

    關注

    25

    文章

    866

    瀏覽量

    122975

原文標題:為什么RTOS系統(tǒng)要使用MPU?

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    RZ/T2M MPU:工業(yè)控制與自動化應用的理想之選

    RZ/T2M MPU:工業(yè)控制與自動化應用的理想之選 在當今的工業(yè)控制與自動化領域,對高性能、高可靠性微處理器單元(MPU)的需求日益增長。Renesas Electronics的RZ/T2M
    的頭像 發(fā)表于 12-29 16:30 ?400次閱讀

    RZ/N2L MPU:高性能與多功能的完美融合

    RZ/N2L MPU:高性能與多功能的完美融合 在電子工程師的世界里,不斷尋找高性能、多功能且穩(wěn)定可靠的微處理器單元(MPU)是一項持續(xù)的追求。今天,我們就來深入探討一下瑞薩電子的RZ/N2L
    的頭像 發(fā)表于 12-29 16:15 ?275次閱讀

    盟通科技基于瑞薩RZ MPU的EtherCAT主站應用方案

    瑞薩電子攜手盟通科技推出基于瑞薩RZ MPU的EtherCAT主站應用方案,為工業(yè)機器人、伺服驅動、PLC和自動化控制設備等應用場景提供完整易用的支持。
    的頭像 發(fā)表于 11-21 10:31 ?1159次閱讀
    盟通科技基于瑞薩RZ <b class='flag-5'>MPU</b>的EtherCAT主站應用方案

    CW32A系列(車規(guī)級 MCU)介紹

    加密、內存保護單元(MPU)、看門狗定時器。 典型應用:車身控制模塊(BCM)、車載傳感器、動力電池管理(BMS)、ADAS 輔助駕駛。
    發(fā)表于 11-17 06:30

    RTThread支持內存保護功能嗎?

    以前在其他視頻里看過說單片機可以實現線程崩潰不會影響系統(tǒng)運行, 我一直不知道怎么實現的, 最近了解到 MPU和Zephyr的內存保護, 這些在RTthread中可以
    發(fā)表于 10-14 07:14

    如何從 MCU/MPU 角度保護物聯(lián)網應用?

    如何從 MCU/MPU 角度保護物聯(lián)網應用?
    發(fā)表于 09-08 07:33

    邊聊安全 | 功能安全開發(fā)之MPU

    上海磐時PANSHI“磐時,做汽車企業(yè)的安全智庫”功能安全開發(fā)之MPU寫在前面:在與從事功能安全開發(fā)行業(yè)的同事以及SASETECH社區(qū)的成員討論時,筆者經常被問及有關芯片內存保護單元(MPU
    的頭像 發(fā)表于 09-05 16:21 ?2509次閱讀
    邊聊安全 | 功能安全開發(fā)之<b class='flag-5'>MPU</b>

    M453 支持 MPU 嗎?

    M453 支持 MPU 嗎?如果是這樣,如何啟用它?
    發(fā)表于 08-28 06:37

    如何使用 SPI 全雙工在兩個 5LP MPU 之間連接 RAM?

    我需要將兩個 5LP MPU 連接在一起以鏡像兩個 5LP MPU 內的 RAM。 我認為這將是 DMA 的一個功能,但我不確定如何實現該功能。 我的主 SPI 單元將向從屬 MPU
    發(fā)表于 07-15 06:20

    瑞薩RZ/A3M HMI MPU介紹

    對于高質量圖形顯示的應用要求,用戶通常采用功能強大及搭載DDR高速接口的MPU實現更多功能和更流暢的畫面。但在開發(fā)過程會遇到DDR高速總線設計的難題,同時Linux系統(tǒng)難以實現類似MCU的快速啟動性能。瑞薩新推出的RZ/A3M
    的頭像 發(fā)表于 05-27 16:14 ?1090次閱讀
    瑞薩RZ/A3M HMI <b class='flag-5'>MPU</b>介紹

    邊緣AI MPU深度盤點:品牌、型號與技術特性全解析

    邊緣AI MPU深度盤點:品牌、型號與技術特性全解析 隨著邊緣計算與人工智能的深度融合,邊緣AI MPU(微處理器)已成為支撐物聯(lián)網、智能制造、自動駕駛等場景的核心硬件。本文從品牌、型號、技術特性
    的頭像 發(fā)表于 04-30 17:27 ?4111次閱讀

    MPU-6000和MPU-6050產品規(guī)格書

    電子發(fā)燒友網站提供《MPU-6000和MPU-6050產品規(guī)格書.pdf》資料免費下載
    發(fā)表于 04-29 16:52 ?3次下載

    SEGGER發(fā)布下一代安全實時操作系統(tǒng)embOS-Ultra-MPU

    2025年3月,SEGGER發(fā)布滿足周期定時分辨率要求的下一代安全實時操作系統(tǒng)embOS-Ultra-MPU,該系統(tǒng)基于成熟的embOS-Classic-MPU和embOS-Ultra操作系統(tǒng)構建。
    的頭像 發(fā)表于 03-31 14:56 ?1335次閱讀

    通過EtherCAT實現高速、高精度實時控制的高性能MPU RZ/T2L數據手冊

    RZ/T2L 是一款高性能 MPU,可通過 EtherCAT 實現高速、高精度的實時控制。 RZ/T2L 搭載最大頻率為 800MHz 的 Arm? Cortex?-R52 內核以及與 CPU 緊密
    的頭像 發(fā)表于 03-14 15:07 ?1026次閱讀
    通過EtherCAT<b class='flag-5'>實現</b>高速、高精度實時控制的高性能<b class='flag-5'>MPU</b> RZ/T2L數據手冊

    關于mpu6050問題

    我很早之前買了一個,我現在使用這個mpu6050,我在調mpu6050數據時候,數據抖動特別大,我沒動這個mpu6050,它自己都有抖動,然后本來放在水平,他的機械中值是2.5,但是我水平抖動后,機械中值突然變成了-258,這是
    發(fā)表于 03-09 17:17