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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? passthrough.c

?? 文件系統過濾驅動程序的框架
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*++

Copyright (c) 1999 - 2002  Microsoft Corporation

Module Name:

    passThrough.c

Abstract:

    This is the main module of the passThrough miniFilter driver.
    This filter hooks all IO operations for both pre and post operation
    callbacks.  The filter passes through the operations.

Environment:

    Kernel mode

--*/

#include <fltKernel.h>

PFLT_FILTER gFilterHandle;
ULONG_PTR OperationStatusCtx = 1;

#define PTDBG_TRACE_ROUTINES            0x00000001
#define PTDBG_TRACE_OPERATION_STATUS    0x00000002

ULONG gTraceFlags = 0;


#define PT_DBG_PRINT( _dbgLevel, _string )          \
    (FlagOn(gTraceFlags,(_dbgLevel)) ?              \
        DbgPrint _string :                          \
        ((void)0))

/*************************************************************************
    Prototypes
*************************************************************************/

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

NTSTATUS
PtInstanceSetup (
    IN PCFLT_RELATED_OBJECTS FltObjects,
    IN FLT_INSTANCE_SETUP_FLAGS Flags,
    IN DEVICE_TYPE VolumeDeviceType,
    IN FLT_FILESYSTEM_TYPE VolumeFilesystemType
    );

VOID
PtInstanceTeardownStart (
    IN PCFLT_RELATED_OBJECTS FltObjects,
    IN FLT_INSTANCE_TEARDOWN_FLAGS Flags
    );

VOID
PtInstanceTeardownComplete (
    IN PCFLT_RELATED_OBJECTS FltObjects,
    IN FLT_INSTANCE_TEARDOWN_FLAGS Flags
    );

NTSTATUS
PtUnload (
    FLT_FILTER_UNLOAD_FLAGS Flags
    );

NTSTATUS
PtInstanceQueryTeardown (
    IN PCFLT_RELATED_OBJECTS FltObjects,
    IN FLT_INSTANCE_QUERY_TEARDOWN_FLAGS Flags
    );

FLT_PREOP_CALLBACK_STATUS
PtPreOperationPassThrough (
    IN OUT PFLT_CALLBACK_DATA Data,
    IN PCFLT_RELATED_OBJECTS FltObjects,
    OUT PVOID *CompletionContext
    );

VOID
PtOperationStatusCallback (
    IN PCFLT_RELATED_OBJECTS FltObjects,
    IN PFLT_IO_PARAMETER_BLOCK ParameterSnapshot,
    IN NTSTATUS OperationStatus,
    IN PVOID RequesterContext
    );

FLT_POSTOP_CALLBACK_STATUS
PtPostOperationPassThrough (
    IN OUT PFLT_CALLBACK_DATA Data,
    IN PCFLT_RELATED_OBJECTS FltObjects,
    IN PVOID CompletionContext,
    IN FLT_POST_OPERATION_FLAGS Flags
    );

FLT_PREOP_CALLBACK_STATUS
PtPreOperationNoPostOperationPassThrough (
    IN OUT PFLT_CALLBACK_DATA Data,
    IN PCFLT_RELATED_OBJECTS FltObjects,
    OUT PVOID *CompletionContext
    );

BOOLEAN
PtDoRequestOperationStatus(
    IN PFLT_CALLBACK_DATA Data
    );

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

#ifdef ALLOC_PRAGMA
#pragma alloc_text(INIT, DriverEntry)
#pragma alloc_text(PAGE, PtUnload)
#pragma alloc_text(PAGE, PtInstanceQueryTeardown)
#pragma alloc_text(PAGE, PtInstanceSetup)
#pragma alloc_text(PAGE, PtInstanceTeardownStart)
#pragma alloc_text(PAGE, PtInstanceTeardownComplete)
#endif

//
//  operation registration
//

