• <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>

            任我行

            一天一個腳印......
            每日一句:
            posts - 54, comments - 218, trackbacks - 1, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            好啦,辛辛苦苦終于寫完了程序,讓我們編譯運行吧!按下Ctrl+F5(嘿嘿,讓我們先假設(shè)你習(xí)慣用VC來寫程序),我等啊等……疑?怎么毫無動靜的?再看看Output窗口,哇!有幾百個錯誤啊!!不禁頭大——這是怎么回事呢?

            原來,WDM程序編譯出來的并不是我們常見的.exe,而是.sys文件,在未經(jīng)設(shè)置編譯環(huán)境之前,是不能直接用VC來編譯的(這就是為什么會有幾百個錯誤了)。這種類型的文件你可以在WINNT\System32\Drivers里面找到很多。其實驅(qū)動程序也是一種PE文件,它同樣由DOS MZ header開頭,也有完整的DOS stub和PE header,同樣擁有Import table和Export table——……那跟普通的PE文件有什么不一樣呢?那么就讓我們先來做個小剖析,加深對.sys文件的認識吧


            首先祭出Delphi里附帶的tdump.exe程序。讓我們鍵入:
            C:\WINNT\System32\Drivers>tdump ccport.sys -em -ee
            參數(shù)-em是列出Import table,-ee是列出Export table。回車之后,屏幕列出一大堆東西:

            C:\WINNT\SYSTEM32\DRIVERS>tdump ccport.sys -em -ee
            Turbo Dump  Version 5.0.16.12 Copyright ? 1988, 2000 Inprise Corporation
                                Display of File CCPORT.SYS

            IMPORT:     NTOSKRNL.EXE={hint:011Fh}.’memcpy’
            IMPORT:     NTOSKRNL.EXE={hint:003Dh}.’IoDeleteDevice’
            IMPORT:     NTOSKRNL.EXE={hint:0030h}.’IoAttachDeviceToDeviceStack’
            IMPORT:     NTOSKRNL.EXE={hint:008Eh}.’KeSetEvent’
            IMPORT:     NTOSKRNL.EXE={hint:0068h}.’IofCallDriver’
            IMPORT:     NTOSKRNL.EXE={hint:0095h}.’KeWaitForSingleObject’
            IMPORT:     NTOSKRNL.EXE={hint:0074h}.’KeInitializeEvent’
            IMPORT:     NTOSKRNL.EXE={hint:003Fh}.’IoDetachDevice’
            IMPORT:     NTOSKRNL.EXE={hint:00D3h}.’RtlFreeUnicodeString’
            IMPORT:     NTOSKRNL.EXE={hint:0077h}.’KeInitializeSpinLock’
            IMPORT:     NTOSKRNL.EXE={hint:0129h}.’strcpy’
            IMPORT:     NTOSKRNL.EXE={hint:0121h}.’memset’
            IMPORT:     NTOSKRNL.EXE={hint:003Ch}.’IoCreateUnprotectedSymbolicLink’
            IMPORT:     NTOSKRNL.EXE={hint:0038h}.’IoCreateDevice’
            IMPORT:     NTOSKRNL.EXE={hint:00C2h}.’RtlAnsiStringToUnicodeString’
            IMPORT:     NTOSKRNL.EXE={hint:0069h}.’IofCompleteRequest’
            IMPORT:     NTOSKRNL.EXE={hint:0124h}.’sprintf’
            IMPORT:     NTOSKRNL.EXE={hint:003Eh}.’IoDeleteSymbolicLink’
            IMPORT:     NTOSKRNL.EXE={hint:0042h}.’IoFreeIrp’
            IMPORT:     NTOSKRNL.EXE={hint:004Dh}.’IoInitializeIrp’
            IMPORT:     NTOSKRNL.EXE={hint:002Dh}.’IoAllocateIrp’
            IMPORT:     NTOSKRNL.EXE={hint:0027h}.’InterlockedExchange’
            IMPORT:     NTOSKRNL.EXE={hint:0025h}.’InterlockedCompareExchange’
            IMPORT:     NTOSKRNL.EXE={hint:0035h}.’IoCancelIrp’
            IMPORT:     NTOSKRNL.EXE={hint:012Ah}.’strlen’
            IMPORT:     NTOSKRNL.EXE={hint:0126h}.’strcat’
            IMPORT:     NTOSKRNL.EXE={hint:0114h}.’atoi’
            IMPORT:     NTOSKRNL.EXE={hint:0128h}.’strcmp’
            IMPORT:     NTOSKRNL.EXE={hint:0034h}.’IoBuildSynchronousFsdRequest’
            IMPORT:     NTOSKRNL.EXE={hint:00D5h}.’RtlInitAnsiString’
            IMPORT:          HAL.DLL={hint:0006h}.’KfAcquireSpinLock’
            IMPORT:          HAL.DLL={hint:0009h}.’KfReleaseSpinLock’

            EXPORT ord:0001=’Vcomm_DriverControl’



            看到了嗎?它主要調(diào)用了NTOSKRNL.EXE和HAL.DLL文件(實際上你會發(fā)現(xiàn),幾乎所有的WDM驅(qū)動程序都會調(diào)用NTOSKRNL.EXE文件,從它的名字你可以看出為什么了吧?),并且輸出了一個函數(shù)“Vcomm_DriverControl”。這表明,其實.sys跟.exe文件一樣,都是一種PE文件來的。不同的是,.sys文件Import的通常是NTOSKRNL.EXE,而.exe文件Import的通常是KERNEL32.DLL和USER32.DLL。

            知道了這些有什么用呢?實際上,由于.sys通常不調(diào)用KERNEL32.DLL和USER32.DLL,所以你是不能在設(shè)備驅(qū)動程序里面調(diào)用任何C、C++和Win32函數(shù)的,而且也不能用C++關(guān)鍵字new和delete等(可以用malloc和free來代替),而必須使用大量的內(nèi)核函數(shù)。另外,你應(yīng)該也能看到她調(diào)用了像IoDeleteDevice、IoAttachDeviceToDeviceStack等等函數(shù),這些你以前可能沒有見過的函數(shù)都是些內(nèi)核函數(shù)。為了讀者的方便,下面我列出一些常見的驅(qū)動程序可用的內(nèi)核函數(shù):

            Ex…        執(zhí)行支持
            Hal…        硬件抽象層(僅NT/Windows 2000)
            Io…        I/O管理器(包括即插即用函數(shù))
            Ke…        內(nèi)核
            Ks…        內(nèi)核流IRP管理函數(shù)
            Mm…        內(nèi)存管理器
            Ob…        對象管理器
            Po…        電源管理
            Ps…        進程結(jié)構(gòu)
            Rtl…        運行時庫
            Se…        安全引用監(jiān)視
            Zw…        其他函數(shù)


            最后讓我們再來看看,寫設(shè)備驅(qū)動程序時必須注意的一些問題:

            1、內(nèi)核宏
            如果查看DDK頭文件,會發(fā)現(xiàn)有幾個內(nèi)核函數(shù)是以宏的方式實現(xiàn)的。這種宏中有幾個宏的定義是相當(dāng)糟糕的。例如,我們看到RemoveHeadList的定義如下:

            #define RemoveHeadList(ListHead)
                    (ListHead)->Flink;
                    {RemoveEntryList((ListHead)->Flink)}


            如果以以下方式調(diào)用RemoveHeadList,則將編譯錯誤的代碼:

            if(SomethingInList)
                    Entry = RemoveHeadList(list);


            使這個調(diào)用安全的唯一方法是使用花括號:

            if(SomethingInList)
                {
                    Entry = RemoveHeadList(list);
                }


            所以我們切勿為了貪圖一時的方便,而使用不太規(guī)范的寫法,最好是在所有的if、for和while等語句中使用花括號。

            2、驅(qū)動程序函數(shù)名稱
            跟C/C++的main()函數(shù)一樣,設(shè)備驅(qū)動程序也有一個必須存在,而且只能以DriverEntry()為名稱的入口函數(shù)。然而,除此之外,我們可以使用任何名字來給其他函數(shù)命名——只要你自己記得就行了,當(dāng)然,最好符合某些特定的規(guī)范啦,例如匈牙利命名法……

            3、安裝時的問題
            ·在Windows98中驅(qū)動程序可執(zhí)行文件必須是8.3文件名。(別問我為什么,我也不知道,我只能建議你去問比爾該死)
            ·如果INF文件中含有非法節(jié)的詳細資料,Windows將不使用這個INF文件。

            本節(jié)羅羅嗦嗦講了一大堆,跟實際的編程卻并沒有太大的關(guān)系,前傳嘛!就是這樣的啦!

            久久人做人爽一区二区三区| 久久免费视频网站| 一本久久a久久精品综合香蕉| 色欲综合久久躁天天躁| 亚洲av成人无码久久精品| 77777亚洲午夜久久多喷| 久久精品视频91| 国产精品毛片久久久久久久| 久久国产视频网| 2021国产成人精品久久| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 无码8090精品久久一区| 亚洲中文字幕久久精品无码APP| 999久久久无码国产精品| 久久伊人亚洲AV无码网站| 国产精品青草久久久久婷婷| 7777久久久国产精品消防器材| 狠狠干狠狠久久| 久久久久国产精品熟女影院| 久久综合久久美利坚合众国| 国产精品成人99久久久久91gav| 国产麻豆精品久久一二三| 久久无码高潮喷水| 久久久午夜精品| 午夜福利91久久福利| 久久精品无码专区免费| 国产成人久久777777| 尹人香蕉久久99天天拍| 久久久久亚洲AV成人网人人软件| 久久久久女人精品毛片| 99久久这里只精品国产免费| 开心久久婷婷综合中文字幕| 欧美久久天天综合香蕉伊| 久久国产精品视频| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久艹国产| 国产激情久久久久影院小草| 中文精品久久久久国产网址| 国产香蕉97碰碰久久人人| 久久国产成人午夜AV影院| 久久精品无码一区二区app|