《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > μC/OS-Ⅱ實時操作系統內存管理的改進

μC/OS-Ⅱ實時操作系統內存管理的改進

2009-02-17
作者:王保進 王志剛1 劉恒禹2

  摘? 要: 分析了μC/OS-Ⅱ實時操作系統內存管理上存在的不足,提出了改進方法,通過一個具體實例描述了該方法的實現。?

  關鍵詞: 實時操作系統? 內存管理? 微處理器? 鏈接器?

?

  μC/OS-Ⅱ是一種開放源碼的實時操作系統,具有搶先式、多任務的特點,已被應用到眾多的微處理器上。雖然該內核功能較多,但還是有不甚完善的地方。筆者在分析使用中發現,內核在任務管理(包括任務調度、任務間的通信與同步)和中斷管理上是比較完善的,具有可以接受的穩定性和可靠性;但在內存管理上顯得過于簡單,內存分區的建立方式有不合理之處。?

1 內存管理不足之處的分析?

  在分析許多μC/OS-Ⅱ的應用實例中發現,任務棧空間和內存分區的創建采用了定義全局數組的方法,即定義一維或二維的全局數組,在創建任務或內存分區時,將數組名作為內存地址指針傳遞給生成函數。這樣實現起來固然簡單,但是不夠靈活有效。?

  編譯器會將全局數組作為未初始化的全局變量,放到應用程序映像的數據段。數組大小是固定的,生成映像后不可能在使用中動態地改變。對于任務棧空間來說,數組定義大了會造成內存浪費;定義小了任務棧溢出,會造成系統崩潰。對于內存分區,在不知道系統初始化后給用戶留下了多少自由內存空間的情況下,很難定義內存分區所用數組的大小。總之利用全局數組來分配內存空間是很不合理的。?

  另外,現在的μC/OS-Ⅱ只支持固定大小的內存分區,容易造成內存浪費。μC/OS-Ⅱ將來應該被改進以支持可變大小的內存分區。為了實現這一功能,系統初始化后能清楚地掌握自由內存空間的情況是很重要的。?

2 解決問題的方法?

  為了能清楚掌握自由內存空間的情況,避免使用全局數組分配內存空間,關鍵是要知道整個應用程序在編譯、鏈接后代碼段和數據段的大小,在目標板內存中是如何定位的,以及目標板內存大小。對于最后一條,系統編程人員當然是清楚的,第一條編譯器會給出,而如何定位是由編程人員根據具體應用環境在系統初始化確定的。因此,系統初始化時,如果能正確安排代碼段和數據段的位置,就能清楚地知道用戶可以自由使用的內存空間起始地址。用目標板內存最高端地址減去起始地址,就是這一自由空間的大小。?

3 舉例描述該方法的實現?

  下面以在CirrusLogic公司的EP7211微處理器上使用μC/OS-Ⅱ為例,描述該方法的實現過程。假設基于μC/OS-Ⅱ的應用程序比較簡單,以簡化問題的闡述。?

3.1 芯片初始化過程和鏈接器的功能?

  EP7211采用了RISC體系結構的微處理器核ARM7TDMI,該芯片支持內存管理單元MMU。系統加電復位后,從零地址開始執行由匯編語言編寫的初始化代碼。零地址存放著中斷向量表,第一個是復位中斷,通過該中斷向量指向的地址可以跳轉到系統初始化部分,執行微處理器寄存器初始化。如果使用虛擬內存,則啟動MMU,然后是為C代碼執行而進行的C環境初始化。之后創建中斷處理程序使用的棧空間,最后跳轉到C程序的入口執行系統C程序。?

  對于應用程序,ARM軟件開發包提供的ARM鏈接器會產生只讀段(read-only section RO)、讀寫段(read-write section RW)和零初始化段(zero-initialized section ZI)。每種段可以有多個,對較簡單的程序一般各有一個。?

  只讀段就是代碼段,讀寫段是已經初始化的全局變量,而零初始化段中存放未初始化的全局變量。鏈接器同時提供這三種段的起始地址和結束地址,并用已定義的符號表示。描述如下:Image$$RO$$Base表示只讀段的起始地址,Image$$RO$$Limit表示只讀段結束后的首地址;Image$$RW$$Base 表示讀寫段的起始地址,Image$$RW$$Limit表示讀寫段結束后的首地址;Image$$ZI$$Base 表示零初始化段的起始地址,Image$$ZI$$Limit表示零初始化段結束后的首地址。?

  一般嵌入式應用,程序鏈接定位后生成bin文件,即絕對地址空間的代碼,因此上述符號的值表示物理地址。對于簡單程序,可在編譯鏈接時指定RO和RW的基地址,幫助鏈接器計算上述符號的值。對于較復雜的程序可以由scatter描述文件來定義RO和RW的基地址。?

