《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > μ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亚洲国产精品_日韩亚洲一区二区
亚洲第一精品在线| 欧美一区二区三区日韩| 在线综合亚洲欧美在线视频| 亚洲高清在线播放| 精品成人一区二区| 国产一区二区成人| 国产欧美亚洲精品| 国产精品一区二区欧美| 国产精品久久久久毛片大屁完整版| 欧美日本网站| 欧美绝品在线观看成人午夜影视 | 久久久久.com| 欧美在线高清| 欧美专区日韩视频| 久久成人一区| 久久久综合精品| 久久夜色精品国产欧美乱极品| 麻豆亚洲精品| 欧美激情五月| 欧美日韩激情网| 国产精品激情| 国产视频久久| 激情国产一区| 亚洲激情影视| 亚洲毛片在线看| 一区二区三区四区五区在线 | 亚洲欧美国产va在线影院| 午夜精品免费| 久久久午夜视频| 男人插女人欧美| 欧美日韩精品免费观看| 国产精品国产三级欧美二区| 亚洲国产精品美女| 欧美一区二区三区免费视频| 亚洲国产精品成人va在线观看| 久久精品日韩欧美| 91久久国产综合久久91精品网站| 亚洲欧洲综合另类| 亚洲私拍自拍| 久久精品国产91精品亚洲| 久久综合99re88久久爱| 欧美激情免费在线| 欧美性理论片在线观看片免费| 国产精品久久97| 国产无一区二区| 亚洲国产你懂的| 在线亚洲一区二区| 性欧美精品高清| 亚洲蜜桃精久久久久久久| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 久久久久.com| 欧美激情综合亚洲一二区| 欧美天天视频| 国产一区二区精品| 亚洲欧洲中文日韩久久av乱码| 中文无字幕一区二区三区| 欧美一区2区三区4区公司二百| 亚洲黄页视频免费观看| 亚洲欧美激情一区二区| 美女视频黄免费的久久| 欧美丝袜一区二区| 黄色成人av网站| 一区二区三区高清视频在线观看| 久久精品国产欧美激情| 一本色道久久88综合亚洲精品ⅰ| 欧美一区深夜视频| 欧美 日韩 国产一区二区在线视频 | 激情欧美国产欧美| 日韩一级黄色片| 欧美在线一区二区| 一区二区av在线| 久久人人97超碰国产公开结果| 欧美日韩成人一区二区| 国产日韩欧美在线视频观看| 亚洲人成77777在线观看网| 亚洲欧美一区二区精品久久久| 亚洲精品久久嫩草网站秘色| 欧美亚洲视频在线观看| 欧美成人午夜激情| 国产欧美日韩中文字幕在线| 亚洲日韩中文字幕在线播放| 欧美中日韩免费视频| 亚洲网站在线看| 免费一区视频| 国产丝袜美腿一区二区三区| 99热在这里有精品免费| 亚洲韩国精品一区| 久久精品论坛| 国产精品久久久久久五月尺| 亚洲国产裸拍裸体视频在线观看乱了中文 | 久久久久99精品国产片| 欧美性大战久久久久| 亚洲国产一成人久久精品| 欧美一区二区三区免费观看视频 | 日韩一级精品| 麻豆乱码国产一区二区三区| 国产日韩亚洲| 亚洲一区二区三区高清| 一卡二卡3卡四卡高清精品视频 | 欧美精品v国产精品v日韩精品| 国模 一区 二区 三区| 亚洲欧美国产精品桃花| 亚洲一区999| 欧美理论在线| 亚洲国产日韩在线| 亚洲国产乱码最新视频| 久久久噜久噜久久综合| 国产日韩精品入口| 亚洲影院高清在线| 亚洲伊人伊色伊影伊综合网 | 国产一区二区三区日韩| 亚洲午夜影视影院在线观看| 一本色道久久综合亚洲精品不卡| 欧美国产先锋| 亚洲欧洲精品一区二区| 91久久极品少妇xxxxⅹ软件| 快射av在线播放一区| 国内精品久久久| 欧美影院在线播放| 久久国产色av| 国产女人18毛片水18精品| 亚洲午夜精品久久久久久浪潮| 好吊色欧美一区二区三区四区| 国产精品综合| 亚洲一区免费观看| 午夜精品影院| 国产精品日本| 亚洲一区在线视频| 性欧美videos另类喷潮| 国产精品视频福利| 亚洲一二三四久久| 欧美一区二区三区视频在线观看| 国产精品爽爽爽| 亚洲尤物在线| 久久精品国产第一区二区三区最新章节 | 在线观看欧美视频| 亚洲高清久久久| 牛牛影视久久网| 亚洲精品少妇网址| 亚洲一区二区三区精品在线观看| 欧美日韩一区自拍| 亚洲午夜精品国产| 久久精品亚洲一区二区| 在线播放亚洲| 亚洲最新色图| 国产精品免费观看在线| 先锋a资源在线看亚洲| 久久久久国产一区二区三区四区 | 宅男66日本亚洲欧美视频| 新狼窝色av性久久久久久| 国产亚洲精品一区二555| 亚洲国产国产亚洲一二三| 欧美福利一区二区| 夜夜嗨av一区二区三区中文字幕| 亚洲欧美日韩国产成人精品影院| 国产婷婷色一区二区三区四区| 亚洲国产精品久久久久秋霞蜜臀| 欧美另类视频| 午夜精品久久久久久久久久久久久 | 中文有码久久| 久久久国产成人精品| 最新成人在线| 午夜精品久久久久久久99樱桃| 国产一区二区精品久久99| 亚洲精品男同| 国产精品卡一卡二| 久久精品视频va| 欧美日韩国产页| 欧美在线一二三四区| 欧美日本一区二区视频在线观看| 亚洲一区在线播放| 欧美sm视频| 亚洲一区欧美| 欧美黄污视频| 午夜精品在线看| 欧美激情中文字幕一区二区| 亚洲一区二区影院| 美日韩丰满少妇在线观看| 在线视频你懂得一区| 久久躁日日躁aaaaxxxx| 99热这里只有成人精品国产| 久久久久免费视频| 日韩一级视频免费观看在线| 久久精品国产久精国产思思| 亚洲精品小视频| 久久这里有精品15一区二区三区| 99天天综合性| 久久免费视频在线观看| 99精品99| 美女精品国产| 亚洲图片欧美日产| 欧美不卡在线视频| 午夜国产精品视频| 欧美日韩另类一区| 久久激情五月婷婷| 国产精品青草久久久久福利99| 亚洲日韩成人| 国产亚洲一级高清| 亚洲女人天堂成人av在线| 1024成人网色www|