亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

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

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

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

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

黃工的嵌入式技術(shù)圈 ? 來(lái)源:黃工的嵌入式技術(shù)圈 ? 2020-03-04 11:17 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

估計(jì)大家經(jīng)??匆?jiàn)MCU、MPU、MMU等這類縮寫(xiě)詞,你們了解MPU嗎?

1寫(xiě)在前面

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

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

可能很多人都處于簡(jiǎn)單知道,或認(rèn)識(shí)MPU的階段,今天就寫(xiě)點(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ì)其編程。如果沒(méi)有啟用MPU,則等同于系統(tǒng)中沒(méi)有配MPU。

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

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

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

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

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

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

3

了解野指針

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

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

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

---來(lái)自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”(即沒(méi)有MPU時(shí)的全部地址空間),不過(guò)它是只能由特權(quán)級(jí)享用。在啟用MPU后,就不得再訪問(wèn)定義之外的地址區(qū)間,也不得訪問(wèn)未經(jīng)授權(quán)的region。否則,將以“訪問(wèn)違例”處理,觸發(fā)MemManage fault。

MPU定義的regions可以相互交迭。如果某塊內(nèi)存落在多個(gè)region中,則訪問(wèn)屬性和權(quán)限將由編號(hào)最大的region來(lái)決定。比如,若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ū)域的大小總是相等的,可以通過(guò)子區(qū)域號(hào)啟用或禁用。因?yàn)樽钚^(qū)域大小是由緩存行長(zhǎng)度(32字節(jié))驅(qū)動(dòng)的,所以8個(gè)32字節(jié)的子區(qū)域?qū)?yīng)256字節(jié)大小。

5

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

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

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

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

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

2.MPU 的寄存器組

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

