《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > WinCE線程和內存管理之內存管理
WinCE線程和內存管理之內存管理
互聯網
摘要: 同其它Windows操作系統一樣,Windows CE.NET也支持32位虛擬內存機制、按需分配內存和內存映射文件等。但是與其它Windows操作系統又有明顯的不同。
Abstract:
Key words :
內存管理

  同其它Windows操作系統一樣,Windows CE.NET也支持32位虛擬內存機制、按需分配內存和內存映射文件等。但是與其它Windows操作系統又有明顯的不同。 
 
<a class=WinCE線程和內存管理之內存管理圖片2" height="1" width="1" />       畢竟Windows CE是一種嵌入式實時性的操作系統,在內存管理方面必須要比其它Windows操作系統更節約物理內存和虛擬地址空間。在內存管理API方面,為了便于移植程序,Windows CE和其它Windows操作系統函數聲明基本一致,這使一個在其它Windows下開發的程序員可以直接使用早就熟悉的API函數, 但是CE下內存管理的原理開發者還是應該熟悉的。

  1、ROM和RAM

  對于早期采用的存儲設備一般采用ROM + RAM ,在ROM中存放的所有文件可以是壓縮的也可以是不壓縮的,這取決于OEM(原始設備制造商)。OEM在定制CE內核時可以設置一個標志告訴ROM鏡像制作工具(romimage.exe)是否壓縮文件。對于ROM中存放的模塊(DLL、EXE文件)來說,如果是壓縮的,模塊在運行前先解壓并全部存放到RAM中。如果是不壓縮的,并且ROM介質支持線性訪問(line-Accessed),就可以本地執行(executed in place,縮寫為XIP)。利用本地執行方式運行應用程序、DLL的優點是:采用這種技術在加載EXE或DLL時,其中的代碼段數據不加載到物理內存中,內核只是分配虛擬地址空間給代碼段,當執行代碼時內核會到實際存放在ROM存儲設備上的文件中尋找代碼并執行。采用這樣的技術既可以節省可用內存又可以減少加載的時間。但是這種技術有一定的局限性,如果要讓CPU到ROM中去尋找代碼執行,那么ROM介質必須支持線性訪問,這就要求ROM介質支持線性訪問,而不是塊訪問。XIP這種加載方式的缺點就是執行速度相對較慢,CPU訪問ROM的速度肯定遠慢于訪問RAM的速度。
 
  基于Windows CE的產品開始采用FLASH、IDE等永久存儲設備時,內核鏡像(.bin)和其它應用程序文件開始存放到永久存儲設備中而不是ROM中,這不僅僅是因為硬盤或者FLASH的I/O速度比ROM快,更因為現在的內核包含的功能多并且文件數量增加,因而需要的存儲空間很大,一般都在20MB左右。再加上其它開發商開發的應用程序文件,要求的空間就更大了。CE啟動時內核鏡像由加載程序解壓并將系統文件加載到RAM的NK,NK是在config.bib中定義的一段RAM區域,專用于保存內核鏡像解壓出來的所有文件。Windows CE將NK看作是ROM,當執行一個應用程序時,CE內核將這個應用程序需要的系統DLL(在NK中保存)加載到Slot 1(地址范圍0x0200 0000-0x03FF FFFF,在Windows CE.NET中Slot 1專用于XIP DLL使用)。Slot 1是一段虛擬地址,當CPU執行DLL的代碼時,CPU會根據地址映射關系到NK中尋找實際的代碼執行,因為NK是一段實際的物理內存,I/O速度非常快,所以相對于在ROM中執行,DLL的運行效率得到很大提高。

  非XIP DLL在加載時CE內核會在調用DLL的進程的地址空間中申請足夠大的地址空間,并且執行代碼時按需提交物理內存。

  RAM和ROM文件系統是Windows CE默認的文件系統。RAM文件系統的優點是支持文件壓縮、支持事務機制(和數據庫中的事務機制相似)、數據I/O較快。Windows CE.NET啟動時把除了NK以外的RAM分為對象存儲(object store)區域和應用程序內存(program memory)區域,并且默認各使用一半RAM。在基于Windows CE的設備沒有采用永久存儲器之前,對象存儲的作用相當于永久存儲器,對象存儲區域采用RAM文件系統來保存文件,對象存儲中可以存儲的對象類型有文件、目錄、數據庫、記錄、數據庫卷。默認在對象存儲中存儲的對象全部是壓縮的。當整個系統關閉時,設備的電源還繼續提供電力給RAM,這樣對象存儲中保存的所有數據就不會丟失。應用程序內存區域留給所有應用程序運行時使用。基于Windows CE的設備采用永久存儲器后,對象存儲的作用就被永久存儲器替代了,所以采用永久存儲器后,應該減小對象存儲區域的大小。如果定制的Windows CE的內核包含了資源管理器(eXPlorer.exe),那么打開“控制面板”,在“系統”-“內存”中,可以調節這兩個存儲區域的比例。滑塊向左,則釋放對象存儲區域的一些可用內存并將這些內存劃到應用程序內存區域中。滑塊向右則相反。

  2、內存結構

  Windows CE.NET只能管理512MB的物理內存和4GB大小的虛擬地址空間。不同的CPU內存管理方法也不同。對于MIPS和SHX系列CPU來說,物理地址映射是由CPU完成的,CE內核可以直接訪問512MB的物理內存。對于x86系列和ARM系列的CPU來說,在內核啟動過程中它會將現有物理內存地址全部映射到0x8000 0000以上的虛擬地址空間中供內核以后使用。OEM可以通過OEMAddressTable來詳細定義虛擬地址和物理地址的映射關系。OEMAddressTable本身并不是一個文件,它只是存在于其它文件中描述虛擬地址和實際物理地址的映射關系的數據。比如文件oem init.asm中包含一段代碼:dd 80000000h, 0, 04000000h 。它表示將整個物理地址(0x0400 0000=64MB)共64MB映射到虛擬地址從0x8000 0000到0x8400 0000中。關于OEMAddressTable我將在以后關于PB的文章中講述。

  整個4GB虛擬地址空間主要劃分為兩部分,從0x8000 0000以上為內核使用部分,0x8000 0000以下為應用程序使用部分。詳細見下表:

