• <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>

            S.l.e!ep.¢%

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

            sfilter(二) - 01 注冊FsFilter回調例程

            Posted on 2010-02-19 13:33 S.l.e!ep.¢% 閱讀(985) 評論(0)  編輯 收藏 引用 所屬分類: Windows WDM

            ??????? 04、注冊FsFilter回調例程:

            ??????? FsFilter通知回調例程在下層文件系統執行某些操作之前或之后調用。如果需要獲取更多有關于FsFilter回調例程相關信息,可參見FsRtlRegisterFileSystemFilterCallbacks例程
            ??????? 為了注冊FsFilter的通知回調例程必須分配并初始化FS_FILTER_CALLBACKS結構體,然后向該結構體中促出FsFilter回調例 程,并將存儲有Callbacks parameter到FsRtlRegisterFileSystemFilterCallbacks中。
            ??????? 例如:FileSpy驅動范例按如下方式注冊FsFilter回調。

            fsFilterCallbacks.SizeOfFsFilterCallbacks = sizeof(FS_FILTER_CALLBACKS);
            fsFilterCallbacks.PreAcquireForSectionSynchronization = SpyPreFsFilterOperation;
            fsFilterCallbacks.PostAcquireForSectionSynchronization = SpyPostFsFilterOperation;
            fsFilterCallbacks.PreReleaseForSectionSynchronization = SpyPreFsFilterOperation;
            fsFilterCallbacks.PostReleaseForSectionSynchronization = SpyPostFsFilterOperation;
            fsFilterCallbacks.PreAcquireForCcFlush = SpyPreFsFilterOperation;
            fsFilterCallbacks.PostAcquireForCcFlush = SpyPostFsFilterOperation;
            fsFilterCallbacks.PreReleaseForCcFlush = SpyPreFsFilterOperation;
            fsFilterCallbacks.PostReleaseForCcFlush = SpyPostFsFilterOperation;
            fsFilterCallbacks.PreAcquireForModifiedPageWriter = SpyPreFsFilterOperation;
            fsFilterCallbacks.PostAcquireForModifiedPageWriter = SpyPostFsFilterOperation;
            fsFilterCallbacks.PreReleaseForModifiedPageWriter = SpyPreFsFilterOperation;
            fsFilterCallbacks.PostReleaseForModifiedPageWriter = SpyPostFsFilterOperation;

            status = FsRtlRegisterFileSystemFilterCallbacks(DriverObject, &fsFilterCallbacks);

            MSDN的詳細解釋

            Windows Driver Kit: Installable File System Drivers
            FsRtlRegisterFileSystemFilterCallbacks

            File system filter drivers call the FsRtlRegisterFileSystemFilterCallbacks routine to register notification callback routines to be invoked when the underlying file system performs certain operations.

            文件系統過濾驅動調用 FsRtlRegisterFileSystemFilterCallbacks 函數注冊需通知回調函數,這些回調函數將在文件系統的相關操作之前被調用

            				
            						
            NTSTATUS

            ??FsRtlRegisterFileSystemFilterCallbacks(
            ????IN?PDRIVER_OBJECT??FilterDriverObject,
            ????IN?PFS_FILTER_CALLBACKS??Callbacks
            ????);?

            Parameters

            FilterDriverObject
            Pointer to the driver object for the filter driver.
            Callbacks
            Pointer to a structure that contains the entry points of caller-supplied notification callback routines.

            This structure is defined as follows.

            Note: All of the callback entry points are optional and can be NULL.

            typedef?struct?_FS_FILTER_CALLBACKS?{
            ????ULONG?SizeOfFsFilterCallbacks;
            ????ULONG?Reserved;
            ????PFS_FILTER_CALLBACK?PreAcquireForSectionSynchronization;
            ????PFS_FILTER_COMPLETION_CALLBACK?PostAcquireForSectionSynchronization;
            ????PFS_FILTER_CALLBACK?PreReleaseForSectionSynchronization;
            ????PFS_FILTER_COMPLETION_CALLBACK?PostReleaseForSectionSynchronization;
            ????PFS_FILTER_CALLBACK?PreAcquireForCcFlush;
            ????PFS_FILTER_COMPLETION_CALLBACK?PostAcquireForCcFlush;
            ????PFS_FILTER_CALLBACK?PreReleaseForCcFlush;
            ????PFS_FILTER_COMPLETION_CALLBACK?PostReleaseForCcFlush;
            ????PFS_FILTER_CALLBACK?PreAcquireForModifiedPageWriter;
            ????PFS_FILTER_COMPLETION_CALLBACK?PostAcquireForModifiedPageWriter;
            ????PFS_FILTER_CALLBACK?PreReleaseForModifiedPageWriter;
            ????PFS_FILTER_COMPLETION_CALLBACK?PostReleaseForModifiedPageWriter;
            }?FS_FILTER_CALLBACKS,?*PFS_FILTER_CALLBACKS;

            The filter callback routine and its parameters are defined as follows:

            typedef
            NTSTATUS?(*PFS_FILTER_CALLBACK)?(
            ??????????????IN?PFS_FILTER_CALLBACK_DATA?Data,
            ??????????????OUT?PVOID?*CompletionContext
            ??????????????);

            ParameterMeaning
            DataPointer to the callback data structure for this operation.? 指向這個操作的回調數據結構
            CompletionContextContext information to be passed to the filter completion callback routine. Set to NULL if no context information is to be passed or if there is no corresponding filter completion callback routine.??傳給過濾器完成回調函數的上下文信息

            The filter completion callback routine and its parameters are defined as follows:

            typedef
            VOID?(*PFS_FILTER_COMPLETION_CALLBACK)?(
            ??????????IN?PFS_FILTER_CALLBACK_DATA?Data,
            ??????????IN?NTSTATUS?OperationStatus,
            ??????????IN?PVOID?CompletionContext
            ??????????);

            ParameterMeaning
            DataPointer to the callback data structure for this operation.
            OperationStatusStatus of the operation. If the file system successfully performed the operation, this parameter is set to STATUS_SUCCESS. Otherwise, it is set to an appropriate error status value.
            CompletionContextContext information that was set in the filter callback routine. This is set to NULL if no information is passed or if there is no corresponding filter callback routine.

            The callback data structure and its members are defined as follows:

            typedef?struct?_FS_FILTER_CALLBACK_DATA?{
            ????ULONG?SizeOfFsFilterCallbackData;
            ????UCHAR?Operation;
            ????UCHAR?Reserved;
            ????struct?_DEVICE_OBJECT?*DeviceObject;
            ????struct?_FILE_OBJECT?*FileObject;
            ????FS_FILTER_PARAMETERS?Parameters;
            }?FS_FILTER_CALLBACK_DATA,?*PFS_FILTER_CALLBACK_DATA;

            MemberMeaning
            SizeOfFsFilterCallbackDataSize of the callback data structure.
            OperationFile system operation for which the callback routine is to be invoked. This operation can be of the following: FS_FILTER_ACQUIRE_FOR_SECTION_SYNCHRONIZATION
            FS_FILTER_RELEASE_FOR_SECTION_SYNCHRONIZATION
            FS_FILTER_ACQUIRE_FOR_MOD_WRITE
            FS_FILTER_RELEASE_FOR_MOD_WRITE
            FS_FILTER_ACQUIRE_FOR_CC_FLUSH
            FS_FILTER_RELEASE_FOR_CC_FLUSH
            ReservedReserved for system use.
            DeviceObjectDevice object for this operation.
            FileObjectFile object for this operation.
            ParametersUnion containing any operation-specific parameters.

            The filter parameter union is defined as follows:

            typedef?union?_FS_FILTER_PARAMETERS?{
            ????struct?{
            ????????PLARGE_INTEGER?EndingOffset;
            ????????PERESOURCE?*ResourceToRelease;
            ????}?AcquireForModifiedPageWriter;
            ????struct?{
            ????????PERESOURCE?ResourceToRelease;
            ????}?ReleaseForModifiedPageWriter;
            ????struct?{
            ????????FS_FILTER_SECTION_SYNC_TYPE?SyncType;
            ????????ULONG?PageProtection;
            ????}?AcquireForSectionSynchronization;
            ????struct?{
            ????????PVOID?Argument1;
            ????????PVOID?Argument2;
            ????????PVOID?Argument3;
            ????????PVOID?Argument4;
            ????????PVOID?Argument5;
            ????}?Others;
            }?FS_FILTER_PARAMETERS,?*PFS_FILTER_PARAMETERS;

            ParameterMeaning
            EndingOffsetOffset of the last byte being written plus one.
            ResourceToReleaseResource to be released.
            SyncTypeType of synchronization requested for the section: SyncTypeCreateSection if a section is being created, SyncTypeOther otherwise.
            PageProtectionType of page protection requested for the section. Must be zero if SyncType is SyncTypeOther. Otherwise, one of the following flags, possibly ORed with PAGE_NOCACHE:
            PAGE_READONLY
            PAGE_READWRITE
            PAGE_WRITECOPY
            PAGE_EXECUTE
            Argument1Reserved for future use.
            Argument2Reserved for future use.
            Argument3Reserved for future use.
            Argument4Reserved for future use.
            Argument5Reserved for future use.

            Return Value

            FsRtlRegisterFileSystemFilterCallbacks can return one of the following status values:

            STATUS_SUCCESS
            The callback routines were successfully registered.
            STATUS_INSUFFICIENT_RESOURCES
            FsRtlRegisterFileSystemFilterCallbacks encountered a pool allocation failure when allocating memory to store the callback information.
            STATUS_INVALID_PARAMETER
            One of the parameters is invalid.

            Comments

            FsRtlRegisterFileSystemFilterCallbacks should only be called by file system filter drivers, and only from the filter's DriverEntry routine.

            FsRtlRegisterFileSystemFilterCallbacks registers the notification callback routines that were specified in the Callbacks parameter to be invoked when requests for certain file operations are sent to the underlying file system.

            Callback routines are currently defined for the following operations:

            Operation Notification Callback Routine and Callback Completion Routine
            The memory manager acquires a file exclusively before creating a memory-mapped section for a portion of the file.

            Note: For this operation, SyncType is set to SyncTypeCreateSection.

            PreAcquireForSectionSynchronization
            PostAcquireForSectionSynchronization
            The memory manager releases a file after creating a memory-mapped section for a portion of the file. PreReleaseForSectionSynchronization
            PostReleaseForSectionSynchronization
            A kernel component (such as the cache manager) acquires a file exclusively before temporarily disabling section creation for a portion of the file.

            Note: For this operation, SyncType is set to SyncTypeOther.

            PreAcquireForSectionSynchronization
            PostAcquireForSectionSynchronization

            Note: PreAcquireForSectionSynchronization should always return a success status code (such as STATUS_SUCCESS) for this operation. Returning any other type of status code causes the system to ASSERT on a checked build. (On free builds, the status code is ignored.)

            A kernel component (such as the cache manager) releases a file after temporarily disabling section creation for a portion of the file. PreReleaseForSectionSynchronization
            PostReleaseForSectionSynchronization
            The cache manager acquires a file exclusively before flushing a portion of the file from the cache. PreAcquireForCcFlush
            PostAcquireForCcFlush
            The cache manager releases a file after flushing a portion of the file from the cache. PreReleaseForCcFlush
            PostReleaseForCcFlush
            The modified page writer acquires a file exclusively before writing a portion of the file to disk. PreAcquireForModifiedPageWriter
            PostAcquireForModifiedPageWriter
            The modified page writer releases a file after writing a portion of the file to disk. PreReleaseForModifiedPageWriter
            PostReleaseForModifiedPageWriter

            The filter notification callback routine is invoked before the operation request is passed to lower-level filter drivers and the underlying file system. In the callback routine, the filter driver should perform any needed processing and immediately return STATUS_SUCCESS. If a filter driver's callback routine returns a status value other than STATUS_SUCCESS, this causes the operation request to fail. Repeated failure of certain requests, such as locking requests, can halt system progress. Thus, filter drivers should fail such a request only when absolutely necessary. When failing these requests, the filter driver should return an error status value that describes the error as completely and accurately as possible.

            Note??A filter driver's notification callback routine cannot fail a request to release a file system resource. If a filter driver returns a status value other than STATUS_SUCCESS from any of the following notification callback routines, the status value is ignored.

            • PreReleaseForSectionSynchronization
            • PreReleaseForCcFlush
            • PreReleaseForModifiedPageWriter

            The filter completion callback routine is invoked after the operation request is passed to lower-level filter drivers and the underlying file system. In the completion callback routine, the filter driver must perform any needed processing and immediately return.

            The callback routines defined by FsRtlRegisterFileSystemFilterCallbacks supersede the following fast I/O callback routines, which are obsolete and should not be used by file system filter drivers:

            • AcquireForCcFlush
            • AcquireFileForNtCreateSection
            • AcquireForModWrite
            • ReleaseForCcFlush
            • ReleaseFileForNtCreateSection
            • ReleaseForModWrite

            Requirements

            Versions: This routine is available on Update Rollup for Windows 2000 Service Pack 4 (SP4) and on Microsoft Windows XP and later.

            IRQL:?Any level

            Headers: Declared in Ntifs.h. Include Ntifs.h.

            久久亚洲AV成人出白浆无码国产| 久久无码人妻一区二区三区| 婷婷久久综合九色综合九七| 99久久国产精品免费一区二区| 亚洲熟妇无码另类久久久| www.久久热.com| 久久91精品国产91| 欧美激情精品久久久久| 久久久久久久波多野结衣高潮| 久久噜噜电影你懂的| 久久精品日日躁夜夜躁欧美| 亚洲伊人久久大香线蕉苏妲己| 久久婷婷五月综合国产尤物app| 国产精品欧美亚洲韩国日本久久 | 国内精品久久久久久99| 最新久久免费视频| 国产2021久久精品| 久久免费美女视频| 国产∨亚洲V天堂无码久久久| 久久亚洲日韩看片无码| 性做久久久久久久久| 国产高清美女一级a毛片久久w| 2020久久精品国产免费| 久久亚洲精品中文字幕| 97视频久久久| 久久亚洲国产精品成人AV秋霞| 久久久精品无码专区不卡| 999久久久国产精品| 久久91精品久久91综合| 国产精品久久久久9999| 久久久无码一区二区三区| 亚洲国产精品久久电影欧美| 亚洲国产精品18久久久久久| 亚洲综合日韩久久成人AV| 婷婷久久久亚洲欧洲日产国码AV| 亚洲乱码精品久久久久..| 亚洲香蕉网久久综合影视 | 日韩亚洲欧美久久久www综合网| 久久精品国产久精国产思思| 国产综合久久久久久鬼色| 93精91精品国产综合久久香蕉|