女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

linux內(nèi)核信號(hào)是如何處理的?看完全懂了……

電子設(shè)計(jì) ? 來(lái)源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2017-11-16 05:11 ? 次閱讀

本文簡(jiǎn)單介紹下Linux信號(hào)處理機(jī)制,為介紹二進(jìn)制翻譯下信號(hào)處理機(jī)制做一個(gè)鋪墊。
本文主要參考書(shū)目《Linux內(nèi)核源代碼情景分析》《獨(dú)辟蹊徑品內(nèi)核:Linux內(nèi)核源代碼導(dǎo)讀》
首先,先說(shuō)一下什么是信號(hào)。信號(hào)本質(zhì)上是在軟件層次上對(duì)中斷機(jī)制的一種模擬,其主要有以下幾種來(lái)源:

程序錯(cuò)誤:除零,非法內(nèi)存訪問(wèn)…

外部信號(hào):終端Ctrl-C產(chǎn)生SGINT信號(hào),定時(shí)器到期產(chǎn)生SIGALRM…

顯式請(qǐng)求:kill函數(shù)允許進(jìn)程發(fā)送任何信號(hào)給其他進(jìn)程或進(jìn)程組。

在Linux下,可以通過(guò)以下命令查看系統(tǒng)所有的信號(hào):

kill-l

可以通過(guò)類(lèi)似下面的命令顯式的給一個(gè)進(jìn)程發(fā)送一個(gè)信號(hào):

kill-2pid

上面的命令將2號(hào)信號(hào)發(fā)送給進(jìn)程id為pid的進(jìn)程。不存在編號(hào)為0的信號(hào)。

目前Linux支持64種信號(hào)。信號(hào)分為非實(shí)時(shí)信號(hào)(不可靠信號(hào))和實(shí)時(shí)信號(hào)(可靠信號(hào))兩種類(lèi)型,對(duì)應(yīng)于 Linux 的信號(hào)值為 1-31 和 34-64。信號(hào)是異步的,一個(gè)進(jìn)程不必通過(guò)任何操作來(lái)等待信號(hào)的到達(dá),事實(shí)上,進(jìn)程也不知道信號(hào)到底什么時(shí)候到達(dá)。本文著重于Linux的信號(hào)處理機(jī)制,對(duì)信號(hào)更多的介紹可以參考這里。

一般情況下一個(gè)進(jìn)程接受到信號(hào)后,會(huì)有如下的行為:

進(jìn)程對(duì)信號(hào)的響應(yīng)

忽略信號(hào):大部分信號(hào)可被忽略,除SIGSTOP和SIGKILL信號(hào)外(這是超級(jí)用戶(hù)殺掉或停掉任意進(jìn)程的手段)。

捕獲信號(hào):注冊(cè)信號(hào)處理函數(shù),它對(duì)產(chǎn)生的特定信號(hào)做處理。

讓信號(hào)默認(rèn)動(dòng)作起作用:unix內(nèi)核定義的默認(rèn)動(dòng)作,有5種情況:

a) 流產(chǎn)abort:終止進(jìn)程并產(chǎn)生core文件。

b) 終止stop:終止進(jìn)程但不生成core文件。

c) 忽略:忽略信號(hào)。

d) 掛起suspend:掛起進(jìn)程。

e) 繼續(xù)continue:若進(jìn)程是掛起的,則resume進(jìn)程,否則忽略此信號(hào)。

注冊(cè)信號(hào)處理函數(shù)

如果想要進(jìn)程捕獲某個(gè)信號(hào),然后作出相應(yīng)的處理,就需要注冊(cè)信號(hào)處理函數(shù)。同中斷類(lèi)似,內(nèi)核也為每個(gè)進(jìn)程準(zhǔn)備了一個(gè)信號(hào)向量表,信號(hào)向量表中記錄著每個(gè)信號(hào)所對(duì)應(yīng)的處理機(jī)制,默認(rèn)情況下是調(diào)用默認(rèn)處理機(jī)制。當(dāng)進(jìn)程為某個(gè)信號(hào)注冊(cè)了信號(hào)處理程序后,發(fā)生該信號(hào)時(shí),內(nèi)核就會(huì)調(diào)用注冊(cè)的函數(shù)。

