什么是信號(hào)
信號(hào)可以理解為軟件中斷,是在軟件層次上對(duì)中斷機(jī)制的一種模擬,在原理上,一個(gè)進(jìn)程收到一個(gè)信號(hào)與處理器收到一個(gè)中斷請(qǐng)求可以說是差不多的。信號(hào)是異步的,一個(gè)進(jìn)程不必通過任何操作來等待信號(hào)的到達(dá)。信號(hào)可以直接進(jìn)行用戶空間進(jìn)程和內(nèi)核進(jìn)程之間的交互,內(nèi)核進(jìn)程也可以利用它來通知用戶空間進(jìn)程發(fā)生了哪些系統(tǒng)事件。
誰來產(chǎn)生信號(hào)
信號(hào)事件的發(fā)生有兩個(gè)來源:
(1) 硬件來源,比如我們按下ctrl+c,會(huì)產(chǎn)生SIGINT信號(hào)。
(2) 軟件來源,比如我們調(diào)用alarm函數(shù)來產(chǎn)生SIGALRM信號(hào)。
常用信號(hào)
Linux信號(hào)的編號(hào)是從1-64,其中32和33空缺,沒有對(duì)應(yīng)的信號(hào)。通過kill -l 可查看所有的信號(hào)。
1~31之間的信號(hào)叫做不可靠信號(hào), 信號(hào)可能會(huì)丟失, 也叫做非實(shí)時(shí)信號(hào)。
34~64之間的信號(hào)叫做可靠信號(hào), 信號(hào)不會(huì)丟失, 也叫做實(shí)時(shí)信號(hào)。
信號(hào)響應(yīng)方式
信號(hào)有如下三種響應(yīng)方式:
(1) 忽略信號(hào),即對(duì)信號(hào)不做任何處理,但是有兩個(gè)信號(hào)不能忽略,即 SIGKILL 及 SIGSTOP。
(2) 捕捉信號(hào),定義信號(hào)處理函數(shù),當(dāng)信號(hào)發(fā)生時(shí),執(zhí)行相應(yīng)的自定義處理函數(shù)。
(3) 執(zhí)行缺省操作,Linux 對(duì)每種信號(hào)都規(guī)定了默認(rèn)操作。
信號(hào)處理過程
信號(hào)處理的大致流程如下:
信號(hào)產(chǎn)生 -》 信號(hào)注冊 -》 信號(hào)在進(jìn)程中注銷 -》 信號(hào)處理函數(shù)執(zhí)行完畢
我們主要講一下“信號(hào)注冊” 和“信號(hào)在進(jìn)程中注銷”。其他兩個(gè)都比較好理解。
信號(hào)注冊指的是在目標(biāo)進(jìn)程中注冊,該目標(biāo)進(jìn)程中有未決信號(hào)的信息。啥叫未決信號(hào)呢,實(shí)際執(zhí)行信號(hào)的處理動(dòng)作稱為信號(hào)遞達(dá),信號(hào)從產(chǎn)生到遞達(dá)之間的狀態(tài),稱為信號(hào)未決。
先來看一下對(duì)應(yīng)的結(jié)構(gòu)體:
struct sigpending{ //未決信號(hào)鏈的頭部與尾部 struct sigqueue *head, *tail; //未決信號(hào)集 sigset_t signal;};
struct sigqueue{ struct sigqueue *next; //信號(hào)所攜帶的信息 siginfo_t info;}
信號(hào)注冊的過程就是將信號(hào)值加入到未決信號(hào)集siginfo_t中,將信號(hào)所攜帶的信息加入到未決信號(hào)鏈的某一個(gè)sigqueue中去。
因此,對(duì)于可靠的信號(hào),可能存在多個(gè)未決信號(hào)的sigqueue結(jié)構(gòu),對(duì)于每次信號(hào)到來都會(huì)注冊。而不可靠信號(hào)只注冊一次,只有一個(gè)sigqueue結(jié)構(gòu)。
只要信號(hào)在進(jìn)程的未決信號(hào)集中,表明進(jìn)程已經(jīng)知道這些信號(hào)了,還沒來得及處理,或者是這些信號(hào)被阻塞。
信號(hào)在進(jìn)程中注銷是指進(jìn)程已經(jīng)接收到信號(hào)了,會(huì)在鏈表中移除。在進(jìn)程的執(zhí)行過程中,每次從系統(tǒng)調(diào)用或中斷返回用戶空間的時(shí)候,都會(huì)檢查是否有信號(hào)沒有被處理。如果這些信號(hào)沒有被阻塞,那么就調(diào)用相應(yīng)的信號(hào)處理函數(shù)來處理這些信號(hào)。可靠信號(hào)和不可靠信號(hào)的處理有所不同:
不可靠信號(hào):由于不可靠信號(hào)在未決信號(hào)鏈中只有一個(gè)sigqueue結(jié)構(gòu),因此將它刪除的同時(shí),也會(huì)將信號(hào)從未決信號(hào)集中刪除。
可靠信號(hào):由于可靠信號(hào)在未決信號(hào)鏈中可能有多個(gè)sigqueue結(jié)構(gòu),如果只有一個(gè),也將信號(hào)從未決信號(hào)集中刪除掉。如果有多個(gè)則不從未決信號(hào)集中刪除信號(hào),注銷完畢。
原文標(biāo)題:Linux信號(hào)及工作原理
文章出處:【微信公眾號(hào):FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
責(zé)任編輯:haq
-
Linux
+關(guān)注
關(guān)注
88文章
11758瀏覽量
219004 -
信號(hào)
+關(guān)注
關(guān)注
12文章
2914瀏覽量
80120
原文標(biāo)題:Linux信號(hào)及工作原理
文章出處:【微信號(hào):zhuyandz,微信公眾號(hào):FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
兩個(gè)RS485-Modbus主站如何通訊
數(shù)字延遲脈沖發(fā)生器 脈沖延遲信號(hào)發(fā)生器 多通道脈沖信號(hào)發(fā)生器
曙光存儲(chǔ)連續(xù)斬獲兩個(gè)行業(yè)獎(jiǎng)項(xiàng)
一個(gè)硬件SPI兩個(gè)CS操作兩個(gè)norflash,怎么互斥操作兩個(gè)norflash?
LMK03328 具有兩個(gè)獨(dú)立 PLL 的超低抖動(dòng)時(shí)鐘發(fā)生器系列技術(shù)手冊
基本半導(dǎo)體連獲兩個(gè)行業(yè)獎(jiǎng)項(xiàng)
你知道嗎?信號(hào)源≠信號(hào)發(fā)生器!#信號(hào)源 #信號(hào)發(fā)生器 #任意波形發(fā)生器 #電子工程師
圖中兩個(gè)按鍵開關(guān)是兩個(gè)干簧管,為什么不直接對(duì)GND設(shè)計(jì)來檢測這個(gè)干簧管通斷呢?
看到STM8L152用兩個(gè)IO用兩個(gè)或非門檢測兩個(gè)通斷,是什么原理呢?
當(dāng)CY7C65215在兩個(gè)通道上配置為 SPI 和 I2C 時(shí),能否在Linux系統(tǒng)中看到兩個(gè)設(shè)備?
ADAU1787四個(gè)ADC、兩個(gè)DAC、帶音頻DSP的低功耗編解碼器技術(shù)手冊
信號(hào)發(fā)生器輸出方波的占空比調(diào)整技巧
信號(hào)發(fā)生器互調(diào)失真測量:原理、方法與工程應(yīng)用
Linux信號(hào)事件發(fā)生的兩個(gè)來源
評(píng)論