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

隨筆-60  評論-98  文章-0  trackbacks-0

根據MSDN翻譯的,網上許多兄弟問此類的問題,解答很少。希望本文能有所幫助。

IRP_MJ_CLEANUP

保持進程定義上下文信息的驅動器,必須在DispatchCleanup中包含cleanup請求。

何時發送:
收到IRP_MJ_CLEANUP意味著請求的目標設備與目標文件的句柄相關(也可能因為io請求后沒有釋放)

入參:

出參:

操作:
該IRP在關閉 file  object 句柄的進程上下文中發送。因此,驅動器應該釋放進程上下文中所指定的資源,比如之前驅動器鎖定或映射的user memory等。
如果驅動器的 device objects 狀態是exclusive,則該device是獨占性的,一次只能為一個線程服務。驅動器必須結束當前目標 device object 隊列中的所有IRP,并設置其I/O status block為STATUS_CANCELLED。
另外,驅動器只是需要取消并結束與待釋放的file object句柄相關的IRP隊列成員。(指向file object的指針位于驅動器IRP IO_STACK_LOCATION的FileObject成員中。)取消隊列中的IRP后,驅動器結束了clear up IRP操作,并將自身的I/O status block置為STATUS_SUCCESS。
//------------------------------------------------------------------------------------------
IRP_MJ_CLOSE

驅動器必須在DispatchClose中包含關閉請求和驅動器的可能發生的異常,因為該驅動器只能通過關閉系統來卸載設備,保持了系統分頁文件的的磁盤驅動器就屬于這類驅動器。具有該類特性驅動器支持動態卸載。

何時發送:
收到IRP_MJ_CLOSE請求意味著與目標device object相關的file object句柄已經關閉或釋放。所有的外部I/O請求都已結束或取消。

入參:

出參:

操作:
很少有設備會設置IRP的status block為STATUS_SUCCESS結束關閉請求。驅動器如何處理關閉請求取決于其設計。通常,驅動器在收到IRP_MJ_CREATE后會undo自己的操作結果。device object為exclusive的驅動器,比如串行驅動器,在收到該請求后也可能會reset硬件。
IRP_MJ_CLOSE不是在關閉了file object句柄的進程上下文中發送的。如果驅動器必須釋放進程指定的資源,比如驅動器之前鎖定或映射的user memeory等,就會對IRP_MJ_CLEANUP請求做同樣的響應。
//------------------------------------------------------------------------------------------
IRP_MJ_CREATE

kernel-mode驅動器必須在DispatchCreate或DispatchCreateClose中提出創建請求。

何時發送:
收到該請求意味著user-mode保護的子系統(可能代表的是某個應用程序),請求一個file object句柄,該局并代表特定的目標device object,或者是較高級別的驅動器正在連接器device object到目標device object。

入參:

出參:

操作:
與IRP_MJ_CLOSE類似,對IRP_MJ_CREATE的相應取決與驅動器的設計,很少有驅動器會設置IRP的I/O status block為STATUS_SUCCESS。帶有pageable-image單元的驅動器,像系統串行驅動器,會通過映射自身的page-out代碼,來為那些嘗試打開設備進行I/O操作的user-mode線程提供資源。

//------------------------------------------------------------------------------------------
IRP_MJ_DIRECTORY_CONTROL

何時發送:
IRP_MJ_DIRECTORY_CONTROL請求是由I/O管理器和其他操作系統組件(比如kernel-mode驅動器)發送的。當user-mode程序調用ReadDirectoryChangesW、FindNextVolumeMountPoint或者kernal-mode componenet調用ZwQueryDirectoryFile時,會發送該請求。

操作:文件系統驅動器
文件系統驅動器通過檢查監控程序code來判斷判斷執行哪一個目錄控制操作。有效的監控程序codes:
IRP_MN_NOTIFY_CHANGE_DIRECTORY
請求告知目錄變更。通常文件系統驅動器會將此IRP放到私有的隊列中,而不是立即進行滿足該請求。 當目錄發生變更時,文件系統驅動器執行通知目錄變更操作,出隊,結束該IRP。
IRP_MN_QUERY_DIRECTORY
目錄查詢請求。消息類型因文件系統而異,通常包括以下幾種:
FileBothDirectoryInformation
FileDirectoryInformation
FileFullDirectoryInformation
FileIdBothDirectoryInformation
FileIdFullDirectoryInformation
FileNamesInformation
FileObjectIdInformation
FileReparsePointInformation

注意:FileQuotaInformation類已不再使用,用IRP_MJ_QUERY_QUOTA代替。
執行之后,結束IRP。

