• <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>
            操作系統(tǒng)運行中,種有各種事情打斷和切換,通過系統(tǒng)陷阱來實現(xiàn): 


            簡單來說就和應用層的回調(diào)函數(shù)一樣, 只不過這些處理是在操作系統(tǒng)內(nèi)核里面,系統(tǒng)初始化時就填充好了IDT(interrupt dispatch table), 當中斷發(fā)生時, 系統(tǒng)會根據(jù)中斷類型,去調(diào)用對應的ISR(interrupt service routine). 當中斷發(fā)生時,操作系統(tǒng)內(nèi)核會保存足夠多的信息(陷阱幀), 這樣系統(tǒng)處理完中斷之后可以回到原來的地方繼續(xù)執(zhí)行。看起來好像和我們應用層的函數(shù)調(diào)用一樣, 但是他們的實現(xiàn)是完全不同的, 函數(shù)調(diào)用是同一線程, 通過堆棧來實現(xiàn)的;中斷處理涉及到線程切換,要保存線程的執(zhí)行環(huán)境。


            中斷處理流程圖: 



            IRQL(interrupt request level) - 中斷請求級別:


            每種中斷都有自己的優(yōu)先級, 高優(yōu)先級的中斷可以打斷低優(yōu)先級的中斷的處理, 反之則不行。
            對應用層開發(fā)人員來說,最重要的是最下面的3個軟件中斷級別:
            (1) DPC/dispatch: 系統(tǒng)的線程調(diào)度器工作在這一級別, 它可以決定掛起和調(diào)度哪個線程。DPC(deferred procedure call)主要是給驅(qū)動程序用的,每個處理器都有一個DPC列表, 處理器在降級當前IRQL之前, 會先把DPC列表里的事情處理完。
            (2) APC: APC即asynchronous procedure call, 每個線程都有一個APC隊列, 我們可以往該隊列中加入自己要處理的事情(QueueUserAPC), 然后系統(tǒng)會在當該線程進入alertable wait state時調(diào)用我們加入的操作,我們可以通過SleepEx/WaitForMultipleObjectEx讓該線程進入這種等待狀態(tài)。我們常見的OVERLAPPED ReadFileEx/WriteFileEx就是通過這種方式實現(xiàn)的。
            (3) Passive/Low: 這個實際上不是一個IRQL, 我們普通的用戶代碼就運行在這個級別,所以它可以隨時被打斷。


            系統(tǒng)服務調(diào)用: 


            在Pentium II 之前, 0x2e中斷進入系統(tǒng)內(nèi)核(eax傳遞服務號), Pentium II 之后處理器提供了Sysenter/Sysexit指令直接進出內(nèi)核。
            內(nèi)核對GUI線程和非GUI線程有不同的SSDT(System Services Descriptor Table), GUI線程服務分發(fā)表更完整,包含了窗口和GDI相關(guān)部分, 在第一調(diào)用user32/GDI相關(guān)的API時系統(tǒng)會修改該線程系統(tǒng)服務表的指針。


            內(nèi)核對象結(jié)構(gòu): 


            應用層打交道的內(nèi)核對象實際上是執(zhí)行體對象, 它是有一個或多個真正的內(nèi)核對象組成的。內(nèi)核對象由對象頭和對象體組成, 對象頭對每種對象包含一致的結(jié)構(gòu), 對象體則每種對象各不相同。對象頭里的對象類型(object type), 對同種類型的對象,指向相同的地址,表明了該種對象的屬性和方法。對象管理器通過對象頭來管理內(nèi)核對象。 


            內(nèi)核對象同步原理:


            應用層我們經(jīng)常調(diào)用WaitForSingle(Multiple)Object, 操作系統(tǒng)內(nèi)部是怎么實現(xiàn)的?

            每個可同步的對象, 內(nèi)部都有一個分發(fā)器頭(dispatch_header), 分發(fā)器頭包含了對象類型,狀態(tài),以及等待該對象的線程列表;每個處于等待狀態(tài)的線程, 都有一個等待塊列表(wait block list), 每個等待塊代表一個等待線程。這樣就很好理解了,當我們把一個同步對象設置成有信號狀態(tài)時, 系統(tǒng)沿著分發(fā)器頭的等待線程列表遍歷,找到可激活的線程,將它轉(zhuǎn)入就緒狀態(tài)參與線程調(diào)度。


            Critical Section是如何實現(xiàn)用戶態(tài)等待的?

            我們知道CRITICAL_SECTION是同一進程內(nèi)我們最常用的同步機制, 號稱不用轉(zhuǎn)入內(nèi)核,以高效聞名, 它是怎么實現(xiàn)的?
            單純在用戶態(tài)等待, 我們只能死循環(huán),不停的檢測, 也就是所謂的自旋鎖(SpinLock), critical section如果用這種方式實現(xiàn),何來高效可言。
            實際上critical section的大概實現(xiàn)是這樣的: 它內(nèi)部包含一個標志位以及一個event object, 進入critical section時首先嘗試設置標志位,如果設置成功,表示成功獲得資源;如果標志位已經(jīng)被設置, 則等待event事件。其中標志位的設置是用類似interlockedexchange這樣的原子API操作的。這樣只要沒有資源競爭,大部分情況下都能滿足我們的高效需求, 如果有資源競爭,實際上還是會轉(zhuǎn)入內(nèi)核態(tài)掛起線程。
            posted on 2016-03-22 22:48 Richard Wei 閱讀(2199) 評論(1)  編輯 收藏 引用 所屬分類: windows desktop

            FeedBack:
            # re: Windows系統(tǒng)機制筆記
            2016-04-13 11:00 | anna
            CRITICAL_SECTION是同一進程內(nèi)我們最常用的同步機制  回復  更多評論
              
            香港aa三级久久三级老师2021国产三级精品三级在 | 久久福利青草精品资源站免费| 亚洲国产另类久久久精品| 国产精品久久久久影院嫩草| 久久只有这精品99| 99久久国产亚洲高清观看2024| 狠狠色丁香久久婷婷综合_中| 精品无码人妻久久久久久| 97久久超碰国产精品2021| 成人免费网站久久久| 久久综合狠狠综合久久激情 | 久久国产欧美日韩精品免费| 久久婷婷人人澡人人爽人人爱| 久久精品中文字幕第23页| 国产精品热久久毛片| 久久综合综合久久狠狠狠97色88 | 99蜜桃臀久久久欧美精品网站| 久久久久人妻一区精品| 亚洲精品无码久久久久久| AA级片免费看视频久久| 久久久久亚洲AV片无码下载蜜桃| 成人午夜精品无码区久久| 青青青国产成人久久111网站| 久久亚洲AV无码精品色午夜| 国产精品永久久久久久久久久| 欧美丰满熟妇BBB久久久| 俺来也俺去啦久久综合网| 久久香蕉超碰97国产精品| 中文字幕无码久久久| 亚洲va久久久噜噜噜久久| 伊人热热久久原色播放www| 久久99精品久久久久久秒播| 久久国产精品99久久久久久老狼| 久久夜色精品国产噜噜亚洲a| 久久久不卡国产精品一区二区| 亚洲国产二区三区久久| 久久国产精品99久久久久久老狼| 久久成人国产精品| 久久国产高清字幕中文| 国产成人精品久久亚洲| 国产精品永久久久久久久久久|