亚洲av成人精品日韩一区,97久久久精品综合88久久,玩弄japan白嫩少妇hd,亚洲av片不卡无码久久,玩弄人妻少妇500系列

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

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

3天內不再提示

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

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來源:未知 ? 2019-02-03 09:30 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

估計大家經(jīng)常看見MCU、MPU、MMU等這類縮寫詞,你們了解MPU嗎?

1寫在前面

不知道大家有沒有關注過Cortex-M內核的一些內容,在STM32大部分型號中都有MPU。

MPU是Cortex-M的選配件,拿STM32F1來說,STM32F10X_XL系列的芯片才具有這個MPU存儲保護單元,而其他STM32F1芯片沒有。

可能很多人都處于簡單知道,或認識MPU的階段,今天就寫點關于MPU的內容,讓大家進一步認識和了解MPU。

2

認識MPU,及作用

MPU:Memory Protection Unit,內存保護單元。

MPU存儲器保護單元,它可以實施對存儲器(主要是內存和外設寄存器)的保護,以使軟件更加健壯和可靠。在使用前,必須根據(jù)需要對其編程。如果沒有啟用MPU,則等同于系統(tǒng)中沒有配MPU。

MPU有如下的能力可以提高系統(tǒng)的可靠性:

阻止用戶應用程序破壞操作系統(tǒng)使用的數(shù)據(jù)。

阻止一個任務訪問其它任務的數(shù)據(jù)區(qū),從而把任務隔開。

可以把關鍵數(shù)據(jù)區(qū)設置為只讀,從根本上消除了被破壞的可能。

檢測意外的存儲訪問,如,堆棧溢出,數(shù)組越界。

此外,還可以通過MPU設置存儲器regions的其它訪問屬性,比如,是否緩區(qū),是否緩沖等。

3

了解野指針

上面簡單認識了一下MPU的功能,其實它有個重要的功能就是對指針訪問的內存具有保護作用。所以,這里讓大家認識一下指針和野指針。

回顧一下, 什么是指針?指針在內存中實際上是一個無符號整數(shù)(unsigned int),但是它的值被賦予特殊的解釋:表示變量或函數(shù)的地址。所以才被形象地稱為“指針”,就好像指向誰家似的。 在使用指針前, 都必須先讓它指向有意義的, 并且允許由程序使用的實體——數(shù)據(jù)和代碼。 而所謂“野指針”, 就是指某個指針變量的值因故超出合法的范圍, 使其“槍口” 亂指。 程序邏輯錯誤、 數(shù)組越界、 堆棧溢出、 指針未經(jīng)初始化、 對緩存與緩沖的處理不當、 多任務環(huán)境中的紊亂條件, 甚至是惡意地破壞等, 都可以制造出野指針。 如果使用野指針去讀取或修改內存, 則被讀取或修改的位置是不可預料的。 前者導致讀回來的都是亂掉的數(shù)據(jù), 后者則會破壞未知用途的數(shù)據(jù)。 這常常導致系統(tǒng)發(fā)生莫名其妙的功能紊亂, 嚴重時會使系統(tǒng)毫無征兆,沒有理由地失控、死機。

野指針就像“肉里的刺, 醬里的蛆” 一般: 一個野指針就足以毀掉整個系統(tǒng), 而且極其隱蔽, 很難通過癥狀來找出是哪里存在野指針, 甚至都不能判定癥狀是否因野指針造成(程序大了其它 bug 也很多,并且也能導致相同的癥狀)。對于通常的單片機系統(tǒng),是沒有任何辦法來防止野指針的破壞的, 完全靠程序員的素質和自律。 但智者千慮, 必有一失。 尤其是當程序規(guī)模變得很大時,復雜度會呈指數(shù)上升,千頭萬緒糾纏不清, 就算是謹慎如諸葛亮,聰明如比爾?蓋茨的天才,也不敢保證沒有漏網(wǎng)之魚。

---來自CM3內核翻譯作者

4

進一步了解MPU

MPU在執(zhí)行其功能時,是以所謂的“region區(qū)域”為單位的。一個region其實就是一段連續(xù)的地址,只是它們的位置和范圍都要滿足一些限制(對齊方式,最小容量等)。