地址范圍用途 0x0000 0000到0x41FF FFFF   由所有應用程序使用。共33個槽,每個槽占32MB。槽0(Slot 0)由當前占有CPU的進程使用。槽1由XIP DLL使用。其它槽用于進程使用,每個進程占用一個槽。 0x4200 0000到0x7FFF FFFF   由所有應用程序共享的區域。32MB地址空間有時不能夠滿足一些進程的需求。那么進程可以使用這個范圍的地址空間。在這個區域里應用程序可以建堆、創建內存映射文件、分配大的地址空間等。 0xA000 0000到0xBFFF FFFF   在這個范圍內核重復定義0x8000 0000到0x9FFF FFFF之間定義的物理地址映射空間。區別是在這范圍映射的虛擬地址空間不能夠用于緩沖。

  我舉例來說明:假設一個產品有64MB物理內存。如上文所述定義好OEMAddressTable后。內核啟動后一個物理地址映射空間范圍在0x8000 0000到0x8400 0000,那么內核會從0xA000 0000到0xA400 0000定義一個同樣范圍的地址空間,這個地址空間和0x8000 0000到0x8400 0000映射到相同的物理地址。但這個虛擬地址空間不能夠用于緩沖。 0xC000 0000到0xC1FF FFFF 系統保留空間 0xC200 0000到0xC3FF FFFF 內核程序nk.exe使用的地址空間。 0xC400 0000到0xDFFF FFFF   這個范圍為用戶定義的靜態虛擬地址空間,但這個地址空間只能用于非緩沖使用。
  利用OEMAddressTable定義物理地址映射空間后,每次內核啟動時這個范圍都不改變了,除非產品包含的物理內存容量發生變化。假如增加到128MB物理內存,那么物理地址映射空間也向后擴大了一倍。Windows CE.NET也允許用戶創建靜態的物理地址映射空間。用戶可以調用CreateStaticMapping函數或者NKCreateStaticMapping函數來映射某一段物理地址到0xC400 0000和0xE000 0000之間的某一個范圍。需要注意的是用這個函數創建的靜態虛擬地址只能夠由內核訪問,而且不能用于緩沖。

0xE000 0000到0xFFFF FFFF 內核使用的虛擬地址。當內核需要大的虛擬地址空間時,會在這個范圍內分配。    