注冊(cè)信號(hào)處理函數(shù)是通過(guò)系統(tǒng)調(diào)用signal()、sigaction()。其中signal()在可靠信號(hào)系統(tǒng)調(diào)用的基礎(chǔ)上實(shí)現(xiàn), 是庫(kù)函數(shù)。它只有兩個(gè)參數(shù),不支持信號(hào)傳遞信息,主要是用于前32種非實(shí)時(shí)信號(hào)的安裝;而sigaction()是較新的函數(shù)(由兩個(gè)系統(tǒng)調(diào)用實(shí) 現(xiàn):sys_signal以及sys_rt_sigaction),有三個(gè)參數(shù),支持信號(hào)傳遞信息,主要用來(lái)與 sigqueue() 系統(tǒng)調(diào)用配合使用,當(dāng)然,sigaction()同樣支持非實(shí)時(shí)信號(hào)的安裝。sigaction()優(yōu)于signal()主要體現(xiàn)在支持信號(hào)帶有參數(shù)。關(guān)于這方面的內(nèi)容,如果想獲取更多,也可參考這里。

Linux下信號(hào)處理機(jī)制

進(jìn)程如何發(fā)現(xiàn)和接受信號(hào)?

我們知道,信號(hào)是異步的,一個(gè)進(jìn)程不可能等待信號(hào)的到來(lái),也不知道信號(hào)會(huì)到來(lái),那么,進(jìn)程是如何發(fā)現(xiàn)和接受信號(hào)呢?實(shí)際上,信號(hào)的接收不是由用戶(hù)進(jìn)程來(lái)完成的,而是由內(nèi)核代理。當(dāng)一個(gè)進(jìn)程P2向另一個(gè)進(jìn)程P1發(fā)送信號(hào)后,內(nèi)核接受到信號(hào),并將其放在P1的信號(hào)隊(duì)列當(dāng)中。當(dāng)P1再次陷入內(nèi)核態(tài)時(shí),會(huì)檢查信號(hào)隊(duì)列,并根據(jù)相應(yīng)的信號(hào)調(diào)取相應(yīng)的信號(hào)處理函數(shù)。如下圖所示:


其中,動(dòng)作c:發(fā)現(xiàn)和捕捉信號(hào)

信號(hào)檢測(cè)和響應(yīng)時(shí)機(jī)

剛才我們說(shuō),當(dāng)P1再次陷入內(nèi)核時(shí),會(huì)檢查信號(hào)隊(duì)列。那么,P1什么時(shí)候會(huì)再次陷入內(nèi)核呢?陷入內(nèi)核后在什么時(shí)機(jī)會(huì)檢測(cè)信號(hào)隊(duì)列呢?

當(dāng)前進(jìn)程由于系統(tǒng)調(diào)用、中斷或異常而進(jìn)入系統(tǒng)空間以后,從系統(tǒng)空間返回到用戶(hù)空間的前夕。

當(dāng)前進(jìn)程在內(nèi)核中進(jìn)入睡眠以后剛被喚醒的時(shí)候(必定是在系統(tǒng)調(diào)用中),或者由于不可忽略信號(hào)的存在而提前返回到用戶(hù)空間。

進(jìn)入信號(hào)處理函數(shù)

發(fā)現(xiàn)信號(hào)后,根據(jù)信號(hào)向量,知道了處理函數(shù),那么該如何進(jìn)入信號(hào)處理程序,又該如何返回呢?

我們知道,用戶(hù)進(jìn)程提供的信號(hào)處理函數(shù)是在用戶(hù)態(tài)里的,而我們發(fā)現(xiàn)信號(hào),找到信號(hào)處理函數(shù)的時(shí)刻處于內(nèi)核態(tài)中,所以我們需要從內(nèi)核態(tài)跑到用戶(hù)態(tài)去執(zhí)行信號(hào)處理程序,執(zhí)行完畢后還要返回內(nèi)核態(tài)。這個(gè)過(guò)程如下圖所示:

如圖中所見(jiàn),處理信號(hào)的整個(gè)過(guò)程是這樣的:進(jìn)程由于 系統(tǒng)調(diào)用或者中斷 進(jìn)入內(nèi)核,完成相應(yīng)任務(wù)返回用戶(hù)空間的前夕,檢查信號(hào)隊(duì)列,如果有信號(hào),則根據(jù)信號(hào)向量表找到信號(hào)處理函數(shù),設(shè)置好“frame”后,跳到用戶(hù)態(tài)執(zhí)行信號(hào)處理函數(shù)。信號(hào)處理函數(shù)執(zhí)行完畢后,返回內(nèi)核態(tài),設(shè)置“frame”,再返回到用戶(hù)態(tài)繼續(xù)執(zhí)行程序。