CONST FLT_OPERATION_REGISTRATION Callbacks[] = {
    { IRP_MJ_CREATE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_CREATE_NAMED_PIPE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_CLOSE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_READ,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_WRITE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_QUERY_INFORMATION,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_SET_INFORMATION,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_QUERY_EA,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_SET_EA,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_FLUSH_BUFFERS,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_QUERY_VOLUME_INFORMATION,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_SET_VOLUME_INFORMATION,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_DIRECTORY_CONTROL,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_FILE_SYSTEM_CONTROL,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_DEVICE_CONTROL,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_INTERNAL_DEVICE_CONTROL,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_SHUTDOWN,
      0,
      PtPreOperationNoPostOperationPassThrough,
      NULL },                               //post operations not supported

    { IRP_MJ_LOCK_CONTROL,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_CLEANUP,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_CREATE_MAILSLOT,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_QUERY_SECURITY,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_SET_SECURITY,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_QUERY_QUOTA,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_SET_QUOTA,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_PNP,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_ACQUIRE_FOR_SECTION_SYNCHRONIZATION,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_RELEASE_FOR_SECTION_SYNCHRONIZATION,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_ACQUIRE_FOR_MOD_WRITE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_RELEASE_FOR_MOD_WRITE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_ACQUIRE_FOR_CC_FLUSH,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_RELEASE_FOR_CC_FLUSH,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_NOTIFY_STREAM_FILE_OBJECT,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_FAST_IO_CHECK_IF_POSSIBLE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_NETWORK_QUERY_OPEN,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_MDL_READ,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_MDL_READ_COMPLETE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_PREPARE_MDL_WRITE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_MDL_WRITE_COMPLETE,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_VOLUME_MOUNT,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_VOLUME_DISMOUNT,
      0,
      PtPreOperationPassThrough,
      PtPostOperationPassThrough },

    { IRP_MJ_OPERATION_END }
};

//
//  This defines what we want to filter with FltMgr
//

CONST FLT_REGISTRATION FilterRegistration = {

    sizeof( FLT_REGISTRATION ),         //  Size
    FLT_REGISTRATION_VERSION,           //  Version
    0,                                  //  Flags

    NULL,                               //  Context
    Callbacks,                          //  Operation callbacks

    PtUnload,                           //  MiniFilterUnload

    PtInstanceSetup,                    //  InstanceSetup
    PtInstanceQueryTeardown,            //  InstanceQueryTeardown
    PtInstanceTeardownStart,            //  InstanceTeardownStart
    PtInstanceTeardownComplete,         //  InstanceTeardownComplete

    NULL,                               //  GenerateFileName
    NULL,                               //  GenerateDestinationFileName
    NULL                                //  NormalizeNameComponent

};



NTSTATUS
PtInstanceSetup (
    IN PCFLT_RELATED_OBJECTS FltObjects,
    IN FLT_INSTANCE_SETUP_FLAGS Flags,
    IN DEVICE_TYPE VolumeDeviceType,
    IN FLT_FILESYSTEM_TYPE VolumeFilesystemType
    )
/*++

Routine Description:

    This routine is called whenever a new instance is created on a volume. This
    gives us a chance to decide if we need to attach to this volume or not.

    If this routine is not defined in the registration structure, automatic
    instances are alwasys created.

Arguments:

    FltObjects - Pointer to the FLT_RELATED_OBJECTS data structure containing
        opaque handles to this filter, instance and its associated volume.

    Flags - Flags describing the reason for this attach request.

Return Value:

    STATUS_SUCCESS - attach
    STATUS_FLT_DO_NOT_ATTACH - do not attach

--*/
{
    UNREFERENCED_PARAMETER( FltObjects );
    UNREFERENCED_PARAMETER( Flags );
    UNREFERENCED_PARAMETER( VolumeDeviceType );
    UNREFERENCED_PARAMETER( VolumeFilesystemType );

    PT_DBG_PRINT( PTDBG_TRACE_ROUTINES,
                  ("PassThrough!PtInstanceSetup: Entered\n") );

    return STATUS_SUCCESS;
}