操作:文件系統過濾驅動器
過濾驅動器將該IRP向棧上的下一層驅動器傳遞。
//------------------------------------------------------------------------------------------
IRP_MJ_QUERY_INFORMATION

何時發送:
IRP_MJ_QUERY_INFORMATION請求的發送和IRP_MJ_DIRECTORY_CONTROL類似,是由I/O管理器和其他操作系統組件(比如kernel-mode驅動器)發送的。調用GetFileInformationByHandle或ZwQueryInformationFile時發送。

操作:文件系統驅動器
文件系統驅動器提取file object信息并進行解析,由此判斷用戶是打開一個文件還是打開一個目錄,這樣,驅動器處理查詢并結束IRP。如果不能對信息進行提取解析,驅動器結束IRP,不處理查詢。
可供查詢的文件和目錄信息因文件系統而異,通常包括如下幾種:
FileAllInformation
FileAttributeTagInformation
FileBasicInformation
FileCompressionInformation
FileEaInformation
FileInternalInformation
FileNameInformation
FileNetworkOpenInformation
FilePositionInformation
FileStandardInformation
FileStreamInformation
ZwQueryInformationFile支持FileAccessInformation, FileAlignmentInformation, 和 FileModeInformation 類型,而無需向文件系統發送IRP_MJ_QUERY_INFORMATION請求,因為他們與文件系統無關。

操作:文件系統過濾驅動器
過濾驅動器將該IRP向棧上的下一層驅動器傳遞。
//------------------------------------------------------------------------------------------
IRP_MJ_QUERY_VOLUME_INFORMATION

何時發送:
IRP_MJ_QUERY_VOLUME_INFORMATION請求由I/O管理器發送。當user-mode程序調用GetDiskFreeSpace或GetFileType時會發送該請求。

操作:文件系統驅動器
文件系統驅動器通過對file object進行提取和解碼,判斷目標device object是不是該文件系統的control device object。如果是,并且請求的是打開volume(或者打開volume上的object),文件系統驅動器會處理請求并結束IRP。如果不是,文件系統驅動器查詢失敗,結束IRP。
可供查詢的volume信息類型因文件系統而異,通常有如下幾種類型:
FileFsAttributeInformation
FileFsDeviceInformation
FileFsSizeInformation
FileFsVolumeInformation

操作:文件系統過濾驅動器
過濾驅動器將該IRP向棧上的下一層驅動器傳遞。
//------------------------------------------------------------------------------------------
IRP_MJ_READ

向系統傳遞數據的驅動器必須在DispatchRead或DispatchReadWrite中包含read請求,在此類驅動器上分層的higher-level驅動器也必須這樣做。

何時發送:
在完成create請求的之后的時間域內發送。
可能由包含file object句柄(代表請求過從從該device傳遞數據的目標device object)的user-mode程序或win32組件發送。也可能由創建和設置read IRP的higher-level驅動器發送。

入參:
IRP中的驅動器I/O stack位置指示Parameters.Read.Length.傳送多少byte數據。
有些驅動器通過Parameters.Read.Key對在device queue或驅動器管理的IRP內部隊列中對read請求進行排序。有的驅動器通過Parameters.Read.ByteOffset(指示傳送操作的offset)進行排序。

出參:
根據驅動器對device object Flag的是DO_BUFFERED_IO還是DO_DIRECT_IO,采用不同的方法傳遞數據:
The buffer at Irp->AssociatedIrp.SystemBuffer if the driver uses buffered I/O
The buffer described by the MDL at Irp->MdlAddress if the underlying device driver uses direct I/O (DMA or PIO)

操作:
接收到read請求之后,higher-level驅動器會通過為next-lower驅動器設置IRP中的I/O stack位置,或者為lower驅動器創建并設置附加的IRP。可以調用IoSetCompletionRoutine設置IoCompletion(在IRP輸入中是可選的,但在driver-created IRP是必須的)。
接收到該請求之后,驅動器將器device傳送給系統memory。結束IRP的過程中,驅動器將設置I/O stack block為傳遞的byte數量。
 
//------------------------------------------------------------------------------------------
IRP_MJ_SET_INFORMATION

何時發送:
IRP_MJ_SET_INFORMATION請求的發送和IRP_MJ_QUERY_INFORMATION、IRP_MJ_DIRECTORY_CONTROL類似,是由I/O管理器和其他操作系統組件(比如kernel-mode驅動器)發送的。調用SetEndOfFile或ZwSetInformationFile時發送。

