亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ctxinit.c

?? miniFilter.rar所有框架代碼以及對(duì)應(yīng)的PPT資料,可以直接拿來(lái)進(jìn)行修改即可完成各種驅(qū)動(dòng),是你開發(fā)微軟新過濾構(gòu)架驅(qū)動(dòng)所必下資料
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*++

Copyright (c) 1999 - 2003  Microsoft Corporation

Module Name:

    ContextInit.c

Abstract:

    This is the main module of the kernel mode filter driver implementing
    the context sample.


Environment:

    Kernel mode


--*/

#include "pch.h"

//
//  Global variables
//

CTX_GLOBAL_DATA Globals;


//
//  Local function prototypes
//

NTSTATUS
DriverEntry (
    __in PDRIVER_OBJECT DriverObject,
    __in PUNICODE_STRING RegistryPath
    );

NTSTATUS
CtxUnload (
    __in FLT_FILTER_UNLOAD_FLAGS Flags
    );

VOID
CtxContextCleanup (
    __in PFLT_CONTEXT Context,
    __in FLT_CONTEXT_TYPE ContextType
    );

NTSTATUS
CtxInstanceSetup (
    __in PCFLT_RELATED_OBJECTS FltObjects,
    __in FLT_INSTANCE_SETUP_FLAGS Flags,
    __in DEVICE_TYPE VolumeDeviceType,
    __in FLT_FILESYSTEM_TYPE VolumeFilesystemType
    );

NTSTATUS
CtxInstanceQueryTeardown (
    __in PCFLT_RELATED_OBJECTS FltObjects,
    __in FLT_INSTANCE_QUERY_TEARDOWN_FLAGS Flags
    );

VOID
CtxInstanceTeardownStart (
    __in PCFLT_RELATED_OBJECTS FltObjects,
    __in FLT_INSTANCE_TEARDOWN_FLAGS Flags
    );

VOID
CtxInstanceTeardownComplete (
    __in PCFLT_RELATED_OBJECTS FltObjects,
    __in FLT_INSTANCE_TEARDOWN_FLAGS Flags
    );

#if DBG

VOID
CtxInitializeDebugLevel (
    __in PUNICODE_STRING RegistryPath
    );

#endif

//
//  Assign text sections for each routine.
//

#ifdef ALLOC_PRAGMA
#pragma alloc_text(INIT, DriverEntry)

#if DBG
#pragma alloc_text(INIT, CtxInitializeDebugLevel)
#endif

#pragma alloc_text(PAGE, CtxUnload)
#pragma alloc_text(PAGE, CtxContextCleanup)
#pragma alloc_text(PAGE, CtxInstanceSetup)
#pragma alloc_text(PAGE, CtxInstanceQueryTeardown)
#pragma alloc_text(PAGE, CtxInstanceTeardownStart)
#pragma alloc_text(PAGE, CtxInstanceTeardownComplete)
#endif


//
//  Filter driver initialization and unload routines
//

NTSTATUS
DriverEntry (
    __in PDRIVER_OBJECT DriverObject,
    __in PUNICODE_STRING RegistryPath
    )
