国产精品久久久久影院,成人午夜福利视频,国产精品久久久久高潮,国产精品 欧美 亚洲 制服,国产精品白浆无码流出

歷史上的今天

今天是:2025年01月31日(星期五)

2021年01月31日 | 講講Cortex-M內(nèi)核的MPU內(nèi)存保護(hù)單元

發(fā)布者:DreamyEclipse 來源: eefocus關(guān)鍵字:Cortex-M內(nèi)核  MPU  內(nèi)存保護(hù)單元 手機(jī)看文章 掃描二維碼
隨時(shí)隨地手機(jī)看文章

圖片


    估計(jì)大家經(jīng)??匆奙CU、MPU、MMU等這類縮寫詞,你們了解MPU嗎?


1寫在前面

不知道大家有沒有關(guān)注過Cortex-M內(nèi)核的一些內(nèi)容,在STM32大部分型號(hào)中都有MPU。


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

圖片

可能很多人都處于簡(jiǎn)單知道,或認(rèn)識(shí)MPU的階段,今天就寫點(diǎn)關(guān)于MPU的內(nèi)容,讓大家進(jìn)一步認(rèn)識(shí)和了解MPU。


2認(rèn)識(shí)MPU,及作用

MPU:Memory Protection Unit,內(nèi)存保護(hù)單元。


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


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

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

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

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

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

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


3了解野指針

上面簡(jiǎn)單認(rèn)識(shí)了一下MPU的功能,其實(shí)它有個(gè)重要的功能就是對(duì)指針訪問的內(nèi)存具有保護(hù)作用。所以,這里讓大家認(rèn)識(shí)一下指針和野指針。


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


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


---來自CM3內(nèi)核翻譯作者


4進(jìn)一步了解MPU

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


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


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


MPU可用于保護(hù)多達(dá)16個(gè)內(nèi)存區(qū)域。如果區(qū)域至少為256字節(jié),那么這些區(qū)域可以有8個(gè)子區(qū)域。子區(qū)域的大小總是相等的,可以通過子區(qū)域號(hào)啟用或禁用。因?yàn)樽钚^(qū)域大小是由緩存行長(zhǎng)度(32字節(jié))驅(qū)動(dòng)的,所以8個(gè)32字節(jié)的子區(qū)域?qū)?yīng)256字節(jié)大小。

圖片



5MPU學(xué)習(xí)資料

上面只是進(jìn)一步讓大家了解了MPU內(nèi)存保護(hù)單元,對(duì)于想要深入理解的朋友就需要參看更多相關(guān)資料。


對(duì)學(xué)習(xí)MPU編程,就需要對(duì)MPU相關(guān)寄存器進(jìn)行掌握,MPU的寄存器其實(shí)相對(duì)來說也不多,這里再Cotex-M內(nèi)核技術(shù)參考手冊(cè),以及STM32應(yīng)用筆記Managing memory protection unit (MPU) in STM32 MCUs、編程手冊(cè)中都有講述關(guān)于MPU的知識(shí)。


為方便大家,這里也簡(jiǎn)單說幾點(diǎn)。

1.STM32內(nèi)存映射

圖片


2.MPU 的寄存器組

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

圖片

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

特權(quán)級(jí)的程序代碼(如OS內(nèi)核和異常服務(wù)例程)

?用戶級(jí)的程序代碼

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

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

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

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

?常規(guī)外設(shè)區(qū),如UART, ADC等


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);

}


關(guān)鍵字:Cortex-M內(nèi)核  MPU  內(nèi)存保護(hù)單元 引用地址:講講Cortex-M內(nèi)核的MPU內(nèi)存保護(hù)單元

上一篇:定時(shí)器基本原理及常見問題
下一篇:STM32各系列MCU性能對(duì)比及測(cè)試說明

推薦閱讀

自從我們進(jìn)入了4G時(shí)代,各家手機(jī)廠商處理器新品發(fā)布會(huì)現(xiàn)場(chǎng)都會(huì)聽到支持全網(wǎng)通、x模x頻等等一系列與通信網(wǎng)絡(luò)有關(guān)的專有名詞,這些技術(shù)最主要來自手機(jī)中的一個(gè)名為基帶的芯片支持。那么什么是基帶芯片呢?什么是基帶?對(duì)于基帶一詞,想必很多網(wǎng)友都是耳熟能祥的東西,畢竟在“遠(yuǎn)古”時(shí)代的Android是可以隨意刷寫基帶,就像更新ROM一樣簡(jiǎn)單,刷入新基帶過后還...
一.內(nèi)存管理原理內(nèi)存管理,是指軟件運(yùn)行時(shí)對(duì)計(jì)算機(jī)內(nèi)存資源的分配和使用的技術(shù)。其最主要的目的是如何高效,快速的分配,并且在適當(dāng)?shù)臅r(shí)候釋放和回收內(nèi)存資源。內(nèi)存管理的實(shí)現(xiàn)方法有很多種,他們其實(shí)最終都是要實(shí)現(xiàn)2個(gè)函數(shù):malloc和free;malloc函數(shù)用于內(nèi)存申請(qǐng),free函數(shù)用于內(nèi)存釋放。我們介紹一種比較簡(jiǎn)單的辦法來實(shí)現(xiàn):分塊式內(nèi)存管理。下面我們介...
一、簡(jiǎn)介本文以STM8S103F3P6編程為例,介紹STM8S103F3P6定時(shí)器4計(jì)時(shí)驅(qū)動(dòng)PB5腳二、實(shí)驗(yàn)平臺(tái)電腦平臺(tái):Windows7 64位旗艦編譯軟件:IAR硬件平臺(tái):STM8S103F3P6三、版權(quán)聲明四、實(shí)驗(yàn)前提1、在進(jìn)行本文步驟前,請(qǐng)先安裝IAR EWSTM8-EV-1311版本;準(zhǔn)備好STM8S103F3P6硬件平臺(tái)。五、基礎(chǔ)知識(shí)暫無六、源碼地址暫無七、關(guān)聯(lián)文章鏈接:暫無八、實(shí)驗(yàn)內(nèi)容1.系統(tǒng)時(shí)鐘...
根據(jù)華為準(zhǔn)官方爆料微博 @長(zhǎng)安數(shù)碼君的消息,榮耀 Magic 系列旗下首款折疊屏手機(jī)將于今年發(fā)布。趙明曾表示,榮耀未來將推出超級(jí)旗艦,榮耀也會(huì)有榮耀的 “Mate 和 P”系列?,F(xiàn)在看來,榮耀的超級(jí)旗艦就是 Magic 折疊屏手機(jī),對(duì)標(biāo)的可能就是華為的 Mate X 系列了。華為 Mate X2折疊屏新機(jī)已經(jīng)入網(wǎng),新機(jī)尺寸為161.8×145.8×8.2mm,主屏尺寸為8.01...