MPU寄存器看起來(lái)比較復(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í)訪問(wèn),如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);}

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

    關(guān)注

    147

    文章

    18496

    瀏覽量

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

    關(guān)注

    0

    文章

    440

    瀏覽量

    50919
  • MMU
    MMU
    +關(guān)注

    關(guān)注

    0

    文章

    92

    瀏覽量

    19081
  • Cortex-M
    +關(guān)注

    關(guān)注

    2

    文章

    234

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    RTThread支持內(nèi)存保護(hù)功能嗎?

    以前在其他視頻里看過(guò)說(shuō)單片機(jī)可以實(shí)現(xiàn)線程崩潰不會(huì)影響系統(tǒng)運(yùn)行, 我一直不知道怎么實(shí)現(xiàn)的, 最近了解到 MPU和Zephyr的內(nèi)存保護(hù), 這些在RTthread中可以實(shí)現(xiàn)嗎
    發(fā)表于 10-14 07:14

    如何從 MCU/MPU 角度保護(hù)物聯(lián)網(wǎng)應(yīng)用?

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

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

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

    M453 支持 MPU 嗎?

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

    請(qǐng)問(wèn)NuMicro? Cortex-M? 系列芯片是否支持 I2C 監(jiān)視器功能?

    NuMicro? Cortex-M? 系列芯片是否支持 I2C 監(jiān)視器功能?
    發(fā)表于 08-21 06:04

    RZ/T2H MPU數(shù)據(jù)手冊(cè)和產(chǎn)品介紹#集成了強(qiáng)大的應(yīng)用處理能力和精確的實(shí)時(shí)控制功能

    。Renesas Electronics RZ/T2H MPU具有多達(dá)四個(gè)ARM? Cortex?-A55內(nèi)核(運(yùn)行頻率為1.2GHz)和兩個(gè)ARM Cortex-R52
    的頭像 發(fā)表于 05-21 10:24 ?793次閱讀
    RZ/T2H <b class='flag-5'>MPU</b>數(shù)據(jù)手冊(cè)和產(chǎn)品介紹#集成了強(qiáng)大的應(yīng)用處理能力和精確的實(shí)時(shí)控制功能

    HOLTEK推出全新單片機(jī)HT32F49041

    內(nèi)存保護(hù)單元(MPU),增強(qiáng)數(shù)值運(yùn)算效能與應(yīng)用安全性。該單片機(jī)具備多種節(jié)能模式,特別適合各應(yīng)用場(chǎng)景諸如嵌入式系統(tǒng)、計(jì)算機(jī)周邊、工業(yè)自動(dòng)化、電機(jī)控制、物聯(lián)網(wǎng)、消費(fèi)性電子等領(lǐng)域,為Cortex-
    的頭像 發(fā)表于 05-10 10:43 ?1400次閱讀

    瑞薩RA8快速上手指南:Cortex-M85內(nèi)核瑞薩RA8開(kāi)發(fā)環(huán)境搭建 并點(diǎn)亮一個(gè)LED

    因?yàn)?b class='flag-5'>Cortex-M內(nèi)核,瑞薩RA8系列單片機(jī)支持多種市面上常見(jiàn)的開(kāi)發(fā)環(huán)境,像Keil MDK、IAR EWARM等,而本文講述的是瑞薩自家官方的IDE(e2 studio)。
    的頭像 發(fā)表于 03-17 14:35 ?1428次閱讀
    瑞薩RA8快速上手指南:<b class='flag-5'>Cortex-M</b>85<b class='flag-5'>內(nèi)核</b>瑞薩RA8開(kāi)發(fā)環(huán)境搭建 并點(diǎn)亮一個(gè)LED

    可實(shí)現(xiàn)工業(yè) AC Servo 和控制器高速處理的多功能 MPU RZ/T2M 數(shù)據(jù)手冊(cè)

    ? Cortex?-R52 內(nèi)核,可進(jìn)行實(shí)時(shí)控制,而且還擁有能夠與 CPU 直接連接的大容量緊密耦合內(nèi)存(576KB),以實(shí)現(xiàn)高性能實(shí)時(shí)處理。 此外,它還可以將電機(jī)控制的外設(shè)布置到能直接連接至 CPU
    的頭像 發(fā)表于 03-14 15:39 ?789次閱讀
    可實(shí)現(xiàn)工業(yè) AC Servo 和控制器高速處理的多功能 <b class='flag-5'>MPU</b> RZ/T2<b class='flag-5'>M</b> 數(shù)據(jù)手冊(cè)

    東芝推出七款基于Arm Cortex-M4內(nèi)核的32位微控制器

    東芝電子元件及存儲(chǔ)裝置株式會(huì)社(“東芝”)宣布,最新推出七款配備Cortex-M4內(nèi)核的32位微控制器,進(jìn)一步擴(kuò)大其電機(jī)控制微控制器產(chǎn)品線。其中,六款產(chǎn)品組成新的產(chǎn)品組合——M4K組(1)[1],另外一款產(chǎn)品加入
    的頭像 發(fā)表于 01-22 18:05 ?1227次閱讀
    東芝推出七款基于Arm <b class='flag-5'>Cortex-M</b>4<b class='flag-5'>內(nèi)核</b>的32位微控制器

    MPU的性能評(píng)估方法

    MPU(Microprocessor Unit,微處理器單元)的性能評(píng)估是確保其在實(shí)際應(yīng)用中能夠滿足需求的重要環(huán)節(jié)。以下是一些常用的MPU性能評(píng)估方法: 一、基準(zhǔn)測(cè)試(Benchmark
    的頭像 發(fā)表于 01-08 09:39 ?1189次閱讀

    MPU與數(shù)字信號(hào)處理的關(guān)系

    ,特別是在音頻、視頻和通信領(lǐng)域。 MPU的定義與功能 微處理器單元MPU)是一種集成電路,它集成了中央處理單元(CPU)、內(nèi)存、輸入/輸出
    的頭像 發(fā)表于 01-08 09:29 ?941次閱讀

    MPU與MCU的區(qū)別

    和應(yīng)用上存在顯著差異。 MPU與MCU的定義 微處理器單元MPU) : MPU是一種通用的中央處理單元,它主要設(shè)計(jì)用于執(zhí)行復(fù)雜的計(jì)算任務(wù)。
    的頭像 發(fā)表于 01-08 09:25 ?2377次閱讀

    如何使用Ozone分析Cortex-M異常

    Ozone可以幫助用戶快速分析和查找導(dǎo)致CPU故障的軟件bug。本文解釋如何使用Ozone的調(diào)試功能,深入了解Cortex-M架構(gòu)上的這些錯(cuò)誤。
    的頭像 發(fā)表于 11-29 11:14 ?2318次閱讀
    如何使用Ozone分析<b class='flag-5'>Cortex-M</b>異常

    兆易創(chuàng)新推出基于Arm Cortex-M33內(nèi)核的GD32G5系列高性能微控制器

    近日,業(yè)界領(lǐng)先的半導(dǎo)體器件供應(yīng)商兆易創(chuàng)新GigaDevice (股票代碼 603986) 宣布,正式推出基于Arm Cortex-M33內(nèi)核的GD32G5系列高性能微控制器。
    的頭像 發(fā)表于 11-13 17:24 ?2345次閱讀
    兆易創(chuàng)新推出基于Arm <b class='flag-5'>Cortex-M</b>33<b class='flag-5'>內(nèi)核</b>的GD32G5系列高性能微控制器