• <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.¢% 閱讀(336) 評論(0)  編輯 收藏 引用 所屬分類: Windows WDM
            [資料] http://m.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国产精品久久| 伊人精品久久久久7777| 伊人久久大香线蕉av不变影院| 亚洲国产高清精品线久久| 亚洲精品乱码久久久久久蜜桃 | 欧美亚洲国产精品久久蜜芽| 久久天堂电影网| 无码乱码观看精品久久| 久久国产精品99国产精| 欧美午夜A∨大片久久 | 亚洲狠狠综合久久| 久久精品国产亚洲av麻豆图片| 99精品国产在热久久无毒不卡 | 精品久久久久久亚洲| 久久久91人妻无码精品蜜桃HD| 中文字幕久久精品无码| 久久99精品久久久久久噜噜| 久久精品国产亚洲av麻豆小说 | 99精品国产在热久久无毒不卡| 久久久久亚洲国产| 99久久精品免费| .精品久久久麻豆国产精品| 四虎影视久久久免费观看| 国产福利电影一区二区三区,免费久久久久久久精| 亚洲精品成人久久久| 国产AV影片久久久久久| 99精品久久精品| 久久久一本精品99久久精品66| 女人高潮久久久叫人喷水| 大蕉久久伊人中文字幕| 久久久综合九色合综国产| 青草国产精品久久久久久| 伊人久久大香线蕉AV色婷婷色| 超级碰碰碰碰97久久久久| 深夜久久AAAAA级毛片免费看| 久久久久国色AV免费看图片| 国产高清国内精品福利99久久| 日本免费久久久久久久网站| 99热热久久这里只有精品68| 97精品国产97久久久久久免费| 色综合色天天久久婷婷基地|