史海拾趣

問答坊 | AI 解惑

常用電源設(shè)計(jì)技巧圖解

本文羅列了八個(gè)電源工程師常用的電源設(shè)計(jì)技巧。助您的設(shè)計(jì)一臂之力!…

查看全部問答∨

請(qǐng)問CDMA的代理服務(wù)器的IP是什么呢?

請(qǐng)問CDMA的代理服務(wù)器的IP是什么呢? 我用操作系統(tǒng)的撥號(hào)程序把CDMA的模塊撥上網(wǎng)后(建立PPP接連),在網(wǎng)絡(luò)正常的前提下(可用該連接瀏覽網(wǎng)頁),用TCP連各個(gè)可能的代理服務(wù)器IP(WAP代理服務(wù)器)都失敗?!?

查看全部問答∨

望各位高手給下意見,小弟剛學(xué)習(xí)匯編第3天寫出了如此令我迷茫的程序望各位指點(diǎn)一下?

若自block開始的內(nèi)存緩沖區(qū)有100個(gè)字節(jié),帶符號(hào)數(shù),需找出最大值將其存放在max單元中? 代碼如下      mov al,0; mov bl,1;                      ...…

查看全部問答∨

用vs2005開發(fā)的程序的打包問題

有一個(gè).exe文件,還有幾個(gè)文本文件,現(xiàn)在想打個(gè)包,不知道該怎么打 最好是那種可以和安裝程序一樣的,打開之后安裝,然后就可以使用啊 …

查看全部問答∨

怎么論壇頭頂?shù)娘w思卡廣告點(diǎn)不動(dòng)?

怎么論壇頭頂?shù)娘w思卡廣告點(diǎn)不動(dòng)?如下圖 [ 本帖最后由 vvv9876 于 2011-3-27 23:30 編輯 ]…

查看全部問答∨

【MSP430共享】基于無線通信的高壓電力電纜巡檢系統(tǒng)設(shè)計(jì)

傳統(tǒng)的現(xiàn)場(chǎng)總線監(jiān)控系統(tǒng)僅適合小范圍監(jiān)控,而對(duì)于大規(guī)模的高壓電力電纜監(jiān)測(cè)存在電纜敷設(shè)難、成本高、難以維護(hù)等問題;設(shè)計(jì)了一種新型電力電纜監(jiān)控系統(tǒng),系統(tǒng)利用低功耗數(shù)字溫度傳感器 TMP 1 0 0實(shí)現(xiàn)地下電纜接頭溫度采集,MS P 4 3 0 F I 4 9作為工 ...…

查看全部問答∨

定位一組數(shù)據(jù)中的最小值或最大值

現(xiàn)有并行輸入的8個(gè)數(shù)據(jù)。要找到其中的最大值和最小值,并給其定位,比較大小沒問題,關(guān)鍵是定位問題沒有解決,請(qǐng)大家?guī)蛶兔Γx謝…

查看全部問答∨

查找表(Look-Up-Table)的原理與結(jié)構(gòu)(FPGA

  一.查找表(Look-Up-Table)的原理與結(jié)構(gòu) 采用這種結(jié)構(gòu)的PLD芯片我們也可以稱之為FPGA:如altera的ACEX,APEX系列,xilinx的Spartan,Virtex系列等。 查找表(Look-Up-Table)簡(jiǎn)稱為L(zhǎng)UT,LUT本質(zhì)上就是一個(gè)RAM。 目前FPGA中多使用4輸入的LUT, ...…

查看全部問答∨

LM3S9B96 選擇μC/OS-II還是SAFERTOS,哪一個(gè)上手更快、資料更豐富?

9b96開發(fā)板內(nèi)部是移植好了SAFERTOS這個(gè)操作系統(tǒng)了么?關(guān)于在9B96上用操作系統(tǒng),μC/OS-II和SAFERTOS哪一個(gè)用的更多呢,或者哪一個(gè)的資料會(huì)更多點(diǎn)。。。 …

查看全部問答∨
小廣播
設(shè)計(jì)資源 培訓(xùn) 開發(fā)板 精華推薦

最新單片機(jī)文章

 
EEWorld訂閱號(hào)

 
EEWorld服務(wù)號(hào)

 
汽車開發(fā)圈

 
機(jī)器人開發(fā)圈

電子工程世界版權(quán)所有 京ICP證060456號(hào) 京ICP備10001474號(hào)-1 電信業(yè)務(wù)審批[2006]字第258號(hào)函 京公網(wǎng)安備 11010802033920號(hào) Copyright ? 2005-2025 EEWORLD.com.cn, Inc. All rights reserved