/*++

Routine Description:

    This is the initialization routine for this filter driver. It registers
    itself with the filter manager and initializes all its global data structures.

Arguments:

    DriverObject - Pointer to driver object created by the system to
        represent this driver.

    RegistryPath - Unicode string identifying where the parameters for this
        driver are located in the registry.

Return Value:

    Returns STATUS_SUCCESS.

--*/
{
    NTSTATUS status;

    //
    //  Filters callback routines
    //

    FLT_OPERATION_REGISTRATION callbacks[] = {

        { IRP_MJ_CREATE,
          FLTFL_OPERATION_REGISTRATION_SKIP_PAGING_IO,
          CtxPreCreate,
          CtxPostCreate },

        { IRP_MJ_CLEANUP,
          FLTFL_OPERATION_REGISTRATION_SKIP_PAGING_IO,
          CtxPreCleanup,
          NULL },

        { IRP_MJ_CLOSE,
          FLTFL_OPERATION_REGISTRATION_SKIP_PAGING_IO,
          CtxPreClose,
          NULL },

        { IRP_MJ_SET_INFORMATION,
          FLTFL_OPERATION_REGISTRATION_SKIP_PAGING_IO,
          CtxPreSetInfo,
          CtxPostSetInfo },

        { IRP_MJ_OPERATION_END }
    };

    const FLT_CONTEXT_REGISTRATION contextRegistration[] = {

        { FLT_INSTANCE_CONTEXT,
          0,
          CtxContextCleanup,
          CTX_INSTANCE_CONTEXT_SIZE,
          CTX_INSTANCE_CONTEXT_TAG },

        { FLT_FILE_CONTEXT,
          0,
          CtxContextCleanup,
          CTX_FILE_CONTEXT_SIZE,
          CTX_FILE_CONTEXT_TAG },

        { FLT_STREAM_CONTEXT,
          0,
          CtxContextCleanup,
          CTX_STREAM_CONTEXT_SIZE,
          CTX_STREAM_CONTEXT_TAG },

        { FLT_STREAMHANDLE_CONTEXT,
          0,
          CtxContextCleanup,
          CTX_STREAMHANDLE_CONTEXT_SIZE,
          CTX_STREAMHANDLE_CONTEXT_TAG },

        { FLT_CONTEXT_END }
    };

    //
    // Filters registration data structure
    //

    FLT_REGISTRATION filterRegistration = {

        sizeof( FLT_REGISTRATION ),                     //  Size
        FLT_REGISTRATION_VERSION,                       //  Version
        0,                                              //  Flags
        contextRegistration,                            //  Context
        callbacks,                                      //  Operation callbacks
        CtxUnload,                                      //  Filters unload routine
        CtxInstanceSetup,                               //  InstanceSetup routine
        CtxInstanceQueryTeardown,                       //  InstanceQueryTeardown routine
        CtxInstanceTeardownStart,                       //  InstanceTeardownStart routine
        CtxInstanceTeardownComplete,                    //  InstanceTeardownComplete routine
        NULL, NULL, NULL                                //  Unused naming support callbacks
    };


    RtlZeroMemory( &Globals, sizeof( Globals ) );

#if DBG

    //
    //  Initialize global debug level
    //

    CtxInitializeDebugLevel( RegistryPath );

#else

    UNREFERENCED_PARAMETER( RegistryPath );

#endif

    DebugTrace( DEBUG_TRACE_LOAD_UNLOAD,
                ("[Ctx]: Driver being loaded\n") );



    //
    //  Register with the filter manager
    //

    status = FltRegisterFilter( DriverObject,
                                &filterRegistration,
                                &Globals.Filter );

    if (!NT_SUCCESS( status )) {

        return status;
    }

    //
    //  Start filtering I/O
    //

    status = FltStartFiltering( Globals.Filter );

    if (!NT_SUCCESS( status )) {

        FltUnregisterFilter( Globals.Filter );
    }

    DebugTrace( DEBUG_TRACE_LOAD_UNLOAD,
                ("[Ctx]: Driver loaded complete (Status = 0x%08X)\n",
                status) );

    return status;
}

#if DBG

VOID
CtxInitializeDebugLevel (
    __in PUNICODE_STRING RegistryPath
    )
/*++

Routine Description:

    This routine tries to read the filter DebugLevel parameter from
    the registry.  This value will be found in the registry location
    indicated by the RegistryPath passed in.

Arguments:

    RegistryPath - The path key passed to the driver during DriverEntry.

Return Value:

    None.

--*/
{
    OBJECT_ATTRIBUTES attributes;
    HANDLE driverRegKey;
    NTSTATUS status;
    ULONG resultLength;
    UNICODE_STRING valueName;
    UCHAR buffer[sizeof( KEY_VALUE_PARTIAL_INFORMATION ) + sizeof( LONG )];

    Globals.DebugLevel = DEBUG_TRACE_ERROR;

    //
    //  Open the desired registry key
    //

    InitializeObjectAttributes( &attributes,
                                RegistryPath,
                                OBJ_CASE_INSENSITIVE,
                                NULL,
                                NULL );

    status = ZwOpenKey( &driverRegKey,
                        KEY_READ,
                        &attributes );

    if (NT_SUCCESS( status )) {

        //
        // Read the DebugFlags value from the registry.
        //

        RtlInitUnicodeString( &valueName, L"DebugLevel" );

        status = ZwQueryValueKey( driverRegKey,
                                  &valueName,
                                  KeyValuePartialInformation,
                                  buffer,
                                  sizeof(buffer),
                                  &resultLength );

        if (NT_SUCCESS( status )) {

            Globals.DebugLevel = *((PULONG) &(((PKEY_VALUE_PARTIAL_INFORMATION) buffer)->Data));
        }
    }

    //
    //  Close the registry entry
    //

    ZwClose( driverRegKey );
}

#endif

NTSTATUS
CtxUnload (
    __in FLT_FILTER_UNLOAD_FLAGS Flags
    )
/*++

Routine Description:

    This is the unload routine for this filter driver. This is called
    when the minifilter is about to be unloaded. We can fail this unload
    request if this is not a mandatory unloaded indicated by the Flags
    parameter.

Arguments:

    Flags - Indicating if this is a mandatory unload.

Return Value:

    Returns the final status of this operation.

--*/
{
    UNREFERENCED_PARAMETER( Flags );

    PAGED_CODE();

    DebugTrace( DEBUG_TRACE_LOAD_UNLOAD,
                ("[Ctx]: Unloading driver\n") );


    FltUnregisterFilter( Globals.Filter );
    Globals.Filter = NULL;

    return STATUS_SUCCESS;
}