3.2 具體實例及說明?

  所謂C環境初始化,就是利用上述符號初始化RW段和ZI段,以使后面使用全局變量的C程序正常運行。下面是初始化部分的實例:?

??? ENTRY??? ?? ;應用程序入口,應該位于內存的零地址。?

??? ;中斷向量表?

??? B?????? Reset_Handler?

??? B?????? Undefined_Handler?

??? B?????? SWI_Handler?

??? B?????? Prefetch_Handler?

??? B?????? Abort_Handler?

??? NOP??? ???? ;保留向量?

??? B?????? IRQ_Handler?

??? B?????? FIQ_Handler?

??? ;當用戶使用除復位中斷以外的幾個中斷時,應將跳轉地址換成中斷處理程序的入口地址。?

??? Undefined_Handler?

??? ??????? ??? B?????? Undefined_Handler?

??? SWI_Handler?

??? ??????? ??? B?????? SWI_Handler?

??? Prefetch_Handler?

??? ??????? ??? B?????? Prefetch_Handler?

??? Abort_Handler?

??? ??????? ??? B?????? Abort_Handler?

??? IRQ_Handler?

??? ??????? ??? B?????? IRQ_Handler?

??? FIQ_Handler?

??? ??????? ??? B?????? FIQ_Handler?

??? ;程序初始化部分?

??? Reset_Handler?

??? ??? ;初始化微處理器寄存器,以使其正常工作。?

??? ? ? ……?

??????? ;啟動MMU,進入虛擬內存管理。?

??? ??? ……?

??????? ;初始化C環境。?

??????? ??? IMPORT? |Image$$RO$$Limit|????? ?

??? ??????? IMPORT? |Image$$RW$$Base|?????? ?

??? ??????? IMPORT? |Image$$ZI$$Base|?????? ?

??? ??????? IMPORT? |Image$$ZI$$Limit|????? ?

??? ??????? LDR???? r0, =|Image$$RO$$Limit| ?

??? ??????? LDR???? r1, =|Image$$RW$$Base|? ?

??? ??????? LDR???? r3, =|Image$$ZI$$Base|? ?

??? ??????? CMP???? r0, r1????????????????? ?

???? ?????? BEQ???? %F1?

??? 0?????? CMP???? r1, r3????????????????? ?

??????????? LDRCC?? r2, [r0], #4?

??? ??????? STRCC?? r2, [r1], #4?

??????? ??? BCC???? %B0?

??? 1?????? LDR???? r1, =|Image$$ZI$$Limit| ?

??? ??????? MOV???? r2, #0?

??? 2?????? CMP???? r3, r1???????????????? ?

??? ??????? STRCC?? r2, [r3], #4?

??? ??????? BCC???? %B2?

  在RAM中初始化RW段和ZI段后,ZI段結束后的首地址到系統RAM最高端之間的內存就是用戶可以自由使用的空間,也就是說Image$$ZI$$Limit是這一內存空間的起始地址。?

  如果系統使用了FIQ和IRQ中斷,在ZI段之后可以創建這兩種中斷的棧空間,然后是操作系統使用的SVC模式下的棧空間,假設每一個棧大小為1024個字節。如果系統使用了定時器,還可在此之后創建定時器中斷的棧空間,假設其大小也為1024個字節。此時自由內存空間的起始地址變為:?

  Image$$ZI$$Limit+1024×4?

  在初始化代碼的最后將其作為一個參數傳遞到C程序入口,代碼如下:?

??? LDR???? r0,? =|Image$$ZI$$Limit| ?

??? ;創建IRQ棧空間。?

??? ……?

??? ;增加地址指針。?

??? ADD???? r0,? r0,? #1024? ?

??? ;創建FIQ棧空間。?

??? ……?

??? ;增加地址指針。?

??? ADD???? r0,? r0,? #1024? ?

??? ;創建SVC棧空間。?

??? ……?

??? ;增加地址指針。?

