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

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

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

IRP_MJ_CLEANUP

保持進(jìn)程定義上下文信息的驅(qū)動器,必須在DispatchCleanup中包含cleanup請求。

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

入?yún)ⅲ?br>無

出參:

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

驅(qū)動器必須在DispatchClose中包含關(guān)閉請求和驅(qū)動器的可能發(fā)生的異常,因為該驅(qū)動器只能通過關(guān)閉系統(tǒng)來卸載設(shè)備,保持了系統(tǒng)分頁文件的的磁盤驅(qū)動器就屬于這類驅(qū)動器。具有該類特性驅(qū)動器支持動態(tài)卸載。

何時發(fā)送:
收到IRP_MJ_CLOSE請求意味著與目標(biāo)device object相關(guān)的file object句柄已經(jīng)關(guān)閉或釋放。所有的外部I/O請求都已結(jié)束或取消。

入?yún)ⅲ?br>無

出參:

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

kernel-mode驅(qū)動器必須在DispatchCreate或DispatchCreateClose中提出創(chuàng)建請求。

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

入?yún)ⅲ?br>無

出參:

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

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

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

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

注意:FileQuotaInformation類已不再使用,用IRP_MJ_QUERY_QUOTA代替。
執(zhí)行之后,結(jié)束IRP。

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

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

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

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

何時發(fā)送:
IRP_MJ_QUERY_VOLUME_INFORMATION請求由I/O管理器發(fā)送。當(dāng)user-mode程序調(diào)用GetDiskFreeSpace或GetFileType時會發(fā)送該請求。

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

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

向系統(tǒng)傳遞數(shù)據(jù)的驅(qū)動器必須在DispatchRead或DispatchReadWrite中包含read請求,在此類驅(qū)動器上分層的higher-level驅(qū)動器也必須這樣做。

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

入?yún)ⅲ?br>IRP中的驅(qū)動器I/O stack位置指示Parameters.Read.Length.傳送多少byte數(shù)據(jù)。
有些驅(qū)動器通過Parameters.Read.Key對在device queue或驅(qū)動器管理的IRP內(nèi)部隊列中對read請求進(jìn)行排序。有的驅(qū)動器通過Parameters.Read.ByteOffset(指示傳送操作的offset)進(jìn)行排序。

