青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

一、 何謂可分頁和非分頁內存


??????
默認情況下,內核加載器會加載所有的代碼部分和全局數據到非分頁內存中。而且,加載器是一次加載整個驅動的可執行文件,包括相關的 DLL 。加載后,內核加載器關閉驅動程序文件,甚至你可以刪除當前正在執行的驅動文件。
但是,你可以告訴加載器你希望驅動的哪部分是可分頁,所謂可分頁,就是可能會被換頁出內存( Page out )。可以使用下面的指令來實現:
#define ALLOC_PRAGMA
#pragma alloc_text(PAGE, function_name1)
#pragma alloc_text(PAGE, function_name2)

#endif
??????

?????? function_namex 指定的函數代碼將被放置于可分頁內存中。
使數據段可分頁,使用下面的編譯指令:
#ifdef ALLOC_PRAGMA
#pragma data_seg(PAGE)

//
define your pageeble data section module here.
#pragma data_seg()

要注意,絕不能讓可能在高的 IRQL 級別被調用的例程被換出頁面。

??????
可以調用 MmLockPageableCodeSection MmLockPageableCodeSection-
ByHandle
來鎖定被標志為可分頁的代碼段。
可以調用 MmLockPageableDataSection MmLockPageableDataSectionB-
yHandle
來鎖定被標志為可分頁的數據段
可以調用 MmUnlockPageableImageSection 來解除被上面列出的函數鎖定的代碼
或數據段。
可以調用 MmPageEntireDriver 使整個驅動程序可分頁,覆蓋使用編譯指令修飾的段的頁面屬性。
可以調用 MmResetDriverPaging 把頁面屬性重設回最初描述的屬性。

??????
最后,把那些驅動初始化后不再需要的代碼自動丟棄可以使用這些編譯指令:
#ifdef ALLOC_PRAGMA
#pragma alloc_text(INIT, DriverEntry)

#pragma alloc_text(INIT, function_name) // function called by driverEntry

#endif
驅動程序在執行時可能需要動態分配內存空間,這時你要決定需要的是可分頁還是不可分頁的內存。如果你的驅動在運行中訪問內存的時候能夠經受頁錯誤,那么盡量使用可分頁內存。

注意:大多數低層磁盤和網絡驅動通常不能使用可分頁內存,因為他們的代碼常常在較高的 IRQL 等級執行而不允許頁錯誤。但是,文件系統(通常比磁盤驅動占用更大,更多資源)有時候可從可分頁池中分配一些內存。

?????? 非分頁內存在整個系統中是一個有限的資源,其數量依賴于系統使用的類型,和系統可用的物理內存。 NT 提供下面的例程給內核驅動來分配內存:

ExAllocatePool

ExAllocatePoolWithQuota

ExAllocatePoolWithTag

ExAllocatePoolWithQuotaTag

調用這些函數來請求內存時,必須要指定請求的內存的類型:

NonPagedPool??? 請求分配一個不可分頁的內存

PagedPool?????? 請求分配一個可分頁的內存

?????????? 如果你在分配的內存里有任何同步結構的話,決不要分配分頁內存。

?????????? 當你的應用訪問內存時候可以處理頁錯誤的時候,應該指定這個類型。

NonPagedPoolMustSucceed

????????????? 在其它方式都失敗時,而你又必須立即得到內存的時候可以使用這個標志 類型。注意這種類型的內存是極度缺乏的資源,可能不足 16K 。注意,只 有在其它途徑都失敗的時候才使用,如果分配失敗,將會導致系統的 bugcheck ,錯誤代碼是 MUST_SUCCEED_POOL_EMPTY

NonPagedPoolCacheAligned

?????????? 這個標志分配使用數據緩存線的尺寸來在 CPU 特定的邊界對齊的非分頁 內存。注意這個操作默認是在 Intel 平臺上的 NonPagedPool 分配類型。

PagedPoolCacheAligned

?????????? 這個標志分配使用數據緩存線的尺寸來在 CPU 特定的邊界對齊的分頁 內存。

NonPagedPoolCacheAlignedMustSucceed

?????????? 參考 NonPagedPoolMustSucceed NonPagedPoolCacheAligned

?????? 內 存池分配器初始化了一些列表,每個列表包含一種固定大小的塊。當你使用上面的函數請求內存時,例程試圖分配一個和你請求數量相近的或更大一點的固定大小的 塊。但是,如果你要求的數量超過一頁時,或者超過列表中最大塊的大小時,又或者在預先分配的列表中沒有可用的塊的時候, VMM 就會從任何適當類型的系統可用的內存中分配你請求的數量內存給你。

?????? 當預先分配的列表空了的時候, VMM 會分配至少一頁的內存,切分,然后把剩下的數據放進適當的塊列表中。但是,當你請求的非分頁內存的數量超過 PAGE_SIZE 時候,內存池分配例程不會切分未使用的部分,這會浪費寶貴的非分頁內存。

也可以使用 MmAllocateNonCachedMemory MmAllocateContiguousMemory

來分配非分頁或物理連續內存。它們通常不使用在文件系統或者過濾驅動中,而是用于執行池例程或者其它結構。

