• <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://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麻豆久久久国产精品免费| 精品人妻久久久久久888| 伊人久久大香线蕉成人| 久久99中文字幕久久| 99精品国产99久久久久久97 | 香蕉久久久久久狠狠色| 久久这里只有精品首页| 精品久久久久久亚洲精品| 亚洲中文字幕无码久久精品1| 久久99精品国产麻豆蜜芽| 一本久久a久久精品综合夜夜| 69久久精品无码一区二区| 久久久久亚洲av无码专区| 久久香蕉国产线看观看精品yw| 偷窥少妇久久久久久久久| 久久亚洲中文字幕精品一区| 囯产精品久久久久久久久蜜桃| 久久人人爽人人爽人人爽| 精品国产乱码久久久久久呢| 狠狠色狠狠色综合久久| 久久久久久国产精品免费无码| 久久久久久亚洲精品成人| 久久精品人人做人人爽97| 狠狠久久亚洲欧美专区| 国产精品亚洲美女久久久| 精品综合久久久久久88小说 | 99久久精品国内| 99久久精品国产综合一区| 久久男人AV资源网站| 久久久国产99久久国产一| 中文字幕人妻色偷偷久久| av国内精品久久久久影院| 久久久久人妻一区精品| 亚洲色大成网站www久久九| 996久久国产精品线观看| 久久精品国产一区二区三区| 久久精品国产免费观看| 蜜桃麻豆www久久| av色综合久久天堂av色综合在| 精品亚洲综合久久中文字幕| 亚洲国产成人精品91久久久|