操作:文件系統驅動器
文件系統驅動器提取file object信息并進行解析,由此判斷用戶是打開一個文件還是打開一個目錄,這樣,驅動器處理查詢并結束IRP。
可供設置的文件、目錄屬性信息如下:
FileBasicInformation
FileDispositionInformation
FileLinkInformation (for file systems that allow cycles to be created in the directory hierarchy)
FilePositionInformation
FileRenameInformation
文件專有屬性:
FileAllocationInformation
FileEndOfFileInformation
FileLinkInformation (for file systems, such as NTFS, that do not allow cycles to be created in the directory hierarchy)
FileValidDataLengthInformation

操作:文件系統過濾驅動器
過濾驅動器將該IRP向棧上的下一層驅動器傳遞。
//------------------------------------------------------------------------------------------
IRP_MJ_SET_INFORMATION*
IRP_MJ_SET_INFORMATION (Serial)

何時發送:
client通過set information請求改變串行設備上打開的文件結尾位置時發送。

//------------------------------------------------------------------------------------------
IRP_MJ_WRITE

向系統傳遞數據的驅動器必須在DispatchWrite或DispatchReadWrite中包含write請求,在此類驅動器上分層的higher-level驅動器也必須這樣做。

何時發送:
成功結束creat請求的時間域內。
可能由包含file object句柄(代表請求過從從該device傳遞數據的目標device object)的user-mode程序或win32組件發送。也可能由創建和設置write IRP的higher-level驅動器發送。

入參:
IRP中的驅動器I/O stack位置指示Parameters.Write.Length.傳送多少byte數據。
有些驅動器通過Parameters.Write.Key對在device queue或驅動器管理的IRP內部隊列中對write請求進行排序。有的驅動器通過Parameters.write.ByteOffset(指示傳送操作的offset)進行排序。
根據驅動器對device object Flag的是DO_BUFFERED_IO還是DO_DIRECT_IO,采用不同的方法傳遞數據:
The buffer at Irp->AssociatedIrp.SystemBuffer, if the driver uses buffered I/O
The buffer described by the MDL at Irp->MdlAddress, if the underlying device driver uses direct I/O (DMA or PIO)

出參:

操作:
接收到write請求之后,higher-level驅動器會通過為next-lower驅動器設置IRP中的I/O stack位置,或者為lower驅動器創建并設置附加的IRP。可以調用IoSetCompletionRoutine設置IoCompletion(在IRP輸入中是可選的,但在driver-created IRP是必須的)。之后,驅動器通過IoCallDriver傳遞請求給next-lower驅動器。
接收到該請求之后,驅動器將數據從系統memory傳遞到自身的device。結束IRP的過程中,驅動器將設置I/O stack block為傳遞的byte數量。
//------------------------------------------------------------------------------------------
IRP_MJ_WRITE*
分段寫入,提供Offset,每次寫入65536字節。

