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

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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

為什么要使用MPU?MPU如何實(shí)現(xiàn)內(nèi)存保護(hù)?

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

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

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

MPU:Microprocessor Unit,微處理器

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

嵌入式專欄

1

為什么要使用MPU?

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

嵌入式系統(tǒng)中使用內(nèi)存保護(hù)單元(MPU)可以在開發(fā)早期及時(shí)發(fā)現(xiàn)因內(nèi)存而導(dǎo)致的Bug,節(jié)省更多開發(fā)時(shí)間。

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

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

也就是說,使用MPU,會(huì)避免因?yàn)樾薷囊粋€(gè)bug,而引起多個(gè)bug的情況(0生1,1生萬物)。

2

MPU如何實(shí)現(xiàn)內(nèi)存保護(hù)

簡單來說就是保護(hù)與當(dāng)前執(zhí)行的代碼不相關(guān)的所有數(shù)據(jù)。

RTOS任務(wù)A和B來說: 任務(wù)A和B不應(yīng)相互交互數(shù)據(jù),但是存在一個(gè)錯(cuò)誤,任務(wù)A可能會(huì)意外地寫入任務(wù)B偶爾使用的某些數(shù)據(jù),不會(huì)影響任務(wù)A的正確操作。但是,當(dāng)任務(wù)B嘗試使用損壞的數(shù)據(jù)時(shí),任務(wù)B可能會(huì)意外故障。

如果沒有配置MPU來阻止任務(wù)A寫入任務(wù)B的數(shù)據(jù),則該錯(cuò)誤可能需要很長的時(shí)間供開發(fā)人員跟蹤。如果錯(cuò)誤很小,或者如果任務(wù)B很少使用該數(shù)據(jù),則將很難解決該bug。但是,如果使用了MPU,則該bug就會(huì)及早被發(fā)現(xiàn)。

在某些體系結(jié)構(gòu)上,MPU甚至可以幫助你檢測NULL指針引用,因?yàn)槟憧梢栽O(shè)置MPU區(qū)域以防止非特權(quán)代碼訪問內(nèi)存0x0。

應(yīng)用程序中一組設(shè)計(jì)良好的MPU區(qū)域可以很好的保護(hù)重要的內(nèi)存區(qū)域,以防止出現(xiàn)特定的問題。

一個(gè)很好的例子是通過在MPU區(qū)域的末尾放置緩沖區(qū)來防止緩沖區(qū)溢出,你還可以將任務(wù)堆棧放置在任何非特權(quán)代碼都無法訪問的區(qū)域。如果這樣做,則每個(gè)任務(wù)必須使用自己的MPU區(qū)域之一來設(shè)置自己對自己的堆棧的訪問權(quán)限。

3

使用MPU的好處

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

使用的內(nèi)存保護(hù)單元(MPU)有很多優(yōu)勢,MPU通常允許你以特權(quán)或非特權(quán)模式運(yùn)行,并使用一組“區(qū)域”來確定當(dāng)前正在執(zhí)行的代碼是否具有訪問代碼和數(shù)據(jù)的權(quán)限。

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

在整個(gè)系統(tǒng)運(yùn)行時(shí)中,這些區(qū)域不必相同。MPU區(qū)域可以根據(jù)每個(gè)任務(wù)進(jìn)行修改,每個(gè)任務(wù)可以具有自己獨(dú)特的區(qū)域集,這些區(qū)域在任務(wù)移至運(yùn)行狀態(tài)時(shí)進(jìn)行配置。

這使你可以僅對需要代碼和數(shù)據(jù)的任務(wù)設(shè)置訪問權(quán)限,利用MPU的嵌入式操作系統(tǒng)將在每次上下文切換期間管理每個(gè)任務(wù)的區(qū)域和特權(quán)級別。

比如設(shè)置RTOS兩個(gè)任務(wù)不同的內(nèi)存保護(hù)區(qū)域:

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

上面這張圖,大家都能看懂吧?Flash和內(nèi)存區(qū)域被分別設(shè)置保護(hù)。

兩個(gè)全局保護(hù)區(qū)域:Flash開頭、RAM開頭;

在Flash中,一部分僅限任務(wù)1訪問,這部分不能被任務(wù)訪問;同時(shí),在Flash另外區(qū)域,僅限任務(wù)2訪問,不能被任務(wù)1訪問。如果這兩部分區(qū)域被對方訪問,則會(huì)生成生成MPU故障。

在RAM區(qū)域,同一部分區(qū)域,一個(gè)只能被讀,一個(gè)只能被寫入,如果不按約定操作,同樣也會(huì)生產(chǎn)MPU故障。

4

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

一個(gè)簡單的項(xiàng)目

一個(gè)對性能至關(guān)重要的項(xiàng)目