NTSTATUS
PtInstanceQueryTeardown (
    IN PCFLT_RELATED_OBJECTS FltObjects,
    IN FLT_INSTANCE_QUERY_TEARDOWN_FLAGS Flags
    )
/*++

Routine Description:

    This is called when an instance is being manually deleted by a
    call to FltDetachVolume or FilterDetach thereby giving us a
    chance to fail that detach request.

    If this routine is not defined in the registration structure, explicit
    detach requests via FltDetachVolume or FilterDetach will always be
    failed.

Arguments:

    FltObjects - Pointer to the FLT_RELATED_OBJECTS data structure containing
        opaque handles to this filter, instance and its associated volume.

    Flags - Indicating where this detach request came from.

Return Value:

    Returns the status of this operation.

--*/
{
    UNREFERENCED_PARAMETER( FltObjects );
    UNREFERENCED_PARAMETER( Flags );

    PT_DBG_PRINT( PTDBG_TRACE_ROUTINES,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产青草久久久久福利| 欧美一区二区精品| 麻豆成人久久精品二区三区小说| 国产精品青草久久| ww久久中文字幕| 精品国产免费人成在线观看| 51精品久久久久久久蜜臀| 欧美日韩在线播放| 欧美日韩国产一二三| 欧美精品一二三| 91麻豆精品国产综合久久久久久| 91精品国产综合久久精品| 欧美一区二区在线免费观看| 欧美一级一级性生活免费录像| 欧美一区二区三区思思人| 91精品国产综合久久久久久漫画| 欧美一区二区三区日韩| 久久久精品免费网站| 国产精品激情偷乱一区二区∴| 91首页免费视频| 欧洲国内综合视频| 91精品国产综合久久久久久漫画| 精品成人在线观看| 欧美国产欧美综合| 亚洲丝袜另类动漫二区| 亚洲午夜私人影院| 韩国视频一区二区| 色婷婷久久久久swag精品| 欧美日韩免费视频| 亚洲精品一区二区三区99| 亚洲国产精品v| 午夜欧美视频在线观看| 国产福利精品导航| 在线观看国产精品网站| 精品美女一区二区| 18欧美亚洲精品| 亚洲国产成人av| 国产**成人网毛片九色| 欧美日韩一区不卡| 日本一二三四高清不卡| 日韩精品一二区| av午夜一区麻豆| 欧美xxx久久| 艳妇臀荡乳欲伦亚洲一区| 国精产品一区一区三区mba视频| 色综合久久六月婷婷中文字幕| 日韩一级二级三级| 一区二区三区四区在线| 韩国成人福利片在线播放| 91女神在线视频| 欧美www视频| 亚洲人快播电影网| 国产黄人亚洲片| 日韩视频一区二区三区| 亚洲免费三区一区二区| 国产精品一区在线观看你懂的| 欧美三级视频在线播放| 亚洲美女在线国产| 成人黄动漫网站免费app| 2024国产精品| 日韩精品免费专区| 欧美日韩激情一区二区三区| 玉足女爽爽91| 色婷婷av一区| 亚洲欧美区自拍先锋| 成人性生交大合| 久久久亚洲精品石原莉奈| 一区二区三区小说| 国产一级精品在线| 国产精品538一区二区在线| 日韩欧美一区在线观看| 亚洲一级不卡视频| 色av综合在线| 亚洲三级电影网站| 91在线云播放| 亚洲精品一卡二卡| 日本久久一区二区三区| 洋洋成人永久网站入口| 欧美伊人久久大香线蕉综合69| 国产精品久线在线观看| 不卡一区中文字幕| 亚洲成av人片在www色猫咪| 色狠狠av一区二区三区| 亚洲日穴在线视频| 在线亚洲欧美专区二区| 一区二区三区 在线观看视频 | 成人的网站免费观看| 中文字幕不卡在线| 99久久精品免费看国产| 亚洲一区二区三区四区的| 在线免费视频一区二区| 视频一区免费在线观看| 日韩免费一区二区三区在线播放| 久久国产精品99精品国产| 久久人人97超碰com| 国产91精品一区二区麻豆网站| 亚洲国产高清aⅴ视频| 99精品久久99久久久久| 亚洲一区二区三区美女| 91精品国产欧美一区二区成人| 久久av老司机精品网站导航| 久久久精品免费网站| 色综合视频一区二区三区高清| 亚洲综合色丁香婷婷六月图片| 91精品国产乱| 成人性生交大合| 日韩电影一二三区| 久久久久久久久久久电影| 色哟哟一区二区在线观看| 亚洲bdsm女犯bdsm网站| 久久久久久久久久电影| 欧美丝袜自拍制服另类| 狠狠色丁香久久婷婷综合丁香| 国产精品对白交换视频| 欧美日韩小视频| 国产宾馆实践打屁股91| 亚洲高清三级视频| 国产人伦精品一区二区| 欧美影院午夜播放| 国产91精品在线观看| 日韩制服丝袜先锋影音| 亚洲日本va在线观看| 精品久久国产字幕高潮| 在线观看亚洲成人| 波波电影院一区二区三区| 日韩精品免费专区| 亚洲综合男人的天堂| 国产日产亚洲精品系列| 日韩美女视频在线| 欧美色综合天天久久综合精品| 久久久久久久综合狠狠综合| 欧美日韩国产中文| 成a人片亚洲日本久久| 国内精品免费在线观看| 日韩av一区二区三区| 亚洲夂夂婷婷色拍ww47| 国产精品二三区| 国产清纯白嫩初高生在线观看91 | 成人黄页毛片网站| 久久机这里只有精品| 日韩精品一卡二卡三卡四卡无卡| 久久久久久久久免费| 国产精品沙发午睡系列990531| 91亚洲永久精品| 国产清纯在线一区二区www| 国产精品久久久久久久久晋中| 这里是久久伊人| 欧美色视频一区| 在线免费观看日韩欧美| 色婷婷国产精品| 色吊一区二区三区| 色香蕉成人二区免费| 99热这里都是精品| 色综合视频在线观看| 色婷婷狠狠综合| 欧美日韩视频一区二区| 欧美日韩一区精品| 欧美色精品在线视频| 欧美美女网站色| 精品日韩99亚洲| 精品国产伦一区二区三区观看方式| 91麻豆精品国产91久久久更新时间| 欧美美女黄视频| 日韩一区二区影院| 久久综合久久综合久久综合| 久久久91精品国产一区二区精品| 久久中文娱乐网| 中文字幕不卡在线观看| 亚洲精选视频在线| 日韩国产精品大片| 精品一区免费av| 波多野结衣中文字幕一区二区三区| 91亚洲男人天堂| 欧美老年两性高潮| 26uuu国产在线精品一区二区| 亚洲国产成人在线| 亚洲一区中文在线| 麻豆精品一二三| 91在线观看高清| 欧美色综合久久| 国产日韩成人精品| 91麻豆精品国产91久久久久| 久久综合色之久久综合| 亚洲欧美在线高清| 青草av.久久免费一区| 成人精品国产福利| 欧美日韩精品一区二区三区| 精品88久久久久88久久久| 最新久久zyz资源站| 久久久精品国产免费观看同学| 亚洲精品久久嫩草网站秘色| 欧美a级一区二区| 99久久综合99久久综合网站| 日韩美女一区二区三区四区| 亚洲品质自拍视频网站| 精品一区二区三区视频在线观看| 99国产欧美另类久久久精品| 欧美草草影院在线视频| 伊人性伊人情综合网| 成人综合在线网站|