當前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]μC/OS-Ⅱ?qū)崟r操作系統(tǒng)內(nèi)存管理的改進

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

1 內(nèi)存管理不足之處的分析

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

  編譯器會將全局數(shù)組作為未初始化的全局變量,放到應(yīng)用程序映像的數(shù)據(jù)段。數(shù)組大小是固定的,生成映像后不可能在使用中動態(tài)地改變。對于任務(wù)棧空間來說,數(shù)組定義大了會造成內(nèi)存浪費;定義小了任務(wù)棧溢出,會造成系統(tǒng)崩潰。對于內(nèi)存分區(qū),在不知道系統(tǒng)初始化后給用戶留下了多少自由內(nèi)存空間的情況下,很難定義內(nèi)存分區(qū)所用數(shù)組的大小??傊萌謹?shù)組來分配內(nèi)存空間是很不合理的。

  另外,現(xiàn)在的μC/OS-Ⅱ只支持固定大小的內(nèi)存分區(qū),容易造成內(nèi)存浪費。μC/OS-Ⅱ?qū)響?yīng)該被改進以支持可變大小的內(nèi)存分區(qū)。為了實現(xiàn)這一功能,系統(tǒng)初始化后能清楚地掌握自由內(nèi)存空間的情況是很重要的。

2 解決問題的方法

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

3 舉例描述該方法的實現(xiàn)

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

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

  EP7211采用了RISC體系結(jié)構(gòu)的微處理器核ARM7TDMI,該芯片支持內(nèi)存管理單元MMU。系統(tǒng)加電復(fù)位后,從零地址開始執(zhí)行由匯編語言編寫的初始化代碼。零地址存放著中斷向量表,第一個是復(fù)位中斷,通過該中斷向量指向的地址可以跳轉(zhuǎn)到系統(tǒng)初始化部分,執(zhí)行微處理器寄存器初始化。如果使用虛擬內(nèi)存,則啟動MMU,然后是為C代碼執(zhí)行而進行的C環(huán)境初始化。之后創(chuàng)建中斷處理程序使用的??臻g,最后跳轉(zhuǎn)到C程序的入口執(zhí)行系統(tǒng)C程序。

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

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

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

3.2 具體實例及說明

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

    ENTRY       ;應(yīng)用程序入口,應(yīng)該位于內(nèi)存的零地址。

    ;中斷向量表

    B       Reset_Handler

    B       Undefined_Handler

    B       SWI_Handler

    B       Prefetch_Handler

    B       Abort_Handler

    NOP         ;保留向量

    B       IRQ_Handler

    B       FIQ_Handler

    ;當用戶使用除復(fù)位中斷以外的幾個中斷時,應(yīng)將跳轉(zhuǎn)地址換成中斷處理程序的入口地址。

    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,進入虛擬內(nèi)存管理。

        ……

        ;初始化C環(huán)境。

            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段結(jié)束后的首地址到系統(tǒng)RAM最高端之間的內(nèi)存就是用戶可以自由使用的空間,也就是說Image$$ZI$$Limit是這一內(nèi)存空間的起始地址。

  如果系統(tǒng)使用了FIQ和IRQ中斷,在ZI段之后可以創(chuàng)建這兩種中斷的棧空間,然后是操作系統(tǒng)使用的SVC模式下的??臻g,假設(shè)每一個棧大小為1024個字節(jié)。如果系統(tǒng)使用了定時器,還可在此之后創(chuàng)建定時器中斷的??臻g,假設(shè)其大小也為1024個字節(jié)。此時自由內(nèi)存空間的起始地址變?yōu)?

  Image$$ZI$$Limit+1024×4

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

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

    ;創(chuàng)建IRQ棧空間。

    ……

    ;增加地址指針。

    ADD     r0,  r0,  #1024  

    ;創(chuàng)建FIQ??臻g。

    ……

    ;增加地址指針。

    ADD     r0,  r0,  #1024  

    ;創(chuàng)建SVC??臻g。

    ……

    ;增加地址指針。

    ADD     r0,  r0,  #1024  

    ;創(chuàng)建定時器中斷棧空間。

    ……

    ;增加地址指針。

    ADD     r0,  r0,  #1024  

    ;導(dǎo)入C代碼入口點。

    IMPORT  C_ENTRY

    ;跳轉(zhuǎn)到C代碼,此時r0作為入口參數(shù)。

    B       C_ENTRY

3.3 對實例的總結(jié)

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

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

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

  μC/OS-Ⅱ的內(nèi)存管理還有需要改進的地方,例如,現(xiàn)在的內(nèi)存管理只支持固定大小的分區(qū),而實際應(yīng)用中有動態(tài)分配非固定分區(qū)的需求。這就要求μC/OS-Ⅱ有實現(xiàn)該功能的軟件結(jié)構(gòu)和內(nèi)存分配、回收算法。現(xiàn)在能清楚地掌握系統(tǒng)初始化后內(nèi)存分布情況,為今后實現(xiàn)這些軟件結(jié)構(gòu)和算法打下了基礎(chǔ)。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