第1個(gè)很簡單:一個(gè)非常簡單的應(yīng)用程序基本上沒必要使用MPU,反而增加了系統(tǒng)的復(fù)雜性。不設(shè)置內(nèi)存保護(hù),RAM和外圍設(shè)備的MPU區(qū)域,你自己一眼就能找到bug。

第2個(gè)對性能要求高的項(xiàng)目,在上下文切換時(shí),設(shè)置內(nèi)存保護(hù),堆棧那些操作,有可能影響系統(tǒng)的實(shí)時(shí)性,從而導(dǎo)致系統(tǒng)異常。這個(gè)需要結(jié)合項(xiàng)目實(shí)際情況考慮用,還是不用MPU功能。




審核編輯:劉清

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

    關(guān)注

    10

    文章

    1623

    瀏覽量

    147781
  • RAM
    RAM
    +關(guān)注

    關(guān)注

    8

    文章

    1367

    瀏覽量

    114541
  • 微處理器
    +關(guān)注

    關(guān)注

    11

    文章

    2247

    瀏覽量

    82330
  • MPU
    MPU
    +關(guān)注

    關(guān)注

    0

    文章

    348

    瀏覽量

    48738

原文標(biāo)題:好文推薦| MPU如何實(shí)現(xiàn)內(nèi)存保護(hù)?

文章出處:【微信號:麥克泰技術(shù),微信公眾號:麥克泰技術(shù)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    管理STM32 MCU中的內(nèi)存保護(hù)單元

    本應(yīng)用筆記介紹如何管理 STM32 產(chǎn)品中的內(nèi)存保護(hù)單元(MPU)。MPU 是用于存儲(chǔ)器保護(hù)的可選組件。STM32 微控制器(MCU)中嵌入 MPU
    發(fā)表于 12-23 11:04 ?1036次閱讀

    為什么要使MPUMPU實(shí)現(xiàn)內(nèi)存保護(hù)原理分析

    簡單來說就是保護(hù)與當(dāng)前執(zhí)行的代碼不相關(guān)的所有數(shù)據(jù)。 拿RTOS任務(wù)A和B來說: 任務(wù)A和B不應(yīng)相互交互數(shù)據(jù),但是存在一個(gè)錯(cuò)誤,任務(wù)A可能會(huì)意外地寫入任務(wù)B偶爾使用的某些數(shù)據(jù),不會(huì)影響任務(wù)A的正確操作。
    發(fā)表于 02-23 09:17 ?1714次閱讀

    【安富萊】【μCOS-III教程】第6章 內(nèi)存保護(hù)單元MPU

    第6章內(nèi)存保護(hù)單元MPU本期教程帶領(lǐng)大家學(xué)習(xí)內(nèi)存保護(hù)單元MPU的使用,在前面的幾期教程中曾多次的提到MPU的使用,
    發(fā)表于 01-08 18:04

    主要講armv7-m架構(gòu)下的MPU內(nèi)存保護(hù)單元

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

    Armv8-M內(nèi)存模型與內(nèi)存保護(hù)用戶指南

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

    如何管理STM32產(chǎn)品中的內(nèi)存保護(hù)單元(MPU

    本應(yīng)用筆記介紹如何管理 STM32 產(chǎn)品中的內(nèi)存保護(hù)單元(MPU)。MPU 是用于存儲(chǔ)器保護(hù)的可選組件。STM32 微控制器(MCU)中嵌入 MPU
    發(fā)表于 09-07 06:23

    MPU是什么Cortex-M內(nèi)核的MPU內(nèi)存保護(hù)單元詳細(xì)講解

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

    Cortex-M內(nèi)核的MPU內(nèi)存保護(hù)單元

    講講Cortex-M內(nèi)核的MPU內(nèi)存保護(hù)單元
    的頭像 發(fā)表于 03-04 11:17 ?3627次閱讀
    Cortex-M內(nèi)核的<b class='flag-5'>MPU</b><b class='flag-5'>內(nèi)存保護(hù)</b>單元

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

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

    Cortex-M內(nèi)核的MPU內(nèi)存保護(hù)單元

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

    什么是Cortex-M內(nèi)核的MPU內(nèi)存保護(hù)單元)?

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

    為什么要使MPUMPU如何實(shí)現(xiàn)內(nèi)存保護(hù)

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

    如何管理STM32產(chǎn)品中的MPU

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

    什么是MPUMPU在哪些方面保護(hù)內(nèi)存安全?

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

    如何管理STM32產(chǎn)品中的內(nèi)存保護(hù)單元(MPU)

    電子發(fā)燒友網(wǎng)站提供《如何管理STM32產(chǎn)品中的內(nèi)存保護(hù)單元(MPU).pdf》資料免費(fèi)下載
    發(fā)表于 08-01 09:15 ?0次下載
    如何管理STM32產(chǎn)品中的<b class='flag-5'>內(nèi)存保護(hù)</b>單元(<b class='flag-5'>MPU</b>)