WinCE線程和內存管理之內存管理圖片9
圖1 Windows CE.NET內存結構

進入討論組討論。


  3、進程地址空間結構

  進程地址空間結構如圖2所示。這個圖源至MSDN。 
 WinCE線程和內存管理之內存管理圖片2
        WinCE線程和內存管理之內存管理圖片2Windows CE.NET同以前版本的Windows CE操作系統在進程地址空間上有所不同,以前的Windows CE把XIP DLL也加載到進程的32MB地址空間中,而Windows CE.NET把XIP DLL單獨加載到Slot 1中,這樣對于每個進程來說,它總的地址空間就大了一倍,也就是64MB。這個問題我在講解進程的時候提到過。

  當一個應用程序啟動時,內核為這個程序選擇一個空閑的槽(Slot),并且加載所有的代碼、資源,并分配堆棧,加載DLL等。當這個進程得到CPU使用權時,它的整個地址空間被內核映射到Slot 0,也就是當前進程使用的地址空間,然后開始運行。圖中給出的地址實際上是經過映射到Slot 0之后的結構。從圖中可以看出,進程首先加載代碼段,因為每個進程最低部64KB作為保留區域,所以代碼段從0x0001 0000開始,內核為代碼段分配足夠的虛擬地址空間后,接著分配空間為只讀數據和可讀/可寫數據,接著分配空間為資源數據,之后分配空間為默認堆和棧。非XIP DLL從進程最高地址向下開始加載。非XIP DLL的加載按如下規則:內核先檢查要加載的DLL是否被其它進程加載過,如果加載過,就做一個地址的重定位。這樣就避免了整個系統內多次加載相同DLL。如果沒有加載過,就按照從槽的高地址到槽的低地址的順序查找空閑的地址空間。然后分配足夠的地址空間用于加載DLL。因為每個進程在執行前都要映射到Slot 0,而且進程使用的所有DLL可能來自不同的槽(Slot),為避免所有使用的DLL在映射到Slot 0中出現地址空間沖突的現象,內核的加載器(Loader)在加載DLL時會查找所有槽中加載的DLL的地址,保證在映射到Slot 0時不會發生地址沖突現象。假如系統內有兩個進程,進程A只加載了DLL A,進程B
