資料介紹
μ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)編程人員當(dā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)建中斷處理程序使用的棧空間,最后跳轉(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
;當(dāng)用戶使用除復(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模式下的棧空間,假設(shè)每一個棧大小為1024個字節(jié)。如果系統(tǒng)使用了定時器,還可在此之后創(chuàng)建定時器中斷的棧空間,假設(shè)其大小也為1024個字節(jié)。此時自由內(nèi)存空間的起始地址變?yōu)椋?br /> Image$$ZI$$Limit+1024×4
在初始化代碼的最后將其作為一個參數(shù)傳遞到C程序入口,代碼如下:
LDR r0, =|Image$$ZI$$Limit|
;創(chuàng)建IRQ棧空間。
……
;增加地址指針。
ADD r0, r0, #1024
;創(chuàng)建FIQ棧空間。
……
;增加地址指針。
ADD r0, r0, #1024
;創(chuàng)建SVC棧空間。
……
;增加地址指針。
ADD r0, r0, #1024
;創(chuàng)建定時器中斷棧空間。
……
;增加地址指針。
ADD r0, r0, #1024
;導(dǎo)入C代碼入口點。
IMPORT C_ENTRY
;跳轉(zhuǎn)到C代碼,此時r0作為入口參數(shù)。
B C_ENTRY
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)編程人員當(dā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)建中斷處理程序使用的棧空間,最后跳轉(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
;當(dāng)用戶使用除復(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模式下的棧空間,假設(shè)每一個棧大小為1024個字節(jié)。如果系統(tǒng)使用了定時器,還可在此之后創(chuàng)建定時器中斷的棧空間,假設(shè)其大小也為1024個字節(jié)。此時自由內(nèi)存空間的起始地址變?yōu)椋?br /> Image$$ZI$$Limit+1024×4
在初始化代碼的最后將其作為一個參數(shù)傳遞到C程序入口,代碼如下:
LDR r0, =|Image$$ZI$$Limit|
;創(chuàng)建IRQ棧空間。
……
;增加地址指針。
ADD r0, r0, #1024
;創(chuàng)建FIQ棧空間。
……
;增加地址指針。
ADD r0, r0, #1024
;創(chuàng)建SVC棧空間。
……
;增加地址指針。
ADD r0, r0, #1024
;創(chuàng)建定時器中斷棧空間。
……
;增加地址指針。
ADD r0, r0, #1024
;導(dǎo)入C代碼入口點。
IMPORT C_ENTRY
;跳轉(zhuǎn)到C代碼,此時r0作為入口參數(shù)。
B C_ENTRY
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 嵌入式實時操作系統(tǒng)μC/OS-Ⅱ在LPC1788上的移植及應(yīng)用
- 基于μC/OS-Ⅱ的遠程環(huán)境監(jiān)測系統(tǒng)設(shè)計方案
- 以μC OS-III為例的嵌入式實時操作系統(tǒng)概述 8次下載
- 淺談嵌入式操作系統(tǒng)μC/OS-Ⅱ面向數(shù)控系統(tǒng)的改進 1次下載
- 關(guān)于μC/OS-II實時操作系統(tǒng)內(nèi)存管理的改進方法分析 0次下載
- 嵌入式實時操作系統(tǒng)μC_OS_在LPC1788上的移植及應(yīng)用 10次下載
- 嵌入式實時操作系統(tǒng)uCOS-II原理 261次下載
- 實時操作系統(tǒng)μCOS_II在LPC2114上的移植
- 一種基于μC/OS-Ⅱ的IPMC開發(fā)方案
- 基于μC/OS-Ⅱ的實時分層調(diào)度算法研究
- 實時操作系統(tǒng)μC/OS-II調(diào)度算法的研究
- 無線信息設(shè)備的理想操作系統(tǒng)Symbian OS
- μC/OS-Ⅱ與VxWORKs介紹及說明
- UC/OS-Ⅱ操作系統(tǒng)在ARM處理器上的移植
- 嵌入式實時操作系統(tǒng)μC/OS-Ⅱ在ARM處理器上的實現(xiàn)
- 詳解實時操作系統(tǒng)和非實時操作系統(tǒng) 6.7k次閱讀
- FreeRTOS:一個迷你的實時操作系統(tǒng)內(nèi)核 1.7k次閱讀
- Linux是實時系統(tǒng)還是分時操作系統(tǒng)? 2.1k次閱讀
- 內(nèi)存的基本概念以及操作系統(tǒng)的內(nèi)存管理算法 2.7k次閱讀
- RTA-OS實時操作系統(tǒng)中的Task對象 4.7k次閱讀
- 基于實時嵌入式操作系統(tǒng)mC/OS-II實現(xiàn)GPRS終端系統(tǒng)的設(shè)計 3.2k次閱讀
- μC/OS-II操作系統(tǒng)移植在LPC2378上的系統(tǒng)測試及問題解決方法 1.5k次閱讀
- 米爾科技嵌入式實時操作系統(tǒng)介紹 3k次閱讀
- 51單片機對μC/OS-II實時操作系統(tǒng)的移植 3k次閱讀
- 對實時操作系統(tǒng)特性的討論 5.8k次閱讀
- 基于Linux上進行改進的具有實時應(yīng)用能力的現(xiàn)代嵌入式操作系統(tǒng)解決方案詳解 1.2k次閱讀
- μC/OS-Ⅱ操作系統(tǒng)設(shè)備驅(qū)動設(shè)計及實際應(yīng)用舉例 2.1k次閱讀
- 如何安裝實時操作系統(tǒng)RTOS 6.8k次閱讀
- 基于FreeRTOS的嵌入式實時操作系統(tǒng)的原理和實現(xiàn) 7.3k次閱讀
- uC/OS和uClinux操作系統(tǒng)的區(qū)別 4.9k次閱讀
下載排行
本周
- 1冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 4次下載 | 10 積分
- 2安川A1000變頻器中文版說明書
- 20.16 MB | 3次下載 | 3 積分
- 3直流電路的組成和基本定律
- 1.67 MB | 2次下載 | 免費
- 4丹佛斯2800系列變頻器說明書
- 8.00 MB | 1次下載 | 5 積分
- 5PC8011同步開關(guān)型降壓3.5A單節(jié)鋰電池充電管理電路技術(shù)手冊
- 0.74 MB | 1次下載 | 免費
- 6ES7243E+ES8311音頻錄制與播放電路資料
- 0.06 MB | 1次下載 | 5 積分
- 7SDM02 激光測距模塊產(chǎn)品手冊
- 0.43 MB | 1次下載 | 免費
- 8SDFM 激光測距模塊模組手冊
- 0.54 MB | 1次下載 | 免費
本月
- 1CH341編程器軟件NeoProgrammer_2.2.0.10
- 20.47 MB | 170次下載 | 1 積分
- 22025智能家居傳感器市場分析及創(chuàng)新應(yīng)用
- 3.11 MB | 43次下載 | 免費
- 3RV1126B系列開發(fā)板產(chǎn)品資料
- 4.19 MB | 18次下載 | 免費
- 4CH341編程軟件下載
- 2.50 MB | 16次下載 | 5 積分
- 5全志系列-米爾基于T153核心板開發(fā)板 四核異構(gòu)、3路千兆網(wǎng),賦能多元化工業(yè)場景
- 3.05 MB | 12次下載 | 免費
- 6【開源】60余套STM32單片機、嵌入式Linux、物聯(lián)網(wǎng)、人工智能項目案例及入門學(xué)習(xí)資源包
- 10.55 MB | 8次下載 | 免費
- 7冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 4次下載 | 10 積分
- 8特斯拉MODEL S車載充電機主電路回路原理圖
- 0.81 MB | 4次下載 | 3 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233094次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191448次下載 | 10 積分
- 5十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183356次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81604次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73824次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論