在上面這段話中,我提到“frame”,frame是什么?那么為什么要設(shè)置frame?為什么在執(zhí)行完信號(hào)處理函數(shù)后還要返回內(nèi)核態(tài)呢?

什么叫Frame?

在調(diào)用一個(gè)子程序時(shí),堆棧要往下(邏輯意義上是往上)伸展,這是因?yàn)樾枰诙褩V斜4孀映绦虻姆祷氐刂罚€因?yàn)樽映绦蛲芯植孔兞浚惨加枚褩V械目臻g。此外,調(diào)用子程序時(shí)的參數(shù)也是在堆棧中。子程序調(diào)用嵌套越深,則堆棧伸展的層次也越多。在堆棧中的每一個(gè)這樣的層次,就稱(chēng)為一個(gè)”框架”,即frame。

一般來(lái)說(shuō),當(dāng)子程序和調(diào)用它的程序在同一空間中時(shí),堆棧的伸展,也就是堆棧中框架的建立,過(guò)程主要如下:

call指令將返回地址壓入堆棧(自動(dòng))

用push指令壓入調(diào)用參數(shù)

調(diào)整堆棧指針來(lái)分配局部變量

為什么以及怎么設(shè)置frame?

我們知道,當(dāng)進(jìn)程陷入內(nèi)核態(tài)的時(shí)候,會(huì)在堆棧中保存中斷現(xiàn)場(chǎng)。因?yàn)橛脩?hù)態(tài)和內(nèi)核態(tài)是兩個(gè)運(yùn)行級(jí)別,所以要使用兩個(gè)不同的棧。當(dāng)用戶(hù)進(jìn)程通過(guò)系統(tǒng)調(diào)用剛進(jìn)入內(nèi)核的時(shí)候,CPU會(huì)自動(dòng)在該進(jìn)程的內(nèi)核棧上壓入下圖所示的內(nèi)容:(圖來(lái)自《Linux內(nèi)核完全注釋》)

在處理完系統(tǒng)調(diào)用以后,就要調(diào)用do_signal()函數(shù)進(jìn)行設(shè)置frame等工作。這時(shí)內(nèi)核堆棧的狀態(tài)應(yīng)該跟下圖左半部分類(lèi)似(系統(tǒng)調(diào)用將一些信息壓入棧了):

在找到了信號(hào)處理函數(shù)之后,do_signal函數(shù)首先把內(nèi)核堆棧中存放返回執(zhí)行點(diǎn)的eip保存為old_eip,然后將eip替換為信號(hào)處理函數(shù)的地址,然后將內(nèi)核中保存的“原ESP”(即用戶(hù)態(tài)棧地址)減去一定的值,目的是擴(kuò)大用戶(hù)態(tài)的棧,然后將內(nèi)核棧上的內(nèi)容保存到用戶(hù)棧上,這個(gè)過(guò)程就是設(shè)置frame.值得注意的是下面兩點(diǎn):

之所以把EIP的值設(shè)置成信號(hào)處理函數(shù)的地址,是因?yàn)橐坏┻M(jìn)程返回用戶(hù)態(tài),就要去執(zhí)行信號(hào)處理程序,所以EIP要指向信號(hào)處理程序而不是原來(lái)應(yīng)該執(zhí)行的地址。

之所以要把frame從內(nèi)核棧拷貝到用戶(hù)棧,是因?yàn)檫M(jìn)程從內(nèi)核態(tài)返回用戶(hù)態(tài)會(huì)清理這次調(diào)用所用到的內(nèi)核棧(類(lèi)似函數(shù)調(diào)用),內(nèi)核棧又太小,不能單純的在棧上保存另一個(gè)frame(想象一下嵌套信號(hào)處理),而我們需要EAX(系統(tǒng)調(diào)用返回值)、EIP這些信息以便執(zhí)行完信號(hào)處理函數(shù)后能繼續(xù)執(zhí)行程序,所以把它們拷貝到用戶(hù)態(tài)棧以保存起來(lái)。

以上這些搞清楚之后,下面的事情就順利多了。這時(shí)進(jìn)程返回用戶(hù)空間,就會(huì)根據(jù)內(nèi)核棧中的EIP值執(zhí)行信號(hào)處理函數(shù)。那么,信號(hào)處理程序執(zhí)行完后,怎么返回程序繼續(xù)執(zhí)行呢?

信號(hào)處理函數(shù)執(zhí)行完后怎么辦?

