日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀] 我們知道,在Config.bib配置中,RAM指定的內(nèi)存區(qū)域會被劃分為程序內(nèi)存和對象存儲。但在使用paging pool時,RAM段要減去paging pool的大小,剩余空間再劃分為程序內(nèi)存和對

 我們知道,在Config.bib配置中,RAM指定的內(nèi)存區(qū)域會被劃分為程序內(nèi)存和對象存儲。但在使用paging pool時,RAM段要減去paging pool的大小,剩余空間再劃分為程序內(nèi)存和對象存儲。其中程序內(nèi)存主要為正在運行的程序保存堆和棧的內(nèi)容。

那么paging pool是什么呢,使用paging pool有什么好處呢?在查閱了相關(guān)資料后談?wù)勎业囊稽c認(rèn)識,如有錯誤,也希望批評指正。(其中參考了Sue Loh的《Paging and the Windows CE Paging Pool》一文,有興趣的可以看一下。)

先看一下paging pool的概念。Paging pool是RAM中reserved的一塊區(qū)域。用于存放pageale data(只讀的可執(zhí)行文件的代碼,數(shù)據(jù)以及內(nèi)存映射文件)。如果使用paging pool就會給pageale data所使用的內(nèi)存設(shè)定限制,它還包括將pagable data從內(nèi)存移出的算法機制。

在WinCE3.0以前的系統(tǒng),并沒有使用paging pool。這意味著系統(tǒng)對保存pageable data所使用的RAM沒有限制。那么如果運行大量的程序或訪問大量的內(nèi)存映射文件時,內(nèi)存使用率就會大大增加,直到系統(tǒng)耗盡內(nèi)存,這時再分配內(nèi)存就會失敗??雌饋砗孟駜?nèi)存真的用完了,但實際上還存在大量可以通過page data out從而釋放的空間。最后,當(dāng)系統(tǒng)到達(dá)一個最低內(nèi)存限制時,kernel就會把所有的pageble的數(shù)據(jù)全部page out。這樣突然間系統(tǒng)就會出現(xiàn)大量可用內(nèi)存,你要使用的數(shù)據(jù)就會通過產(chǎn)生page fault重新page in到內(nèi)存。但這樣會帶來系統(tǒng)的不穩(wěn)定。

因此WinCE引入了paging pool。The paging pool limits an amount of pageable memory system can has so it would be less "thrashing" prone. 使用paging pool,會設(shè)置有限的RAM用于存放pageable的data。Pool的size設(shè)置太小,這意味著pages可能會被過早地page out,盡管他們?nèi)匀辉谑褂?,從而引起頻繁的page fault。Pool大小設(shè)置得太大,這意味著操作系統(tǒng)將保留更多的內(nèi)存用于pageable data。這樣就會減少page faults ,因為更多的代碼存儲在paging pool中。但Pool內(nèi)存將無法被應(yīng)用程序使用。

在CE 6.0中,虛擬內(nèi)存的架構(gòu)改變了,涉及Windows CE的存儲系統(tǒng)的重寫,包括paging pool。CE 6.0的paging pool原理仍然相當(dāng)簡單,但有一點更加靈活。CE 6.0有兩個paging pools:loader pool用來存放可執(zhí)行代碼,file pool用于存放所有file-backed memory-mapped文件和CE6.0新增的文件cache過濾器,或者叫cache管理器。以這種方式,OEMs不但可以設(shè)置只讀數(shù)據(jù)的內(nèi)存使用量,而且可以設(shè)置read-write數(shù)據(jù)的內(nèi)存使用量了。并且可以分別為代碼和數(shù)據(jù)設(shè)置內(nèi)存使用的限制。

這兩個pool有幾個參數(shù)。主要的參數(shù)是target size和maximum size。原理是操作系統(tǒng)總會保證pool擁有至少target數(shù)量的內(nèi)存使用。如果有多余的可用內(nèi)存,內(nèi)核允許pool占有多于target的內(nèi)存。但是當(dāng)這種情況發(fā)生時,內(nèi)核會喚醒一個低優(yōu)先級的線程去page out一些數(shù)據(jù),重新使pool慢慢降到target以下。采用這種方式,在busy “spikes”內(nèi)存使用時,比如系統(tǒng)啟動,系統(tǒng)會占用相當(dāng)多的內(nèi)存用來存放pagable data。但是在steady-state,系統(tǒng)的pool內(nèi)存使用量在target上下徘徊。Maximum size為內(nèi)存消耗設(shè)置了硬性的限制。OEMs可以把這個maximum設(shè)的很大從而避免pool的限制。OEMs也可以把target和maximum大小設(shè)置的相同,從而獲取CE6之前的版本的paging pool的效果。

paging和paging pool是獨立的。不管是不是paging pool都會發(fā)生paging。如果你關(guān)閉了paging pool,你也就關(guān)掉了用于paging的RAM的限制。但是pages仍然可以paging。如果你打開了paging pool,那么就會有限制。只不過對于paging pool,page in的data還可以page out。而對于非paging pool中的data則不會被page out。

ROM中的中的FILES中可執(zhí)行文件的code和只讀data將會使用pool??蓤?zhí)行文件中的R/W data不能被page out,所以不會使用paging pool。MODULES中的壓縮的可執(zhí)行文件中的code和只讀data也會使用pool。如果Image是從NOR或者RAM運行,MODULES中未壓縮的可執(zhí)行文件將直接運行,而不使用pool。NAND中Image中MODULES中的可執(zhí)行文件將會使用pool。

如果可執(zhí)行文件被標(biāo)志為“non-pagable”,則在加載時就會被page到RAM中,不會被page out,直到被卸載。這些Pages不使用pool。你也可以創(chuàng)造些“partially pagable”的可執(zhí)行文件,通過告訴linker使部分sections non-pagable。一般如果code和data是ISR的一部分,或者在suspend/resume時被調(diào)用,或被其他電源管理調(diào)用,就不能是pagable的,因為paging會造成系統(tǒng)崩潰或死鎖。如果code和data被IST訪問也不能是pagable,因為paging會影響實時性。

RAM-backed的內(nèi)存映射文件不會使用Pool。在CE5或更老的版本中,只讀的file-back mapfiles會使用Pool而R/W mapfiles不使用。在CE6中,所有的file-backed mapfiles都使用file pool。并且新的file cache filter(cache manager)會映射所有打開的文件,所以cached file data也使用pool。

在CE5.0中,如果想使用paging pool,只需在Config.bib中定義如下:

#define PAGINGPOOLSIZE 00500000

cbNKPagingPoolSize 00000000 $(PAGINGPOOLSIZE) FIXUPVAR

即把paging pool的size設(shè)置為5MB。如果設(shè)置為0或者不設(shè)置的話,就沒打開paging pool,沒有對存放pageable的data和code的RAM的限制,效果和上面談到的WinCE3.0之前沒有paging pool時一樣。不過建議使用paging pool。Pool的size設(shè)置是個難題,過大過小都不合適。不過在CE 6.0中,如果將size設(shè)置為0的話,系統(tǒng)就會自動調(diào)節(jié)cbNKPagingPoolSize,這樣就比較方便了。

本文來自CSDN博客,轉(zhuǎn)載請標(biāo)明出處:http://blog.csdn.net/flyalice/archive/2009/02/16/3897253.aspx

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