<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          關(guān) 閉

          新聞中心

          EEPW首頁(yè) > 工控自動(dòng)化 > 設(shè)計(jì)應(yīng)用 > 一種提高μC/OS-II操作系統(tǒng)安全性與穩(wěn)定性的方法

          一種提高μC/OS-II操作系統(tǒng)安全性與穩(wěn)定性的方法

          作者: 時(shí)間:2011-03-22 來(lái)源:網(wǎng)絡(luò) 收藏

          摘要:通過(guò)分析μC/,利用Cortex-M3內(nèi)核上配置的MPU(Memory Protection Unit,存儲(chǔ)器保護(hù)單元),把內(nèi)存劃分為特權(quán)級(jí)與用戶(hù)級(jí)兩個(gè)區(qū)。對(duì)移植到內(nèi)核上的μC/實(shí)時(shí)進(jìn)行改進(jìn)與優(yōu)化,使與用戶(hù)任務(wù)在不同的訪問(wèn)等級(jí)下運(yùn)行,并且使用不同的堆棧指針,以提高系統(tǒng)的。
          關(guān)鍵詞:μC/;Cortex-M3;存儲(chǔ)器保護(hù)單元;;

          引言
          μC/OS-II是基于優(yōu)先級(jí)的可剝奪型內(nèi)核,實(shí)時(shí)性較強(qiáng),但不區(qū)分用戶(hù)空間和系統(tǒng)空間,使得系統(tǒng)的安全性變差。而μC/OS-II官網(wǎng)提供的基于Cortex-M3內(nèi)核移植的μC/OS-II操作系統(tǒng),一直運(yùn)行在特權(quán)級(jí)下,用戶(hù)程序也可以訪問(wèn)操作系統(tǒng)的變量和常量,導(dǎo)致系統(tǒng)的安全性與穩(wěn)定性變得更差。

          1 開(kāi)發(fā)壞境與Cortex-M3內(nèi)核簡(jiǎn)介
          使用IAR 5.30開(kāi)發(fā)環(huán)境,移植μC/OS-II 2.86到Cortex-M3內(nèi)核上,選用配置了MPU的LPC1786處理器作為硬件實(shí)驗(yàn)平臺(tái)。
          Cortex-M3處理器支持:兩種工作模式,線程模式和處理模式;兩種訪問(wèn)等級(jí),特權(quán)級(jí)和用戶(hù)級(jí);兩個(gè)堆棧指針,主堆棧指針(MSP)和進(jìn)程堆棧指針(PSP)。異常處理工作在“處理模式+特權(quán)級(jí)+MSP”下;線程模式下,訪問(wèn)等級(jí)與堆棧指針可以相互搭配使用;但是在用戶(hù)級(jí)下,對(duì)特殊功能寄存器和系統(tǒng)控制空間(SCS)的大部分寄存器的訪問(wèn)是禁止的。
          如果處理器(如LPC1700系列、LM3S系列等)配置有MPU,可通過(guò)設(shè)定內(nèi)存的訪問(wèn)權(quán)限大幅度地提高系統(tǒng)的安全性。

          2 μC/OS-II內(nèi)核簡(jiǎn)介
          μC/OS-II操作系統(tǒng)憑借其源代碼公開(kāi)、結(jié)構(gòu)小巧、內(nèi)核可剝奪、實(shí)時(shí)性高等諸多特性而得到廣泛的應(yīng)用,并且μC/OS-II絕大部分代碼是用C語(yǔ)言編寫(xiě)的,便于移植到各種內(nèi)核上。它提供了諸如任務(wù)調(diào)度、任務(wù)管理、時(shí)間管理、內(nèi)存管理、中斷管理,以及任務(wù)間的同步與通信等實(shí)時(shí)內(nèi)核的基本功能,而沒(méi)有提供輸入輸出管理、文件系統(tǒng)、圖形用戶(hù)接口及網(wǎng)絡(luò)組件之類(lèi)的額外服務(wù)。但由于μC/OS-II具有較好的可移植性和開(kāi)源性,用戶(hù)可以根據(jù)實(shí)際應(yīng)用添加所需要的服務(wù),而且系統(tǒng)移植只需修改文件OS_CPU_C.C、OS_CPU.H、OS_CPU_A.ASM。

          3 μC/OS-II操作系統(tǒng)移植的改進(jìn)
          如果用戶(hù)任務(wù)運(yùn)行在“用戶(hù)級(jí)+PSP”狀態(tài)下,而調(diào)用操作系統(tǒng)函數(shù)時(shí)運(yùn)行在“特權(quán)級(jí)+MSP”狀態(tài)下,再配合MPU的使用,可以使系統(tǒng)的安全性與穩(wěn)定性得到很大的提高。
          3.1 設(shè)置系統(tǒng)寄存器
          系統(tǒng)任務(wù)(統(tǒng)計(jì)任務(wù)、空閑任務(wù)等)只使用主堆棧指針MSP,并且一直運(yùn)行在特權(quán)級(jí)下;而用戶(hù)任務(wù)則使用PSP、MSP兩個(gè)堆棧。在系統(tǒng)初始化時(shí),設(shè)置MPU的相關(guān)寄存器,把內(nèi)存分為特權(quán)級(jí)與用戶(hù)級(jí)兩個(gè)區(qū),如圖1所示。PSP分配在用戶(hù)區(qū),MSP、系統(tǒng)變量與常量分配在特權(quán)區(qū),以提高系統(tǒng)的安全性。

          本文引用地址:http://www.ex-cimer.com/article/202468.htm

          a.jpg

          linux操作系統(tǒng)文章專(zhuān)題:linux操作系統(tǒng)詳解(linux不再難懂)
          電能表相關(guān)文章:電能表原理

          上一頁(yè) 1 2 3 下一頁(yè)

          評(píng)論


          相關(guān)推薦

          技術(shù)專(zhuān)區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();