?????? 內核驅動如果重復的分配和釋放小塊的內存(小于一個 PAGE_SIZE , 可能導致系統的可用物理內存碎片化。這會給系統帶來各種問題,包括降低系統的性能等。有一個方法可以避免系統碎片化,就是預先分配一塊合理大小的內存,然后自已管理,在這個預先分配的塊中分配和釋放小塊的內存,但這種方法有可能會浪費核心內存。

二、用池來管理內存

?????? 上面提到用預先分配一塊合理大小的內存來自已管理,可以避免系統內存碎片。我們可以用池來管理這塊預先分配的內存。必須再次強調,預先分配的內存大小必須足夠準確,太大會浪費寶貴的資源。

?????? 調用 ExAllocatePool 來分配池使用的內存,你要選擇從分頁或者非分頁的池中分配,注意你的內存片基址必須在 8 字節的邊界對齊。

?????? 還要分配和初始化一個自旋鎖或者使用其它的同步機制來保護對內存塊列表的修改。注意不要在比 DISPATCH_LEVEL 更高的 IRQL 等級使用池操作例程,因為在更高的 IRQL 等級不能使用同步結構。

?????? 然后定義一個 ZONE_HEADER 結構的全局變量,用來作為這個池的控制結構,并調用 ExInitializeZone 來初始化池頭部。然后,就可以通過調用 ExAllocateFromZone

ExInterlockedAllocateFromZone 來分配自已管理的內存塊。這兩個函數的差別在于后者使用了自旋鎖用于操作同步。調用 ExFreeToZone ExInterlockedFreeToZone 來釋放分配的內存。

?????? 雖然池幫助減少系統內存的碎片,但池還是有一些不足:

1、 驅動程序必須預先為池分配內存,這些內存可能會閑置很久造成內存浪費

2、 你對需要的內存的數量必須相當的精確,在很多時候這個很難做到。

3、 當內存需求增大時,可以擴大池的尺寸,但是卻不能減小池的尺寸,直到重啟系統

lookaside lists

lookaside lists NT4.0 里新的特性,它突破了池的限制。

?????? 當你調用 ExInitializeNPagedLookasideList ExInitializePagedlookasideList 初始化 lookaside lists 時不用預先分配內存,相反,只有當你有真正需要內存的時候才分配。

在初始化時,你必須指定列表的深度,表示尺寸的最大值。相關的函數有 ExAllocateFromN-

PagedLookasideList ExAllocateFromPagedLookasideList 。我們用一個 NPAGED_

LOOKASIDE_LIST PAGED_LOOKASIDE_LIST 結構變量來保存 lookaside lists 的狀態,注意這結構一定要從非分頁內存中分配。

PAGED_LOOKASIDE_LIST

typedef struct _MYDATASTRUCT
{
CHAR buffer[64];
} MYDATASTRUCT,*PMYDATASTRUCT;

VOID LookasideTest()
{
#define NUM 50
PMYDATASTRUCT structs[NUM];

PAGED_LOOKASIDE_LIST Lookaside;
ExInitializePagedLookasideList(&Lookaside, NULL, NULL, 0, sizeof(MYDATASTRUCT), '1234', 0);

// 頻繁請求內存
for(int i = 0; i < NUM; i++)
{
?? structs[i] = (PMYDATASTRUCT)ExAllocateFromPagedLookasideList(&Lookaside);
}

// 頻繁釋放內存
for(int i = 0; i < NUM; i++)
{
?? ExFreeToPagedLookasideList(&Lookaside, structs[i]);
?? structs[i] = NULL;
}

ExDeletePagedLookasideList(&Lookaside);
}

Feedback

# re: 驅動中的幾種內存分配和釋放的用法  回復  更多評論   

2012-03-24 23:17 by cghy2011
學習了 好厲害
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲影音一区| 亚洲国产高清自拍| 亚洲第一在线综合网站| 国产精品久久久久久亚洲调教| 久久久久一区二区三区| 欧美日韩国产综合久久| 牛牛影视久久网| 国产欧美高清| 中文在线资源观看网站视频免费不卡| 亚洲成人资源网| 欧美有码在线视频| 午夜在线视频一区二区区别| 欧美日韩国产999| 亚洲大片在线观看| 亚洲国产精品成人综合色在线婷婷| 一区二区三区免费看| 9人人澡人人爽人人精品| 免费在线播放第一区高清av| 久久人人97超碰精品888| 国产日韩精品综合网站| 亚洲专区免费| 性色一区二区| 国产精品一区二区你懂得 | 在线中文字幕一区| 欧美不卡视频一区发布| 老色批av在线精品| 激情综合网址| 久久性天堂网| 亚洲国产精品va在线观看黑人| 激情久久五月| 久久综合久久综合这里只有精品| 欧美不卡激情三级在线观看| 亚洲大胆人体视频| 美女日韩欧美| 亚洲三级观看| 亚洲一区二区综合| 国产九九精品| 久久久久久9| 你懂的网址国产 欧美| 亚洲人成绝费网站色www| 免费成人性网站| 亚洲精品免费网站| 午夜精品视频在线观看| 国产欧美日韩另类视频免费观看 | 午夜影院日韩| 久久在线观看视频| 亚洲经典三级| 欧美日韩一区二区三区| 亚洲影院在线| 美女国产一区| 日韩一级黄色片| 国产精品手机视频| 久久国产免费| 亚洲精品国产精品国自产观看| 亚洲午夜小视频| 国内揄拍国内精品少妇国语| 你懂的视频一区二区| 夜夜嗨av一区二区三区四区| 久久精彩视频| 日韩亚洲视频在线| 国产精品视频网| 另类欧美日韩国产在线| 夜夜精品视频| 蜜桃av一区二区| 亚洲一区二区三区免费在线观看| 国产在线高清精品| 欧美日韩福利视频| 欧美一区免费| 9i看片成人免费高清| 久久天堂成人| 亚洲一区二区高清视频| 在线精品一区| 国产精品毛片va一区二区三区| 久久久久久九九九九| 亚洲深夜福利在线| 亚洲国产欧美久久| 久久久久久一区二区三区| 亚洲午夜久久久| 亚洲国产精品毛片| 国产一区二区三区日韩欧美| 欧美日韩亚洲成人| 美女视频网站黄色亚洲| 欧美一区二区在线播放| 99视频日韩| 91久久精品国产| 老司机一区二区三区| 欧美资源在线| 亚洲一区视频在线| 一本色道久久99精品综合| 亚洲国产成人在线播放| 国产日韩一区在线| 国产精品色网| 国产精品成人v| 欧美日韩精品久久久| 美日韩精品免费观看视频| 久久精品欧美| 欧美在线黄色| 校园激情久久| 亚洲欧美在线看| 亚洲一区二区欧美日韩| 日韩视频三区| 99国产精品99久久久久久| 亚洲国产精品欧美一二99| 欧美成人午夜77777| 女人天堂亚洲aⅴ在线观看| 久久av一区| 久久精品日产第一区二区三区| 欧美亚洲一区二区在线观看| 欧美亚洲在线观看| 小嫩嫩精品导航| 欧美一区二区在线看| 篠田优中文在线播放第一区| 午夜精品久久久久久久男人的天堂 | 亚洲免费观看在线观看| 亚洲精品一区二区在线观看| 亚洲欧洲另类国产综合| 日韩午夜中文字幕| 亚洲一区二区精品在线| 亚洲一区尤物| 久久高清国产| 久久网站免费| 欧美激情乱人伦| 亚洲精品视频啊美女在线直播| 亚洲免费不卡| 午夜精品亚洲一区二区三区嫩草| 欧美在线视屏| 欧美jizz19hd性欧美| 欧美日韩国产精品| 国产麻豆成人精品| 黑人巨大精品欧美一区二区 | 韩日精品中文字幕| 亚洲国产午夜| 在线亚洲观看| 久久福利精品| 欧美国产三级| 中文亚洲视频在线| 久久大香伊蕉在人线观看热2| 欧美www视频| 欧美性猛交xxxx乱大交蜜桃| 国产亚洲毛片| 日韩视频免费看| 性久久久久久| 亚洲第一在线综合网站| 一区二区三区高清视频在线观看| 久久爱91午夜羞羞| 欧美精品一区二区三| 国产香蕉久久精品综合网| 亚洲激情第一区| 午夜一区二区三区在线观看| 蜜桃伊人久久| 亚洲天堂av综合网| 欧美/亚洲一区| 国产欧美日韩一区二区三区在线| 亚洲高清不卡一区| 亚洲欧美久久久久一区二区三区| 久久亚洲综合网| 亚洲视频高清| 欧美成人在线影院| 国产在线观看精品一区二区三区| 最近看过的日韩成人| 久久精品成人欧美大片古装| 亚洲人午夜精品| 久久成年人视频| 国产精品老牛| 日韩系列在线| 免费亚洲一区| 午夜视黄欧洲亚洲| 国产精品福利在线观看网址| 最新国产成人av网站网址麻豆| 久久福利资源站| 一区二区三区久久网| 欧美电影打屁股sp| 1000部精品久久久久久久久| 亚洲欧美精品中文字幕在线| 亚洲精品久久久久| 免费毛片一区二区三区久久久| 国内精品久久国产| 久久国产精品99国产| 亚洲私人影院在线观看| 欧美日韩天堂| 99精品热6080yy久久| 亚洲国产精品成人综合| 久久美女性网| 黄色一区二区在线| 久久久久网址| 香蕉久久久久久久av网站| 国产精品第一页第二页第三页| 99re66热这里只有精品3直播 | 欧美国产激情二区三区| 亚洲国产精品一区制服丝袜| 麻豆精品网站| 久久亚洲欧洲| 亚洲国产一区二区在线| 亚洲电影毛片| 欧美肥婆在线| 99视频在线精品国自产拍免费观看| 亚洲高清久久网| 欧美日本网站| 亚洲天堂av在线免费观看| 一本久道久久综合中文字幕|