• <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++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            File System Filters Driver(一)

            Posted on 2009-10-30 12:14 S.l.e!ep.¢% 閱讀(340) 評論(0)  編輯 收藏 引用 所屬分類: Windows WDM
            [資料] http://www.shnenglu.com/Files/sleepwom/Windows%20File%20Filters%20Driver%20StudyII.rar

            看的資料是狂人的 Windows File Filter Driver II
            1. NTSTATUS
            ??? DriverEntry(
            ??? IN PDRIVER_OBJECT DriverObject,
            ??? IN PUNICODE_STRING RegistryPath
            ??? );? 函數是每個驅動的入口函數

            2. DriverObject?簡稱 DO
            ??? DriverObject 是我們所寫的驅動對應的 DriverObject, 在加載驅動時,由系統分配的一個對象
            ??? DriverObject?有一組函數指針,稱為 dispatch functions, 開發驅動的任務就是撰寫這些 dispatch function

            3. RegistryPath 是專門用于記錄本驅動相關參數的注冊表路徑,也是由系統分配的

            4. 小試牛刀
            #ifdef?__cplusplus

            extern?"C"
            {
            #endif

            #include?
            "ntddk.h"

            #ifdef?__cplusplus
            }
            #endif

            PDEVICE_OBJECT?gSFilterControlDeviceObject;

            VOID?OnUnLoad(IN?PDRIVER_OBJECT?pDriverObject)?
            {
            ????DbgPrint((
            "Enter?DriverUnload\n"));
            ????
            ????IoDeleteDevice(?gSFilterControlDeviceObject?);

            ????DbgPrint((
            "Leave?DriverUnload\n"));
            }

            extern?"C"?NTSTATUS?
            DriverEntry(
            IN?PDRIVER_OBJECT??DriverObject,
            IN?PUNICODE_STRING?RegistryPath)
            {

            ????DbgPrint(
            "Entry?DriverEntry?Function!\n");

            ????DriverObject
            ->DriverUnload?=?OnUnLoad;

            ????
            //?define?a?unicode?string
            ????UNICODE_STRING?nameString;
            ????RtlInitUnicodeString(
            &nameString,?L"\\FileSystem\\MyFilter");
            ????
            ????
            //?create?a?control?driver
            ????NTSTATUS?status;
            ????status?
            =?IoCreateDevice(DriverObject,?
            ????????????????????????????
            0,?//?has?no?device?extension
            ????????????????????????????&nameString,
            ????????????????????????????FILE_DEVICE_DISK_FILE_SYSTEM,
            ????????????????????????????FILE_DEVICE_SECURE_OPEN,
            ????????????????????????????FALSE,
            ????????????????????????????
            &gSFilterControlDeviceObject);

            ????
            if(?!NT_SUCCESS(?status?)?)
            ????{
            ????????DbgPrint((
            "DriverEntry:Error?Creating?Control?Device?Object?%wZ?status?=?%08x?\n"),
            ?????????????????
            &nameString,?status);
            ????????
            return?status;
            ????}

            ????DbgPrint(
            "Leave?DriverEntry!\n");

            ????
            return?STATUS_SUCCESS;
            }?

            保存為 testwdm.cpp

            #
            #?DO?NOT?EDIT?THIS?FILE
            !!!?Edit?.\sources.?If?you?want?to?add?a?new?source
            #?file?to?
            this?component.?This?file?merely?indirects?to?the?real?make?file
            #?that?
            is?shared?by?all?the?driver?components?of?the?Windows?NT?DDK
            #

            !INCLUDE?$(NTMAKEENV)\makefile.def

            保存為 MAKEFILE

            TARGETNAME=testwdm
            TARGETPATH
            =.\sys
            TARGETTYPE
            =DRIVER
            SOURCES
            =testwdm.cpp

            保存為 SOURCE

            三個文件,然后就可以BUILD了
            使用 DriverMonitor 加載驅動后,然后使用 WinObj.exe 查看
            在 \FileSystem 下面就會多一個 MyFilter 的驅動

            使用 DriverMonitor Stop Driver, 并刪除 Driver
            \FileSystem 下面的 'MyFilter' 就會消失

            FastIo:
            FastIo 是獨立于普通的IRP的分發函數之外的另一組接口,但是他們的作用是一樣的, 就是由驅動處理外部給予的請求,
            而且所處理的請求也基本相同

            FastIo例程返回 FALSE 表示不做任何事,這樣這些請求都會通過IRP重新發送到 普通分發函數.

            Q1.? NTSTATUS
            ???? DriverEntry(
            ??? IN PDRIVER_OBJECT DriverObject,
            ??? IN PUNICODE_STRING RegistryPath
            ??? );
            ?? 函數無疑是驅動的入口函數,但操作系統加載驅動 至 system 線程調用 DriverEntry() 函數的過程是如何的?


            Q2.在本例中,IoCreateDevice() 函數創建的設備是什么設備?假如我想過濾某個物理設備的IRP,是不是需要使用
            ????? IoCreateDevice()?函數去創建一個設備,并綁定到物理設備上面?

            Q3: FastIo 接口位于 普通的 Driver分派函數之上?系統會先調用 FastIo 接口再調用 Driver的分派函數?
            国产精品无码久久四虎| 欧美一区二区久久精品| 日产精品99久久久久久| 国产精品久久久久蜜芽| 香蕉久久影院| 日本加勒比久久精品| 色综合久久精品中文字幕首页| 久久国产高潮流白浆免费观看| 无码人妻久久一区二区三区免费丨| 亚洲精品无码久久久久| 久久无码AV中文出轨人妻| 国产69精品久久久久观看软件| 久久大香萑太香蕉av| 亚洲AV无码1区2区久久| 69久久精品无码一区二区| 久久久青草久久久青草| 久久99精品国产麻豆不卡| 日韩久久无码免费毛片软件| 久久亚洲高清综合| 欧美日韩精品久久免费| 久久综合狠狠综合久久综合88 | 国产成人精品久久亚洲| 国内精品久久国产大陆| 久久综合九色综合精品| 久久亚洲电影| 亚洲∧v久久久无码精品| 青青青青久久精品国产h| 久久99精品久久久久久水蜜桃| 狠狠色丁香久久婷婷综合_中| 久久精品国产亚洲av麻豆小说 | 2021国内久久精品| 97r久久精品国产99国产精| 色综合色天天久久婷婷基地| 中文字幕亚洲综合久久菠萝蜜| 国产午夜免费高清久久影院| 久久久久久青草大香综合精品| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 久久久久久久精品妇女99| 亚洲国产成人久久综合一| 久久亚洲sm情趣捆绑调教| 一级做a爱片久久毛片|