VOID
CtxContextCleanup (
    __in PFLT_CONTEXT Context,
    __in FLT_CONTEXT_TYPE ContextType
    )
{
    PCTX_INSTANCE_CONTEXT instanceContext;
    PCTX_FILE_CONTEXT fileContext;
    PCTX_STREAM_CONTEXT streamContext;
    PCTX_STREAMHANDLE_CONTEXT streamHandleContext;

    PAGED_CODE();

    switch(ContextType) {

    case FLT_INSTANCE_CONTEXT:

        instanceContext = (PCTX_INSTANCE_CONTEXT) Context;

        DebugTrace( DEBUG_TRACE_INSTANCE_CONTEXT_OPERATIONS,
                    ("[Ctx]: Cleaning up instance context for volume %wZ (Context = %p)\n",
                     &instanceContext->VolumeName,
                     Context) );

        //
        //  Here the filter should free memory or synchronization objects allocated to
        //  objects within the instance context. The instance context itself should NOT
        //  be freed. It will be freed by Filter Manager when the ref count on the
        //  context falls to zero.
        //

        CtxFreeUnicodeString( &instanceContext->VolumeName );

        DebugTrace( DEBUG_TRACE_INSTANCE_CONTEXT_OPERATIONS,
                    ("[Ctx]: Instance context cleanup complete.\n") );

        break;


    case FLT_FILE_CONTEXT:

        fileContext = (PCTX_FILE_CONTEXT) Context;

        DebugTrace( DEBUG_TRACE_FILE_CONTEXT_OPERATIONS,
                    ("[Ctx]: Cleaning up file context for file %wZ (FileContext = %p)\n",
                     &fileContext->FileName,
                     fileContext) );


        //
        //  Free the file name
        //

        if (fileContext->FileName.Buffer != NULL) {

            CtxFreeUnicodeString(&fileContext->FileName);
        }

        DebugTrace( DEBUG_TRACE_FILE_CONTEXT_OPERATIONS,
                    ("[Ctx]: File context cleanup complete.\n") );

        break;

    case FLT_STREAM_CONTEXT:

        streamContext = (PCTX_STREAM_CONTEXT) Context;

        DebugTrace( DEBUG_TRACE_STREAM_CONTEXT_OPERATIONS,
                    ("[Ctx]: Cleaning up stream context for file %wZ (StreamContext = %p) \n\tCreateCount = %x \n\tCleanupCount = %x, \n\tCloseCount = %x\n",

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99国产欧美另类久久久精品| 免费一级欧美片在线观看| 亚洲国产精品久久久久秋霞影院| 亚洲3atv精品一区二区三区| 久久国产精品第一页| 成人国产精品免费网站| 欧美视频在线一区| 久久久久九九视频| 亚洲国产日日夜夜| 国产乱子轮精品视频| 91免费看`日韩一区二区| 6080午夜不卡| 中文字幕免费一区| 日韩激情av在线| 99精品视频在线观看| 日韩一区二区不卡| 亚洲免费av观看| 久久成人免费网| 色94色欧美sute亚洲线路一久 | 亚洲三级在线免费观看| 免费的国产精品| 日本韩国精品在线| 精品88久久久久88久久久| 亚洲综合在线免费观看| 国产一区二区三区美女| 69av一区二区三区| 亚洲精品欧美综合四区| 国产酒店精品激情| 精品va天堂亚洲国产| 亚洲国产wwwccc36天堂| a在线播放不卡| 亚洲精品在线观看视频| 亚洲123区在线观看| 91丨九色丨蝌蚪富婆spa| 欧美精品一区二区三区蜜臀| 亚洲图片一区二区| 91影院在线观看| 国产日韩成人精品| 国内精品不卡在线| 欧美一区二区三区四区久久| 亚洲一区在线电影| 99精品热视频| 中文字幕第一区| 国产自产v一区二区三区c| 91麻豆精品国产91久久久久久| 亚洲美女在线国产| 成人a级免费电影| 久久欧美中文字幕| 久久se精品一区精品二区| 欧美日韩国产一级片| 一区二区三区久久| 色av一区二区| 亚洲精品国产一区二区精华液| 成人国产精品免费观看视频| 国产欧美一区二区三区在线看蜜臀 | 日本亚洲天堂网| 91国在线观看| 亚洲理论在线观看| 99久久伊人久久99| ...av二区三区久久精品| 成人aaaa免费全部观看| 国产欧美视频一区二区三区| 国产在线日韩欧美| 久久综合九色综合欧美98| 美女视频一区在线观看| 欧美一级片在线观看| 日本aⅴ免费视频一区二区三区| 欧美精品日韩精品| 日日夜夜精品免费视频| 欧美精品日韩精品| 青青草原综合久久大伊人精品优势| 欧美色男人天堂| 午夜久久久久久久久久一区二区| 欧美在线观看视频一区二区| 亚洲激情网站免费观看| 欧美午夜精品久久久久久孕妇| 一区二区三区中文字幕电影| 在线精品视频免费播放| 亚洲成人激情自拍| 9191久久久久久久久久久| 午夜激情久久久| 日韩一级免费一区| 国产精品资源网| 中文字幕中文在线不卡住| 91欧美激情一区二区三区成人| 亚洲精品久久久久久国产精华液| 在线视频你懂得一区| 午夜精品国产更新| 精品剧情在线观看| 国内精品在线播放| 国产精品久久久久7777按摩| 色哟哟一区二区| 亚洲v中文字幕| 精品国免费一区二区三区| 国产成人免费9x9x人网站视频| 国产精品麻豆久久久| 欧美综合亚洲图片综合区| 日本欧美一区二区三区| 久久久精品一品道一区| 91免费观看在线| 美女视频一区二区| 国产精品欧美综合在线| 欧美主播一区二区三区美女| 奇米精品一区二区三区在线观看| 久久午夜色播影院免费高清| 91免费看视频| 麻豆专区一区二区三区四区五区| 国产亚洲女人久久久久毛片| 色吊一区二区三区| 久久国产夜色精品鲁鲁99| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 中文字幕视频一区| 欧美视频一区在线| 精品一区二区免费看| 最新国产精品久久精品| 欧美精品乱人伦久久久久久| 国产精品自拍网站| 亚洲高清免费在线| 国产欧美一区二区精品性色 | 日韩精品欧美成人高清一区二区| 2024国产精品视频| 色婷婷狠狠综合| 精品一区二区三区视频| 亚洲男人的天堂网| 精品国产伦一区二区三区免费| 91在线国产福利| 九九精品视频在线看| 亚洲精品老司机| 久久久久亚洲蜜桃| 欧美欧美午夜aⅴ在线观看| 懂色av中文一区二区三区 | 精品少妇一区二区三区在线播放 | 亚洲人成人一区二区在线观看| 91精品国产欧美一区二区18| 99久久精品一区| 黄页视频在线91| 五月天亚洲婷婷| 国产精品久久久久久久裸模| 欧美一区二区黄色| 欧美亚洲日本国产| 99视频在线观看一区三区| 久久99热这里只有精品| 亚洲影院久久精品| 一色屋精品亚洲香蕉网站| 久久综合国产精品| 7777精品伊人久久久大香线蕉超级流畅 | 在线观看日韩国产| 成人sese在线| 国产精品小仙女| 日本伊人精品一区二区三区观看方式| 中文字幕亚洲一区二区va在线| 精品国产一区二区三区久久久蜜月 | 国产三级一区二区| 日韩欧美在线观看一区二区三区| 色狠狠av一区二区三区| 成人免费av网站| 国产麻豆成人传媒免费观看| 日本va欧美va精品发布| 亚洲国产欧美一区二区三区丁香婷| 国产精品人成在线观看免费| 久久久美女艺术照精彩视频福利播放| 欧美一级黄色录像| 欧美日韩国产精品自在自线| 色综合色狠狠综合色| 成人动漫一区二区| 国产成人在线网站| 国产一区二区三区在线观看免费视频 | 色综合中文字幕国产 | 中文字幕亚洲一区二区va在线| 国产亚洲综合在线| 精品99一区二区三区| 日韩精品一区二区三区视频| 日韩一区二区三免费高清| 欧美日韩aaaaaa| 欧美精品日韩综合在线| 欧美电影一区二区三区| 欧美日韩高清一区| 欧美日本免费一区二区三区| 欧美性xxxxxxxx| 欧美男生操女生| 欧美一区二区三区免费| 欧美一区二区福利在线| 欧美一级免费大片| 精品国产sm最大网站| 久久亚洲综合色一区二区三区| 久久天天做天天爱综合色| 国产日产欧美精品一区二区三区| 国产网红主播福利一区二区| 欧美极品aⅴ影院| 中日韩av电影| 亚洲久本草在线中文字幕| 亚洲大型综合色站| 另类专区欧美蜜桃臀第一页| 国产在线播放一区二区三区| 丁香激情综合五月| 色综合天天视频在线观看| 欧美日韩一级二级| 日韩一区二区在线看| 久久精品人人做人人综合 | 在线国产电影不卡|