• <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>
            內核層次架構

            windows程序運行分為內核模式和用戶模式,內核模式可以訪問所有的內存地址空間, 并且可以訪問所有的CPU指令。一般程序運行在用戶模式, 通過系統調用切換到內核模式執行系統功能,Windows系統通過這種方式來確保系統的安全和穩定。



            下面是內核的層次劃分:

            硬件抽象層(Hardware Abstraction Layer) (HAL) (hal.dll)
            最底層隔離硬件的, 底層的第三方驅動程序就運行在這層。

            內核 (Kernel)
            實現操作系統的一些底層服務,比如線程調度, 多處理器的同步,中斷/異常處理等。

            執行體 (Executive)(ntoskrnl.exe
            實現基本的操作系統服務,比如基本的線程進程管理,內存管理, IO及進程間通訊等。

            窗口圖形子系統(Windows  Graphics Subsystem)
            由win32K.sys在內核層實現, 用戶界面相關都依賴該層, User32.dll的大部分功能都由該層實現。

            用戶層關鍵進程

            Windows系統在用戶層有幾個關鍵的系統進程:

            Smss.exe (session manager Subsystem)
            關于Session的概念可以參考我的這篇Sessions, Window Stations and Desktops, 在操作系統啟動時會創建一個不與任何Session關聯的Smss.exe管理者實例, 然后當有用戶登錄時它會為每個Sessin拷貝一份與之關聯的Smss.exe實例,然后由該關聯的Smss.exe實例啟動winlogon.exe和csrss.exe.

            WinLogon.exe
            該進程管理用戶的登錄和注銷, 我們按Ctrl+Alt+Del出現的界面和登錄后出現的桌面窗口都是由它啟動的。

            Csrss.exe ( Client/Server Runtime Subsystem)
            我們可以看到我們的桌面窗口(GetDesktopWindow)是由該進程創建的, 該進程主要負責Win32子系統的用戶模式部分(內核模式部分由win32k.sys實現)。

            Lsass.exe (Local Security Authority Subsystem)
            WinLogon.exe通過該進程驗證用戶登錄, 登錄后產生安全訪問令牌對象, 通過該令牌創建Explorer.exe, 我們其他用戶進程都由Explorer.exe啟動,并且繼承了該令牌權限。

            Services.exe
            該進程簡稱為SCM (NT Service Control Manager), 該進程負責啟動用戶態一些特殊進程, 也就是我們通常所說的服務程序。

            用戶模式調用內核模式方式

            由用戶模式調用內核模式一般有2種方式 系統調用(system call) 和 IOCTL (IO Control Commands)


            內核模式調用用戶模式方式

            可以通過IOCTL的上下文傳遞, 也可以通過APC (Asynchronous Procedure Call)直接調用。

            進程間通訊方式

            另外一種非常強大的用戶模式與內核模式通訊方式, 同時也支持進程間通訊, 該方式就是ALPC (Advanced Local Procedure Call), 該方式被操作系統大量使用, WinRT中的Broker進程也用到了它 。
            該方式實際上就4個核心函數:nt!NtAlpcSendWaitReceivePort, nt!NtAlpcCreatePort, nt!NtAlpcConnectPort, Nt!AplcAcceptConnectPort, 大概原理如下:



            總結一下 ,通過上面Windows系統中一些關鍵概念的介紹, 加深我們對Windows系統的理解, 讓我們對應用開發全局性的把握。 
            posted on 2013-01-12 22:03 Richard Wei 閱讀(8617) 評論(0)  編輯 收藏 引用 所屬分類: windows desktop
            91精品婷婷国产综合久久| 亚洲精品无码久久久久sm| 精品熟女少妇a∨免费久久| 欧美亚洲色综久久精品国产| 久久亚洲日韩精品一区二区三区| 久久精品人成免费| 精品久久久久久无码国产| 精品久久久无码中文字幕天天| 老男人久久青草av高清| 久久青青草原亚洲av无码app| 国产精品欧美久久久久无广告| 亚洲精品国产第一综合99久久| 精品无码久久久久国产| 久久精品国产男包| 精品视频久久久久| 国产精品久久久亚洲| 亚洲国产成人精品久久久国产成人一区二区三区综 | 亚洲一区精品伊人久久伊人| 久久久久精品国产亚洲AV无码| 久久最新精品国产| 色8久久人人97超碰香蕉987| 国产精品激情综合久久| 国产亚洲综合久久系列| 99久久精品免费看国产一区二区三区| 久久亚洲国产精品成人AV秋霞| 国产精品久久久久影院嫩草| 中文字幕久久久久人妻| 日韩中文久久| 久久亚洲高清综合| 精品久久久久久无码免费| 亚洲国产二区三区久久| 99久久成人国产精品免费| 久久亚洲AV成人无码电影| 久久无码高潮喷水| 久久久无码精品亚洲日韩蜜臀浪潮| 久久乐国产精品亚洲综合| 国产精品美女久久久网AV| 久久成人国产精品二三区| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 国产精品禁18久久久夂久| 久久久久久亚洲AV无码专区|