CM3的MPU共支持8個regions,還允許把每個region進一步劃分成更小的“子region”。此外,還允許啟用一個“背景region”(即沒有MPU時的全部地址空間),不過它是只能由特權級享用。在啟用MPU后,就不得再訪問定義之外的地址區(qū)間,也不得訪問未經(jīng)授權的region。否則,將以“訪問違例”處理,觸發(fā)MemManage fault。

MPU定義的regions可以相互交迭。如果某塊內存落在多個region中,則訪問屬性和權限將由編號最大的region來決定。比如,若1號region與4號region交迭,則交迭的部分受4號region控制。

MPU可用于保護多達16個內存區(qū)域。如果區(qū)域至少為256字節(jié),那么這些區(qū)域可以有8個子區(qū)域。子區(qū)域的大小總是相等的,可以通過子區(qū)域號啟用或禁用。因為最小區(qū)域大小是由緩存行長度(32字節(jié))驅動的,所以8個32字節(jié)的子區(qū)域對應256字節(jié)大小。

5

MPU學習資料

上面只是進一步讓大家了解了MPU內存保護單元,對于想要深入理解的朋友就需要參看更多相關資料。

對學習MPU編程,就需要對MPU相關寄存器進行掌握,MPU的寄存器其實相對來說也不多,這里再Cotex-M內核技術參考手冊,以及STM32應用筆記Managing memory protection unit (MPU) in STM32 MCUs、編程手冊中都有講述關于MPU的知識。

為方便大家,這里也簡單說幾點。

1.STM32內存映射

2.MPU 的寄存器組

操作MPU是就如操作普通STM32外設一樣,通過訪問它的若干寄存器來實現(xiàn)的,MPU寄存器如下表所示。

MPU寄存器看起來比較復雜,那是自然了,畢竟已經(jīng)上升到存儲器管理的高度。但如果我們胸有成竹——已經(jīng)想好了對存儲器如何劃分,這就只是一些繁瑣和考驗細心的體力活。典型情況下,在啟用MPU的系統(tǒng)中,都會有下列的regions。

特權級的程序代碼(如OS內核和異常服務例程)

?用戶級的程序代碼

?特權級程序的數(shù)據(jù)存儲器,位于代碼區(qū)中(data_stack)

?用戶級程序的數(shù)據(jù)存儲器,位于代碼區(qū)中(data_stack)