出參:
根據(jù)驅(qū)動器對device object Flag的是DO_BUFFERED_IO還是DO_DIRECT_IO,采用不同的方法傳遞數(shù)據(jù):
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驅(qū)動器會通過為next-lower驅(qū)動器設(shè)置IRP中的I/O stack位置,或者為lower驅(qū)動器創(chuàng)建并設(shè)置附加的IRP??梢哉{(diào)用IoSetCompletionRoutine設(shè)置IoCompletion(在IRP輸入中是可選的,但在driver-created IRP是必須的)。
接收到該請求之后,驅(qū)動器將器device傳送給系統(tǒng)memory。結(jié)束IRP的過程中,驅(qū)動器將設(shè)置I/O stack block為傳遞的byte數(shù)量。
 
//------------------------------------------------------------------------------------------
IRP_MJ_SET_INFORMATION

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

操作:文件系統(tǒng)驅(qū)動器
文件系統(tǒng)驅(qū)動器提取file object信息并進(jìn)行解析,由此判斷用戶是打開一個文件還是打開一個目錄,這樣,驅(qū)動器處理查詢并結(jié)束IRP。
可供設(shè)置的文件、目錄屬性信息如下:
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

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

何時發(fā)送:
client通過set information請求改變串行設(shè)備上打開的文件結(jié)尾位置時發(fā)送。

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

向系統(tǒng)傳遞數(shù)據(jù)的驅(qū)動器必須在DispatchWrite或DispatchReadWrite中包含write請求,在此類驅(qū)動器上分層的higher-level驅(qū)動器也必須這樣做。

何時發(fā)送:
成功結(jié)束creat請求的時間域內(nèi)。
可能由包含file object句柄(代表請求過從從該device傳遞數(shù)據(jù)的目標(biāo)device object)的user-mode程序或win32組件發(fā)送。也可能由創(chuàng)建和設(shè)置write IRP的higher-level驅(qū)動器發(fā)送。

入?yún)ⅲ?br>IRP中的驅(qū)動器I/O stack位置指示Parameters.Write.Length.傳送多少byte數(shù)據(jù)。
有些驅(qū)動器通過Parameters.Write.Key對在device queue或驅(qū)動器管理的IRP內(nèi)部隊列中對write請求進(jìn)行排序。有的驅(qū)動器通過Parameters.write.ByteOffset(指示傳送操作的offset)進(jìn)行排序。
根據(jù)驅(qū)動器對device object Flag的是DO_BUFFERED_IO還是DO_DIRECT_IO,采用不同的方法傳遞數(shù)據(jù):
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驅(qū)動器會通過為next-lower驅(qū)動器設(shè)置IRP中的I/O stack位置,或者為lower驅(qū)動器創(chuàng)建并設(shè)置附加的IRP??梢哉{(diào)用IoSetCompletionRoutine設(shè)置IoCompletion(在IRP輸入中是可選的,但在driver-created IRP是必須的)。之后,驅(qū)動器通過IoCallDriver傳遞請求給next-lower驅(qū)動器。
接收到該請求之后,驅(qū)動器將數(shù)據(jù)從系統(tǒng)memory傳遞到自身的device。結(jié)束IRP的過程中,驅(qū)動器將設(shè)置I/O stack block為傳遞的byte數(shù)量。
//------------------------------------------------------------------------------------------
IRP_MJ_WRITE*
分段寫入,提供Offset,每次寫入65536字節(jié)。

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

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   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>
            欧美日韩在线影院| 欧美制服第一页| 亚洲欧美一区二区激情| 亚洲毛片播放| 一本到高清视频免费精品| 日韩午夜电影av| 一本色道88久久加勒比精品| 日韩一本二本av| 亚洲一区二区欧美日韩| 午夜精品久久久久久久蜜桃app| 欧美自拍偷拍| 麻豆精品在线观看| 亚洲黄色在线| 99在线热播精品免费| 亚洲亚洲精品在线观看 | 一区二区三区视频观看| 亚洲欧美日韩一区二区| 老司机午夜精品| 欧美午夜不卡影院在线观看完整版免费 | 欧美一区二区三区免费在线看| 久久久久五月天| 亚洲毛片视频| 久久精品女人| 欧美色图五月天| 伊人影院久久| 亚洲综合色丁香婷婷六月图片| 欧美在线免费观看视频| 亚洲人成在线观看一区二区| 亚洲一区精品视频| 欧美激情网友自拍| 樱花yy私人影院亚洲| 亚洲免费一在线| 免费观看日韩| 香蕉久久夜色精品| 欧美日韩麻豆| 亚洲国产精品小视频| 亚洲欧美在线aaa| 国产欧美日韩在线| 日韩视频免费观看| 免费日韩精品中文字幕视频在线| 一区二区高清视频| 欧美成人官网二区| 国产亚洲日本欧美韩国| 999亚洲国产精| 欧美激情自拍| 久久裸体艺术| 国内精品伊人久久久久av影院| 宅男噜噜噜66一区二区| 亚洲国产99| 巨乳诱惑日韩免费av| 国产亚洲福利社区一区| 亚洲欧美日本国产专区一区| 亚洲激情亚洲| 欧美区一区二| 这里是久久伊人| 亚洲第一区在线| 欧美成人黄色小视频| 在线成人免费视频| 欧美jizzhd精品欧美巨大免费| 午夜精品区一区二区三| 国产一区二区毛片| 久久久久国产精品人| 亚洲欧美综合另类中字| 国产人久久人人人人爽| 久久精品免费| 久久精品视频亚洲| 亚洲第一区中文99精品| 久久蜜臀精品av| 久久久久国产精品人| 在线观看国产一区二区| 欧美二区乱c少妇| 欧美风情在线观看| 亚洲神马久久| 亚洲欧美国产高清va在线播| 国产精品专区第二| 久久一区二区三区av| 欧美.com| 一区二区三区四区蜜桃| 亚洲一级免费视频| 悠悠资源网久久精品| 亚洲精品社区| 国产日韩视频| 欧美激情亚洲自拍| 国产精品久久久久久久久免费樱桃| 欧美一级黄色录像| 久热精品视频| 亚洲综合精品四区| 久久久一区二区三区| 99精品视频免费观看视频| 亚洲免费视频网站| 亚洲电影在线观看| 在线综合视频| 伊人久久婷婷| 在线一区二区三区四区五区| 国内一区二区在线视频观看 | 亚洲精品一区中文| 国产一区久久久| 免费日韩一区二区| 欧美激情国产日韩| 久久精品99国产精品| 久久夜色精品国产噜噜av| 亚洲校园激情| 欧美va亚洲va国产综合| 午夜国产欧美理论在线播放 | 久久久久久伊人| 一本色道久久综合狠狠躁的推荐| 亚洲男同1069视频| 日韩一区二区精品在线观看| 久久成人羞羞网站| 亚洲色图综合久久| 欧美成人免费全部观看天天性色| 午夜精品久久久久| 欧美激情精品| 老鸭窝亚洲一区二区三区| 国产精品丝袜xxxxxxx| 亚洲精品视频中文字幕| 在线观看一区视频| 亚洲一区综合| 亚洲男人的天堂在线观看| 欧美高清视频一二三区| 久久综合网hezyo| 国产欧美一区二区精品仙草咪| 亚洲美女淫视频| 99爱精品视频| 欧美片在线观看| 亚洲破处大片| 亚洲人成7777| 免费不卡视频| 欧美激情国产精品| 亚洲国产精品一区二区第一页| 久久成人资源| 久久蜜桃资源一区二区老牛| 国产一区二区三区电影在线观看| 亚洲视频一区在线观看| 亚洲欧美日产图| 国产日韩在线视频| 久久久久久久97| 欧美二区在线播放| 亚洲欧洲日本国产| 欧美bbbxxxxx| 99精品热视频只有精品10| 国产精品99久久久久久有的能看| 欧美日韩国产精品自在自线| 亚洲深夜影院| 久久久久免费视频| 亚洲欧洲日产国码二区| 欧美激情aⅴ一区二区三区| 亚洲精品韩国| 亚洲欧美视频在线观看| 国产欧美精品| 久久婷婷丁香| 欧美国产日韩二区| 亚洲视频一二| 国产在线播精品第三| 美女主播一区| 日韩写真在线| 久久精品观看| 91久久久久久| 国产精品草草| 久久久免费精品| 夜夜嗨av一区二区三区网页| 久久精品国产69国产精品亚洲 | 在线观看一区| 久久久国产午夜精品| 免费av成人在线| 99爱精品视频| 久久久久久久一区二区三区| 亚洲激情在线| 国产精品二区二区三区| 久久久久久久网| 一本色道精品久久一区二区三区 | 欧美新色视频| 欧美一区高清| 亚洲毛片在线免费观看| 久久婷婷丁香| 亚洲综合视频一区| 亚洲精品视频免费| 韩国女主播一区二区三区| 欧美精品一区二区三区蜜臀| 欧美一区二区三区日韩视频| 亚洲国产精彩中文乱码av在线播放| 正在播放欧美一区| 在线激情影院一区| 欧美视频你懂的| 久久亚洲高清| 亚洲欧美日韩中文在线制服| 亚洲精品国精品久久99热一| 毛片一区二区三区| 欧美呦呦网站| 亚洲一区精彩视频| 一区二区三区日韩欧美| 91久久精品一区二区别| 怡红院精品视频在线观看极品| 国产欧美日韩伦理| 国产精品欧美日韩| 国产精品午夜视频| 国产精品久久久久久一区二区三区 | 欧美日韩国产综合视频在线观看中文| 久久精品免视看| 欧美在线视频观看免费网站|