??? ADD???? r0,? r0,? #1024? ?

??? ;創建定時器中斷棧空間。?

??? ……?

??? ;增加地址指針。?

??? ADD???? r0,? r0,? #1024? ?

??? ;導入C代碼入口點。?

??? IMPORT? C_ENTRY?

??? ;跳轉到C代碼,此時r0作為入口參數。?

??? B?????? C_ENTRY?

3.3 對實例的總結?

  在C程序中,上述起始地址可以作為內存分區創建函數OSMemCreate()的內存地址參數,內存分區的最大值就是目標板RAM的最高端地址減去起始地址的值。圖1顯示了RO段在RAM中的內存分布情況,這種情況下,程序映像一般被保存在目標板閃存中。系統從閃存啟動后,將RO段拷貝到RAM中繼續執行。圖2顯示了RO段在閃存中,RW和ZI段在RAM中的情況。這種情況下,系統啟動和代碼的執行都發生在閃存中。?

?

?

?

  用戶知道起始地址的值和自由內存的大小后,就可以清楚、靈活地建立和使用內存分區了。可以根據具體需要建立一些大小不同的內存分區,任務棧、事件控制塊和消息隊列都可以在這些內存分區中分配。系統可以非常清晰地掌握內存使用情況。?

  本文針對一種芯片描述了如何實現對μC/OS-Ⅱ內存管理的改進。對于其它類型的微處理器,例如CISC指令集的芯片,雖然具體實現過程有所不同,但思路是一樣的。?

  μC/OS-Ⅱ的內存管理還有需要改進的地方,例如,現在的內存管理只支持固定大小的分區,而實際應用中有動態分配非固定分區的需求。這就要求μC/OS-Ⅱ有實現該功能的軟件結構和內存分配、回收算法。現在能清楚地掌握系統初始化后內存分布情況,為今后實現這些軟件結構和算法打下了基礎。?

參考文獻?

1 JEAN J.LABROSSE著,邵貝貝譯. μC/OS-Ⅱ—源碼公開的實時嵌入式操作系統.北京:中國電力出版社,2001?

2 ARM Limited. ARM Software Development Toolkit Reference Guide.1998?

3 ARM Limited. ARM Software Development Toolkit User Guide.1998?