?通用的數(shù)據(jù)存儲器,位于其它存儲器區(qū)域中(如, SRAM

?系統(tǒng)設備區(qū),只允許特權級訪問,如NVIC和MPU的寄存器所有的地址區(qū)間

?常規(guī)外設區(qū),如UARTADC

3.Cube HAL配置MPU例子

void MPU_RegionConfig(void) { MPU_Region_InitTypeDef MPU_InitStruct; /* Disable MPU */ HAL_MPU_Disable(); /* Configure RAM region as Region N°0, 8kB of size and R/W region */ MPU_InitStruct.Enable = MPU_REGION_ENABLE; MPU_InitStruct.BaseAddress = 0x20000000; MPU_InitStruct.Size = MPU_REGION_SIZE_8KB; MPU_InitStruct.AccessPermission = MPU_REGION_FULL_ACCESS; MPU_InitStruct.IsBufferable = MPU_ACCESS_NOT_BUFFERABLE; MPU_InitStruct.IsCacheable = MPU_ACCESS_CACHEABLE; MPU_InitStruct.IsShareable = MPU_ACCESS_SHAREABLE; MPU_InitStruct.Number = MPU_REGION_NUMBER0; MPU_InitStruct.TypeExtField = MPU_TEX_LEVEL0; MPU_InitStruct.SubRegionDisable = 0x00; MPU_InitStruct.DisableExec = MPU_INSTRUCTION_ACCESS_ENABLE; HAL_MPU_ConfigRegion(&MPU_InitStruct); /* Configure FLASH region as REGION N°1, 1MB of size and R/W region */ MPU_InitStruct.BaseAddress = 0x08000000; MPU_InitStruct.Size = MPU_REGION_SIZE_1MB; MPU_InitStruct.IsShareable = MPU_ACCESS_NOT_SHAREABLE; MPU_InitStruct.Number = MPU_REGION_NUMBER1; HAL_MPU_ConfigRegion(&MPU_InitStruct); /* Configure FMC region as REGION N°2, 0.5GB of size, R/W region */ MPU_InitStruct.BaseAddress = 0x60000000; MPU_InitStruct.Size = MPU_REGION_SIZE_512MB; MPU_InitStruct.IsShareable = MPU_ACCESS_SHAREABLE; MPU_InitStruct.Number = MPU_REGION_NUMBER2; HAL_MPU_ConfigRegion(&MPU_InitStruct); /* Enable MPU */ HAL_MPU_Enable(MPU_PRIVILEGED_DEFAULT); }

想要了解更多MPU的內容,可參考CM3技術手冊,以及STM32應用手冊和編程手冊。

近期活動

1、RT-Thread_Nano 3.0.3 內核實戰(zhàn)教程:請在公眾號后臺,回復“內核實戰(zhàn)”即可獲得下載鏈接。

2、《RT-Thread內核實現(xiàn)與應用開發(fā)實戰(zhàn)指南》基于STM32完整電子版下載:在公眾號后臺回復"野火RT-Thread"即可。

3、深圳開發(fā)者大會資料下載:2018深圳開發(fā)者大會-PPT及線下培訓資料下載,請在公眾號后臺回復關鍵詞“深圳開發(fā)者大會”,請勿錯字、漏字、多打空格,否則系統(tǒng)無法識別。

-RT-Thread新版文檔中心,資料更豐富-

https://www.rt-thread.org/document/site/

(請將鏈接復制至外部瀏覽器打開)

你可以添加微信13924608367為好友,注明:公司+姓名,拉進 RT-Thread 官方微信交流群

RT-Thread

物聯(lián)網(wǎng)終端的開發(fā)變得簡單、快速,芯片的價值得到最大化發(fā)揮。Apache2.0協(xié)議,可免費在商業(yè)產(chǎn)品中使用,不需要公布源碼,無潛在商業(yè)風險。

長按二維碼,關注我們

點“閱讀原文” 進入RT-Thread新版文檔中心

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

    關注

    2293

    文章

    11032

    瀏覽量

    364781
  • MPU
    MPU
    +關注

    關注

    0

    文章

    415

    瀏覽量

    49907
  • Cortex-M
    +關注

    關注

    2

    文章

    231

    瀏覽量

    30381

原文標題:講講Cortex-M內核的MPU內存保護單元

文章出處:【微信號:RTThread,微信公眾號:RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

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

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

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

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

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

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

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

    本指南概述了Armv8-M內存模型和內存保護單元(MPU)在Cortex-M處理器中實現(xiàn)。本指南
    發(fā)表于 08-02 08:12

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

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

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

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

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

    代碼訪問其指定區(qū)域以外的內存或外設,而且還可以用于檢測堆棧溢出。 我們基于ARM Cortex-M MCU中的MPU,討論一下MPU所提供的一些特性。
    的頭像 發(fā)表于 07-19 09:47 ?7813次閱讀

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

    估計大家經(jīng)??匆奙CU、MPU、MMU等這類縮寫詞,你們了解MPU嗎?1寫在前面不知道大家有沒有關注過Cortex-M內核的一些內容,在STM32大部分型號中都有
    發(fā)表于 12-01 12:21 ?9次下載
    <b class='flag-5'>Cortex-M</b><b class='flag-5'>內核</b>的<b class='flag-5'>MPU</b><b class='flag-5'>內存保護</b><b class='flag-5'>單元</b>

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

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

    FreeRTOS-MPU特性說明

    MPU(Memory Protection Unit,內存保護單元)在 Cortex-M內核中是可選模塊,帶
    的頭像 發(fā)表于 06-22 14:05 ?3031次閱讀

    為什么要使用MPU?MPU如何實現(xiàn)內存保護?

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

    應用筆記|管理STM32 MCU中的內存保護單元

    內存保護單元MPU)。MPU 是用于存儲器保護的可選組件。STM32 微控制器(MCU)中嵌入 MP
    的頭像 發(fā)表于 12-21 21:05 ?1444次閱讀

    為什么要使用MPUMPU如何實現(xiàn)內存保護?

    如果你開發(fā)的嵌入式項目,因內存溢出,或者內存故障等一些原因,造成了重大經(jīng)濟損失,或者造成了重大事故,你就能體會為什么要使用內存保護單元MPU
    的頭像 發(fā)表于 02-24 11:59 ?3045次閱讀

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

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

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

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