posted on 2007-12-22 16:36 創建更好的解決方案 閱讀(6091) 評論(0)  編輯 收藏 引用 所屬分類: 性能監測

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩一区在线| 欧美成年人视频网站| 宅男噜噜噜66一区二区66| 久久视频在线看| 国产精品一区视频| 一区二区三区鲁丝不卡| 欧美成人午夜影院| 欧美在线不卡| 国产精品免费观看在线| 亚洲一区二区视频在线| 亚洲麻豆视频| 欧美激情视频在线播放 | 国产精品二区三区四区| 亚洲免费电影在线| 亚洲第一网站| 久久成人久久爱| 国产欧美日韩精品a在线观看| 亚洲性图久久| 夜夜嗨av一区二区三区中文字幕| 欧美日韩国产一区精品一区| 亚洲最新色图| 99国产精品99久久久久久粉嫩| 欧美日韩精品免费观看视一区二区 | 亚洲在线观看免费| 一区二区欧美国产| 国产精品女主播一区二区三区| 一本色道久久综合亚洲精品不| 亚洲美女在线视频| 国产精品久久久久91| 久久激情网站| 久久精品在线播放| 亚洲国产裸拍裸体视频在线观看乱了中文| 麻豆成人综合网| 欧美黑人多人双交| 在线视频日本亚洲性| 亚洲国产精品久久人人爱蜜臀| 一区二区亚洲精品国产| 欧美高清在线观看| 欧美日韩精品系列| 欧美亚洲视频在线看网址| 亚洲综合清纯丝袜自拍| 国内成+人亚洲| 亚洲人成在线免费观看| 欧美午夜不卡在线观看免费| 欧美中文字幕不卡| 免费观看国产成人| 午夜激情综合网| 久久九九国产精品| 亚洲视频一区在线| 欧美在线视频日韩| 亚洲伦理网站| 亚洲欧美日韩精品久久奇米色影视| 一色屋精品视频在线观看网站| 亚洲区国产区| 一区二区三区在线视频免费观看| 亚洲人成毛片在线播放| 国产一级揄自揄精品视频| 久久综合狠狠综合久久综青草 | 欧美午夜激情小视频| 久久久青草青青国产亚洲免观| 欧美韩日精品| 久久岛国电影| 欧美日韩亚洲精品内裤| 久久全国免费视频| 欧美无乱码久久久免费午夜一区| 你懂的视频欧美| 国产精品一区二区三区观看 | 久久久国产一区二区| 夜夜精品视频一区二区| 久久久999精品| 午夜在线精品| 欧美视频网址| 亚洲国产日韩一级| 娇妻被交换粗又大又硬视频欧美| 亚洲天堂偷拍| 一本久道久久综合婷婷鲸鱼| 久久一区二区三区四区五区| 久久精品毛片| 国产欧美精品日韩| 亚洲图片欧洲图片av| 一本一本久久| 欧美xx视频| 欧美刺激午夜性久久久久久久| 黄色成人av| 久久国产精品亚洲77777| 欧美专区一区二区三区| 国产精品日韩精品| 在线一区亚洲| 亚洲欧美国产精品桃花| 欧美日本精品在线| 亚洲精品一区二区三区樱花| 久久久久欧美精品| 久久夜色精品国产亚洲aⅴ| 国产视频欧美视频| 午夜精品福利视频| 欧美一区二区性| 国产视频一区欧美| 亚洲精品1234| 久久资源av| 男男成人高潮片免费网站| 韩日精品视频| 久久精品国产精品亚洲综合| 久久久精品免费视频| 国产精品久久久久77777| 99热这里只有成人精品国产| 亚洲午夜高清视频| 国产精品video| 亚洲无人区一区| 欧美在线日韩精品| 激情欧美一区二区三区| 久久这里只精品最新地址| 欧美国产综合一区二区| 99国产精品99久久久久久粉嫩| 欧美日韩三区| 亚洲小视频在线观看| 性欧美8khd高清极品| 国产亚洲精品资源在线26u| 久久精品国产99国产精品澳门| 久久男人av资源网站| 亚洲国产精品久久91精品| 欧美精品成人91久久久久久久| 99re热这里只有精品视频| 欧美亚洲视频| 在线欧美影院| 欧美午夜精品久久久久久孕妇| 亚洲欧美精品中文字幕在线| 久久人人97超碰精品888| 日韩一级二级三级| 国产精品人人做人人爽人人添| 欧美一区二区三区喷汁尤物| 欧美国产视频一区二区| 亚洲一区二区视频在线| 伊人色综合久久天天五月婷| 麻豆av一区二区三区| 一区二区三区鲁丝不卡| 久久综合色影院| 亚洲三级免费| 国产欧美va欧美va香蕉在| 久久综合中文色婷婷| 在线视频欧美精品| 欧美成年人在线观看| 亚洲一级黄色片| 黄色日韩网站| 国产精品jvid在线观看蜜臀| 久久亚洲精品伦理| 亚洲永久免费| 亚洲国产高潮在线观看| 久久夜色精品| 久久精品在线| 午夜精品久久久久久99热软件| 亚洲精品久久视频| 国产视频丨精品|在线观看| 欧美屁股在线| 久久免费视频观看| 亚洲午夜激情| 亚洲美女中文字幕| 亚洲高清视频在线| 久久天天综合| 亚洲香蕉网站| 亚洲卡通欧美制服中文| 在线免费观看欧美| 国内伊人久久久久久网站视频| 国产精品扒开腿做爽爽爽软件| 欧美韩日视频| 欧美大片在线看| 美女日韩欧美| 久久黄色网页| 久久国产综合精品| 久久精品国产亚洲5555| 亚洲欧美日韩一区在线观看| 亚洲伦理自拍| 日韩视频一区二区| 欧美视频一区在线| 久久精品国产精品亚洲综合| 亚洲欧美久久久| 亚洲永久在线| 亚洲小视频在线| 亚洲五月六月| 亚洲综合国产| 欧美一级视频免费在线观看| 亚洲砖区区免费| 亚洲欧美日韩精品久久久| 中文在线一区| 亚洲图片欧洲图片日韩av| 国产精品99久久99久久久二8 | 一区电影在线观看| 亚洲三级免费| 亚洲免费观看高清完整版在线观看熊 | 极品尤物av久久免费看| 国产一区二区电影在线观看| 国产日韩欧美制服另类| 国产亚洲一本大道中文在线| 国产三级欧美三级日产三级99| 国产欧美短视频| 国产亚洲欧洲997久久综合| 国产一区清纯| 亚洲国产精品第一区二区三区| 亚洲精美视频| 亚洲一区二区在线视频| 欧美一区二区三区在线看|