www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(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認識,如有錯誤,也希望批評指正。(其中參考了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從而釋放的空間。最后,當系統(tǒng)到達一個最低內(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原理仍然相當簡單,但有一點更加靈活。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)存。但是當這種情況發(fā)生時,內(nèi)核會喚醒一個低優(yōu)先級的線程去page out一些數(shù)據(jù),重新使pool慢慢降到target以下。采用這種方式,在busy “spikes”內(nèi)存使用時,比如系統(tǒng)啟動,系統(tǒ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í)行文件被標志為“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)載請標明出處: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)系本站刪除。
換一批
延伸閱讀

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ù)學會聯(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)閉