4 ARM 7TDMI Data Sheet. Advanced RISC Machines Ltd(ARM). 1995
本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美日韩精品在线视频| 国产亚洲欧美在线| 欧美一区二区视频免费观看 | 9国产精品视频| 亚洲第一中文字幕| 亚洲你懂的在线视频| 中文国产成人精品| 一本色道久久88综合日韩精品| 亚洲电影免费在线观看| 伊人精品久久久久7777| 娇妻被交换粗又大又硬视频欧美| 黑丝一区二区| 激情综合在线| 狠狠色丁香久久综合频道| 韩日精品视频一区| 亚洲大片在线观看| 亚洲高清激情| 亚洲国产午夜| 亚洲美女精品久久| 日韩一级欧洲| 亚洲视频中文| 亚洲欧美另类综合偷拍| 欧美亚洲一级| 久久精品免费看| 亚洲国产欧美久久| 日韩天堂av| 亚洲一区二区免费在线| 亚洲欧美激情四射在线日| 香蕉精品999视频一区二区| 欧美在线免费看| 久久噜噜亚洲综合| 欧美大片在线影院| 欧美视频一区| 国产九九视频一区二区三区| 国产丝袜一区二区| …久久精品99久久香蕉国产| 亚洲欧洲一级| 亚洲视频一二三| 久久精品国产99国产精品澳门| 亚洲精品视频免费观看| 中文久久乱码一区二区| 午夜精品久久久久久久| 久久亚洲精选| 欧美日韩黄色大片| 国产九色精品成人porny| 狠狠色综合色综合网络| 亚洲精品免费在线播放| 亚洲免费在线看| 亚洲国产乱码最新视频| 这里只有精品丝袜| 久久九九热re6这里有精品| 欧美风情在线观看| 国产精品麻豆欧美日韩ww| 伊人久久综合97精品| 99精品视频免费观看| 欧美一级免费视频| 99re亚洲国产精品| 久久gogo国模裸体人体| 欧美激情综合网| 国产热re99久久6国产精品| 亚洲国语精品自产拍在线观看| 亚洲视频一区二区| 亚洲国产欧美不卡在线观看| 亚洲综合视频一区| 美女国产一区| 国产精品中文在线| 亚洲三级影院| 久久国产手机看片| 亚洲小说春色综合另类电影| 久久久亚洲成人| 国产精品成人国产乱一区| 国语精品一区| 亚洲深夜av| 亚洲日本中文字幕免费在线不卡| 午夜精品视频在线| 欧美日韩国产成人在线免费| 国产一区二区三区成人欧美日韩在线观看| 亚洲精品一区二区在线观看| 欧美一进一出视频| 亚洲尤物影院| 欧美精品在线播放| 好看的日韩视频| 亚洲免费视频一区二区| 中国日韩欧美久久久久久久久| 久久综合给合| 国产日韩欧美视频在线| 艳妇臀荡乳欲伦亚洲一区| 亚洲国产91精品在线观看| 香蕉av777xxx色综合一区| 欧美日韩卡一卡二| 亚洲国产日本| 亚洲第一狼人社区| 久久www成人_看片免费不卡| 欧美视频网址| 亚洲看片免费| 亚洲精品无人区| 榴莲视频成人在线观看| 国产亚洲电影| 亚洲一区视频| 亚洲综合日韩在线| 欧美三级电影网| 亚洲人成小说网站色在线| 亚洲国产高清高潮精品美女| 久久精品亚洲一区| 国产午夜亚洲精品不卡| 亚洲综合社区| 先锋影音久久久| 国产精品视频网| 亚洲视频一区在线| 亚洲在线免费| 欧美性天天影院| 正在播放欧美视频| 亚洲在线日韩| 国产精品青草久久久久福利99| 一区二区高清视频在线观看| 一区二区久久| 欧美日韩亚洲一区二区三区四区 | 国产一区二区三区最好精华液| 亚洲夜间福利| 午夜精品久久久久久久蜜桃app| 欧美视频在线一区| 日韩一级二级三级| 亚洲一区二区成人| 国产精品盗摄久久久| 中文日韩在线| 亚洲欧美在线网| 国产精品免费看久久久香蕉| 亚洲一级片在线观看| 午夜在线成人av| 国产拍揄自揄精品视频麻豆| 欧美一区二区私人影院日本 | 一区二区国产日产| 亚洲欧美日本另类| 国产乱码精品1区2区3区| 亚洲一区二区三区午夜| 欧美一区二区在线播放| 国产日韩亚洲欧美| 亚洲第一色在线| 欧美第一黄色网| 日韩一区二区久久| 亚洲欧美一区二区三区久久| 国产欧美亚洲日本| 亚洲电影网站| 欧美精品久久一区二区| 99成人在线| 欧美资源在线观看| 一区在线播放视频| 亚洲美女在线观看| 欧美日韩综合网| 午夜免费久久久久| 麻豆成人精品| 99re热这里只有精品视频| 欧美亚洲免费| 黄色av日韩| 一区二区三区久久网| 国产精品女主播一区二区三区| 久久精品国产免费| 欧美精品一线| 午夜精品久久久久久久99水蜜桃| 久久久久久久久久久久久久一区| 在线成人中文字幕| 亚洲婷婷免费| 国产一区二区av| 亚洲精品免费在线| 国产精品日韩在线| 最新国产成人av网站网址麻豆| 欧美日韩精品福利| 性欧美暴力猛交69hd| 欧美激情一区二区三区蜜桃视频| 亚洲视频在线二区| 免费国产自线拍一欧美视频| 亚洲色图制服丝袜| 美日韩精品视频免费看| 在线综合亚洲| 母乳一区在线观看| 亚洲欧美国产三级| 欧美成人一品| 午夜精品区一区二区三| 国产日韩欧美a| 一本大道久久a久久精品综合| 中文网丁香综合网| 国产婷婷一区二区| 一本久道综合久久精品| 国产精品有限公司| 亚洲精品一区二区三区婷婷月 | 91久久国产综合久久91精品网站| 一区二区三区久久| 一区二区三区我不卡| 亚洲欧美国产视频| 亚洲高清视频一区二区| 欧美一级一区| 亚洲美女尤物影院| 久久综合网络一区二区| 亚洲女与黑人做爰| 欧美日韩国产专区| 欧美在线视频免费| 国产精品视频一二三| 99视频超级精品| 一区二区视频欧美| 欧美一级久久|