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

            小默

            [zz]內核模式編程環境

            內核模式編程環境


            圖3-1顯示了Windows NT操作系統的某些組成部分。每個部分都輸出一些服務函數,這些函數以兩個特別的字母組合開頭:

            • I/O管理器(Io前綴) 包含許多驅動程序可以使用的服務函數,對這些函數的描述遍及本書。
            • 進程結構模塊(Ps前綴) 創建并管理內核模式線程。普通的WDM驅動程序應使用一個獨立的線程循檢無中斷生成能力的設備
            • 內存管理器(Mm前綴) 控制頁表,頁表定義了虛擬內存到物理內存之間的映射。
            • executive (Ex前綴) 提供堆管理同步服務。本章將討論堆管理函數。下一章討論同步服務。
            • 對象管理器(Ob前綴) 集中控制Windows NT中的各種數據對象。WDM驅動程序僅需要對象管理器維護對象的參考計數,以防止對象被意外刪除。
            • 安全參考監視器(Se前綴) 使文件系統驅動程序執行安全檢測。I/O請求到達WDM驅動程序前已經做完了安全檢測,所以本書不討論這些函數。
            • 運行時間庫部件(Rtl前綴) 包含工具例程,例如列表和串管理例程,內核模式驅動程序可以用這些例程來替代常規的ANSI標準例程。大部分例程可以從其名字上直接看出它的功能。
            • Win32子系統存在于用戶模式中,所以用戶模式中的應用程序可以容易地調用其例程。為了方便,Windows NT在內核模式中實現了一些有Zw前綴名的函數,這些函數可以使驅動程序調用Win32子系統例程。Windows 2000 DDK中僅暴露一少部分這樣的函數給驅動程序使用,包括訪問文件和注冊表的函數。我將在本章討論這些函數。
            • Windows NT內核(Ke前綴) 所有多線程和多處理器的低級同步活動都發生在內核中,我將在下一章中討論KeXxx函數。
            • 在操作系統的最底層是硬件抽象層(HALHal前綴)。操作系統把所有關于計算機硬件如何連接的信息都存放在HAL中。HAL了解如何在特定平臺上實現中斷操作,如何實現自旋鎖,如何尋址I/O或內存映射設備,等等。 WDM驅動程序不直接與硬件對話,它通過調用HAL中的函數來達到目的。所以WDM驅動程序能夠實現平臺無關和總線無關

            圖3-1. 內核模式支持例程概觀

            使用標準運行時間庫函數

            在歷史上,Windows NT的設計者認為,不應該在驅動程序中使用C編譯器廠商提供的運行時間庫。部分原因是由于Windows NT是在ANSI標準出臺前設計的,每個C編譯器廠商都有自己的實現方法和品質標準。另一個原因是因為標準運行時間庫中的例程有時需要依賴用戶模式中的應用程序來初始化,并且有些例程并不是以多線程或多處理器安全的方式實現的。

            直到現在,官方認為內核模式驅動程序僅應調用DDK中公開的函數。例如,你不能在驅動程序中調用wcscmp函數,而應該調用RtlCompareUnicodeString。然而,這里有一個公開的秘密,用于創建驅動程序的標準輸入庫(ntoskrnl.lib)定義了許多函數,而這些函數卻是在諸如string.h、stdio.h、stdlib.h,和ctypes.h的頭文件中聲明的,這些頭文件都是應用程序經常使用的頭文件。所以,為什么我們不能使用它們?實際上,倘若你了解所有的內部細節,你完全可以調用它們。但你不能總這樣做,例如,你不能總用memcpy替代RtlCopyBytes,因為這兩者稍有不同。(RtlCopyByte可以保證一個字節一個字節地復制數據而不是以較大的塊,大塊復制數據在某些RISC平臺上會出現麻煩)

            注意側效

            驅動程序中使用的許多支持“函數”其實是DDK頭文件中定義的宏。我們都知道應該避免在宏的參數中使用帶有邊效的表達式,原因很明顯,宏可以多次使用其參數,見下面代碼:

            int a = 2, b = 42, c;
                        c = min(a++, b);

            a的值是什么?(c的值又是什么?) 讓我們看看這個似是而非的min宏:

            #define min(x,y) (((x)<(y)) ? (x) : (y))

            如果你用a++代替x,你將看到a最后等于4,因為表達式a++執行了兩次。而“函數”min將返回3而不是2,因為函數的返回值是在第二次計算a++之前提取的a值

            通常,你不能知道DDK什么時候使用宏,什么時候使用真正的外部函數。有時候,一個特殊的服務函數在某些平臺上是宏而在其它平臺上卻是外部函數。此外,Microsoft也可能在將來改變想法。所以,當你寫WDM驅動程序時應堅守下面原則:

                決不在內核模式服務函數的參數中使用帶有側效的表達式。

            posted on 2009-12-29 08:42 小默 閱讀(428) 評論(0)  編輯 收藏 引用 所屬分類: Windows

            導航

            統計

            留言簿(13)

            隨筆分類(287)

            隨筆檔案(289)

            漏洞

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久成人国产精品一区二区| 无码人妻久久一区二区三区免费丨 | 伊人久久大香线蕉亚洲五月天| 一本一本久久a久久精品综合麻豆| 一本色道久久综合| 久久久久国产精品人妻| 97久久综合精品久久久综合| 久久国产福利免费| 国产美女亚洲精品久久久综合| 狠狠色丁香久久综合婷婷| 2020最新久久久视精品爱| 思思久久99热免费精品6| 久久久亚洲欧洲日产国码二区 | 无遮挡粉嫩小泬久久久久久久| 国内精品久久久久| 99久久99久久精品国产片果冻 | 久久大香香蕉国产| 亚洲日本va午夜中文字幕久久| 久久久精品人妻一区二区三区蜜桃| 91超碰碰碰碰久久久久久综合| 久久人人爽人人爽人人片AV麻烦| 国产V亚洲V天堂无码久久久| 蜜桃麻豆WWW久久囤产精品| 久久综合久久久| 国产精品女同久久久久电影院| 日韩美女18网站久久精品| 国产伊人久久| 国产成人久久久精品二区三区| 久久免费国产精品一区二区| 婷婷久久久亚洲欧洲日产国码AV| 国产精品久久久久久久app| 久久久WWW免费人成精品| 国产精品九九久久免费视频| 国产精品久久网| 国内精品久久久久| 2020最新久久久视精品爱| 久久综合狠狠综合久久激情 | 国产99久久九九精品无码| 国产ww久久久久久久久久| 93精91精品国产综合久久香蕉| 91精品国产91久久久久久青草 |