此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲精品日本| 在线欧美亚洲| 久久久www成人免费无遮挡大片 | 国产一区二区三区网站| 欧美日韩免费观看一区| 久久综合伊人77777| 香蕉尹人综合在线观看| 一本久久综合亚洲鲁鲁五月天| 久久国产黑丝| 亚洲欧美在线视频观看| 一区二区三欧美| 亚洲精品无人区| 国内成人自拍视频| 欧美日韩在线亚洲一区蜜芽| 欧美暴力喷水在线| 久久久精品五月天| 午夜在线精品偷拍| 亚洲免费在线观看| 中文av字幕一区| 亚洲人精品午夜| 久久精品99国产精品酒店日本| 午夜精品999| 亚洲欧美日韩国产综合| 一本色道88久久加勒比精品 | 欧美日韩综合另类| 欧美猛交免费看| 欧美激情一二三区| 欧美激情一区在线| 欧美二区在线| 欧美成人精品h版在线观看| 欧美一区二区在线播放| 午夜日韩在线| 午夜精品久久久久久久男人的天堂 | 亚洲高清免费在线| 久久精品91| 久久国产精品久久久| 欧美夜福利tv在线| 欧美一区二区日韩| 久久精品国产96久久久香蕉| 亚洲免费伊人电影在线观看av| 亚洲精品在线二区| 亚洲精品偷拍| 一区二区av在线| 亚洲午夜久久久久久久久电影院| 一区二区毛片| 亚洲午夜性刺激影院| 亚洲综合色激情五月| 99re66热这里只有精品4 | 日韩视频免费在线观看| 亚洲作爱视频| 亚洲视频免费观看| 亚洲欧美日韩久久精品 | 亚洲国产99| 亚洲精品美女在线观看播放| 99国产精品久久久久久久| 一区二区三区欧美成人| 亚洲欧美久久久久一区二区三区| 先锋a资源在线看亚洲| 亚洲二区视频在线| 亚洲精品自在久久| 中国成人在线视频| 中国成人亚色综合网站| 性伦欧美刺激片在线观看| 久久久久久97三级| 女生裸体视频一区二区三区| 欧美另类亚洲| 国产精品毛片大码女人| 国产区日韩欧美| 在线欧美日韩| 一区二区三区精品久久久| 亚洲网站视频| 久久超碰97中文字幕| 亚洲精品久久久久久一区二区| 在线一区二区日韩| 欧美一进一出视频| 久久综合影视| 欧美日韩在线免费观看| 国产精品豆花视频| 国内精品久久久| 亚洲三级电影全部在线观看高清| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美与黑人午夜性猛交久久久| 亚洲免费黄色| 久久精品噜噜噜成人av农村| 欧美激情视频在线免费观看 欧美视频免费一 | 国产一区二区成人久久免费影院| 亚洲丰满在线| 亚洲综合导航| 亚洲精品免费在线观看| 一本久道综合久久精品| 亚洲欧美综合国产精品一区| 欧美成人日韩| 国产日韩一区二区三区在线| 亚洲精品在线视频观看| 亚洲大黄网站| 亚洲女ⅴideoshd黑人| 美女福利精品视频| 欧美啪啪一区| 国产精品劲爆视频| 亚洲国产精品第一区二区三区| 亚洲欧美日韩精品久久| 99在线|亚洲一区二区| 久久精品国产第一区二区三区最新章节 | 欧美精品一区二区视频 | 国产欧美日韩在线观看| 亚洲精品一品区二品区三品区| 欧美一区二区三区视频| 在线亚洲欧美专区二区| 麻豆精品精华液| 国产伦精品一区二区三区四区免费| 亚洲激情六月丁香| 久久xxxx| 欧美一级免费视频| 欧美日韩三级| 亚洲电影免费观看高清完整版| 性久久久久久久久| 亚洲一区二区三区免费在线观看 | 欧美在线一区二区| 国产精品www.| 亚洲清纯自拍| 亚洲精美视频| 久久久亚洲国产美女国产盗摄| 欧美性猛交xxxx乱大交蜜桃| 亚洲欧洲综合| 亚洲三级影片| 久久午夜国产精品| 国产欧美一区二区三区在线老狼 | 在线亚洲欧美视频| 国产精品wwwwww| 亚洲欧美www| 久久精品国产免费观看| 韩国欧美一区| 亚洲福利在线观看| 欧美二区在线| 日韩一区二区福利| 午夜精品在线观看| 国产私拍一区| 亚洲电影在线| 欧美精品在线观看播放| 99热免费精品| 欧美在线视频全部完| 黄色成人av| 亚洲精品欧美激情| 欧美日韩在线不卡一区| 亚洲永久免费| 久久亚洲不卡| 亚洲日本欧美日韩高观看| 亚洲天堂久久| 国产免费观看久久黄| 亚洲高清视频一区| 欧美精品在线观看| 亚洲永久免费av| 久久久亚洲人| 亚洲精品精选| 欧美影院视频| 一区二区视频欧美| 亚洲校园激情| 国产主播一区二区三区| 亚洲精品日韩久久| 国产精品久久久久影院色老大| 欧美夜福利tv在线| 欧美激情一区二区三区在线 | 久久久夜夜夜| 亚洲毛片av| 久久精品国产久精国产一老狼| 91久久国产综合久久蜜月精品| 亚洲欧美国产高清| 在线观看三级视频欧美| 亚洲一区在线免费观看| 国产综合色一区二区三区 | 欧美体内she精视频| 欧美一区二区三区日韩视频| 欧美久久综合| 篠田优中文在线播放第一区| 欧美日韩aaaaa| 亚洲欧美日韩国产| 欧美激情一区二区三区成人| 亚洲欧美激情四射在线日| 欧美96在线丨欧| 亚洲男人的天堂在线aⅴ视频| 欧美成人免费va影院高清| 亚洲免费视频在线观看| 欧美成人精品1314www| 亚洲免费小视频| 欧美久久成人| 欧美呦呦网站| 国产精品豆花视频| 亚洲激情在线观看视频免费| 国产精品一区二区三区乱码| 日韩一区二区福利| 国模吧视频一区| 亚洲欧美中文字幕| 亚洲激情在线播放| 久久久久久综合网天天| 日韩一区二区精品| 欧美xxx成人| 久久精品观看| 国产日韩精品在线| 亚洲曰本av电影| 亚洲乱码一区二区|