信號(hào)處理程序執(zhí)行完畢之后,進(jìn)程會(huì)主動(dòng)調(diào)用sigreturn()系統(tǒng)調(diào)用再次回到內(nèi)核,查看有沒(méi)有其他信號(hào)需要處理,如果沒(méi)有,這時(shí)內(nèi)核就會(huì)做一些善后工作,將之前保存的frame恢復(fù)到內(nèi)核棧,恢復(fù)eip的值為old_eip,然后返回用戶(hù)空間,程序就能夠繼續(xù)執(zhí)行。至此,內(nèi)核遍完成了一次(或幾次)信號(hào)處理工作。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11459

    瀏覽量

    212789
  • 數(shù)字信號(hào)處理

    關(guān)注

    16

    文章

    567

    瀏覽量

    46540
  • IP內(nèi)核
    +關(guān)注

    關(guān)注

    0

    文章

    13

    瀏覽量

    12958
收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    如何配置和驗(yàn)證Linux內(nèi)核參數(shù)

    Linux系統(tǒng)運(yùn)維和性能優(yōu)化中,內(nèi)核參數(shù)(sysctl)的配置至關(guān)重要。合理的參數(shù)調(diào)整可以顯著提升網(wǎng)絡(luò)性能、系統(tǒng)穩(wěn)定性及資源利用率。然而,僅僅修改參數(shù)是不夠的,如何驗(yàn)證這些參數(shù)是否生效同樣關(guān)鍵。
    的頭像 發(fā)表于 05-29 17:40 ?160次閱讀

    樹(shù)莓派4 性能大比拼:標(biāo)準(zhǔn)Linux與實(shí)時(shí)Linux 4.19內(nèi)核的延遲測(cè)試

    引言本文是對(duì)我之前關(guān)于RaspberryPi3同一主題的帖子的更新。與之前的帖子一樣,我使用的是隨Raspbian鏡像提供的標(biāo)準(zhǔn)內(nèi)核,以及應(yīng)用了RT補(bǔ)丁的相似內(nèi)核版本。對(duì)于實(shí)時(shí)版,我
    的頭像 發(fā)表于 03-25 09:39 ?246次閱讀
    樹(shù)莓派4 性能大比拼:標(biāo)準(zhǔn)<b class='flag-5'>Linux</b>與實(shí)時(shí)<b class='flag-5'>Linux</b> 4.19<b class='flag-5'>內(nèi)核</b>的延遲測(cè)試

    差分輸入的AD轉(zhuǎn)換芯片如何處理單端輸入的信號(hào)

    對(duì)一個(gè)儀表放大器輸出的信號(hào)進(jìn)行AD轉(zhuǎn)換,怎么使用差分輸入呢,IN-端是接地么?還是怎么處理? 即是:差分輸入的AD轉(zhuǎn)換芯片如何處理單端輸入的信號(hào)
    發(fā)表于 02-07 06:40

    騰訊云內(nèi)核團(tuán)隊(duì)修復(fù)Linux關(guān)鍵Bug

    騰訊云操作系統(tǒng)(Tencent OS)內(nèi)核團(tuán)隊(duì)近日在Linux社區(qū)取得了顯著成果。他們提交的兩項(xiàng)改進(jìn)方案,成功解決了自2021年以來(lái)一直困擾眾多一線廠商,并在近期讓多個(gè)Linux頂級(jí)
    的頭像 發(fā)表于 12-31 10:58 ?600次閱讀

    AFE5809EVM GUI如何處理低頻信號(hào)

    請(qǐng)教如何處理低頻信號(hào)。 對(duì)AFE5809EVM GUI進(jìn)行如下圖設(shè)置,請(qǐng)問(wèn)是否正確。
    發(fā)表于 12-09 07:04

    何處理溫度傳感器的信號(hào)干擾

    處理溫度傳感器的信號(hào)干擾是確保其測(cè)量準(zhǔn)確性和穩(wěn)定性的關(guān)鍵。以下是一些有效的處理方法: 一、信號(hào)濾波 信號(hào)濾波技術(shù)是最常用的降噪方法之一。根據(jù)
    的頭像 發(fā)表于 11-22 09:47 ?2176次閱讀

    LMX2572LP如果輸入是單端信號(hào),OSC_INM不用,應(yīng)該如何處理

    我司現(xiàn)用到LMX2572LP,請(qǐng)問(wèn)如果輸入是單端信號(hào),OSC_INM不用,應(yīng)該如何處理? 1.我看手冊(cè)上的應(yīng)用圖是打了一個(gè)×,應(yīng)該是懸空的意思。 2.不過(guò),我看LMX2572LP的評(píng)估板接了些元件 那么,我到底應(yīng)該怎么處理
    發(fā)表于 11-13 06:43

    deepin社區(qū)亮相第19屆中國(guó)Linux內(nèi)核開(kāi)發(fā)者大會(huì)

    中國(guó) Linux 內(nèi)核開(kāi)發(fā)者大會(huì),作為中國(guó) Linux 內(nèi)核領(lǐng)域最具影響力的峰會(huì)之一,一直以來(lái)都備受矚目。
    的頭像 發(fā)表于 10-29 16:35 ?833次閱讀

    詳解linux內(nèi)核的uevent機(jī)制

    linux內(nèi)核中,uevent機(jī)制是一種內(nèi)核和用戶(hù)空間通信的機(jī)制,用于通知用戶(hù)空間應(yīng)用程序各種硬件更改或其他事件,比如插入或移除硬件設(shè)備(如USB驅(qū)動(dòng)器或網(wǎng)絡(luò)接口)。uevent表示“用戶(hù)空間
    的頭像 發(fā)表于 09-29 17:01 ?1664次閱讀

    數(shù)字地和模擬地如何處理

    數(shù)字地和模擬地是電子設(shè)計(jì)中的兩個(gè)基本概念,它們分別代表數(shù)字電路和模擬電路的接地系統(tǒng)。 數(shù)字地和模擬地處理的重要性 在現(xiàn)代電子設(shè)計(jì)中,數(shù)字電路和模擬電路往往共存于同一系統(tǒng)中。數(shù)字電路處理的是離散的信號(hào)
    的頭像 發(fā)表于 09-06 10:39 ?1619次閱讀

    linux驅(qū)動(dòng)程序如何加載進(jìn)內(nèi)核

    Linux系統(tǒng)中,驅(qū)動(dòng)程序是內(nèi)核與硬件設(shè)備之間的橋梁。它們?cè)试S內(nèi)核與硬件設(shè)備進(jìn)行通信,從而實(shí)現(xiàn)對(duì)硬件設(shè)備的控制和管理。 驅(qū)動(dòng)程序的編寫(xiě) 驅(qū)動(dòng)程序的編寫(xiě)是Linux驅(qū)動(dòng)開(kāi)發(fā)的基礎(chǔ)。在編
    的頭像 發(fā)表于 08-30 15:02 ?964次閱讀

    Linux內(nèi)核測(cè)試技術(shù)

    Linux 內(nèi)核Linux操作系統(tǒng)的核心部分,負(fù)責(zé)管理硬件資源和提供系統(tǒng)調(diào)用接口。隨著 Linux 內(nèi)核的不斷發(fā)展和更新,其復(fù)雜性和代碼規(guī)
    的頭像 發(fā)表于 08-13 13:42 ?909次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>測(cè)試技術(shù)

    請(qǐng)問(wèn)比較器不用的引腳如何處理比較好?

    想請(qǐng)問(wèn)一下,比較器不用的引腳如何處理比較好 前段時(shí)間看了一個(gè)國(guó)外比較老的板子,他將比較器不用引腳處理成如下, 總感覺(jué)有點(diǎn)怪怪的,請(qǐng)專(zhuān)家給點(diǎn)意見(jiàn),如何處理比較好
    發(fā)表于 08-12 07:40

    Linux內(nèi)核中的頁(yè)面分配機(jī)制

    Linux內(nèi)核中是如何分配出頁(yè)面的,如果我們站在CPU的角度去看這個(gè)問(wèn)題,CPU能分配出來(lái)的頁(yè)面是以物理頁(yè)面為單位的。也就是我們計(jì)算機(jī)中常講的分頁(yè)機(jī)制。本文就看下Linux內(nèi)核是如何管
    的頭像 發(fā)表于 08-07 15:51 ?563次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>中的頁(yè)面分配機(jī)制

    歡創(chuàng)播報(bào) 華為宣布鴻蒙內(nèi)核已超越Linux內(nèi)核

    1 華為宣布鴻蒙內(nèi)核已超越Linux內(nèi)核 ? 6月21日,在華為開(kāi)發(fā)者大會(huì)上, HarmonyOS NEXT(鴻蒙NEXT)——真正獨(dú)立于安卓和iOS的鴻蒙操作系統(tǒng),正式登場(chǎng)。這是HarmonyOS
    的頭像 發(fā)表于 06-27 11:30 ?1156次閱讀