什么是系統(tǒng)調(diào)用?
Linux內(nèi)核中設(shè)置了一組用于實(shí)現(xiàn)各種系統(tǒng)功能的子程序,稱為系統(tǒng)調(diào)用。用戶可以通過系統(tǒng)調(diào)用命令在自己的應(yīng)用程序中調(diào)用它們。從某種角度來看,系統(tǒng)調(diào)用和普通的函數(shù)調(diào)用非常相似。區(qū)別僅僅在于,系統(tǒng)調(diào)用由操作系統(tǒng)核心提供,運(yùn)行于核心態(tài);而普通的函數(shù)調(diào)用由函數(shù)庫或用戶自己提供,運(yùn)行于用戶態(tài)。
隨Linux核心還提供了一些C語言函數(shù)庫,這些庫對系統(tǒng)調(diào)用進(jìn)行了一些包裝和擴(kuò)展,因?yàn)檫@些庫函數(shù)與系統(tǒng)調(diào)用的關(guān)系非常緊密,所以習(xí)慣上把這些函數(shù)也稱為系統(tǒng)調(diào)用。
為什么要用系統(tǒng)調(diào)用?
實(shí)際上,很多已經(jīng)被我們習(xí)以為常的C語言標(biāo)準(zhǔn)函數(shù),在Linux平臺上的實(shí)現(xiàn)都是靠系統(tǒng)調(diào)用完成的,所以如果想對系統(tǒng)底層的原理作深入的了解,掌握各種系統(tǒng)調(diào)用是初步的要求。進(jìn)一步,若想成為一名Linux下編程高手,也就是我們常說的Hacker,其標(biāo)志之一也是能對各種系統(tǒng)調(diào)用有透徹的了解。
即使除去上面的原因,在平常的編程中你也會發(fā)現(xiàn),在很多情況下,系統(tǒng)調(diào)用是實(shí)現(xiàn)你的想法的簡潔有效的途徑,所以有可能的話應(yīng)該盡量多掌握一些系統(tǒng)調(diào)用,這會對你的程序設(shè)計(jì)過程帶來意想不到的幫助。
系統(tǒng)調(diào)用是怎么工作的?
一般的,進(jìn)程是不能訪問內(nèi)核的。它不能訪問內(nèi)核所占內(nèi)存空間也不能調(diào)用內(nèi)核函數(shù)。CPU硬件決定了這些(這就是為什么它被稱作"保護(hù)模式")。系統(tǒng)調(diào)用是這些規(guī)則的一個例外。其原理是進(jìn)程先用適當(dāng)?shù)闹堤畛?a href="http://www.delux-kingway.cn/tags/寄存器/" target="_blank">寄存器,然后調(diào)用一個特殊的指令,這個指令會跳到一個事先定義的內(nèi)核中的一個位置(當(dāng)然,這個位置是用戶進(jìn)程可讀但是不可寫的)。在Intel CPU中,這個由中斷0x80實(shí)現(xiàn)。硬件知道一旦你跳到這個位置,你就不是在限制模式下運(yùn)行的用戶,而是作為操作系統(tǒng)的內(nèi)核--所以你就可以為所欲為。
進(jìn)程可以跳轉(zhuǎn)到的內(nèi)核位置叫做sysem_call。這個過程檢查系統(tǒng)調(diào)用號,這個號碼告訴內(nèi)核進(jìn)程請求哪種服務(wù)。然后,它查看系統(tǒng)調(diào)用表(sys_call_table)找到所調(diào)用的內(nèi)核函數(shù)入口地址。接著,就調(diào)用函數(shù),等返回后,做一些系統(tǒng)檢查,最后返回到進(jìn)程(或到其他進(jìn)程,如果這個進(jìn)程時間用盡)。
具體過程如下圖所示:
如何使用系統(tǒng)調(diào)用?
先來看一個例子:
這是因?yàn)樵?a href="http://www.delux-kingway.cn/tags/ti/" target="_blank">time.h中實(shí)際上已經(jīng)用庫函數(shù)的形式實(shí)現(xiàn)了time這個系統(tǒng)調(diào)用,替我們省掉了調(diào)用_syscall1宏展開得到函數(shù)原型這一步。
大多數(shù)系統(tǒng)調(diào)用都在各種C語言函數(shù)庫中有所實(shí)現(xiàn),所以在一般情況下,我們都可以像調(diào)用普通的庫函數(shù)那樣調(diào)用系統(tǒng)調(diào)用,只在極個別的情況下,我們才有機(jī)會用到_syscall*()這幾個宏。
調(diào)用性能問題
系統(tǒng)調(diào)用需要從用戶空間陷入內(nèi)核空間,處理完后,又需要返回用戶空間。其中除了系統(tǒng)調(diào)用服務(wù)例程的實(shí)際耗時外,陷入/返回過程和系統(tǒng)調(diào)用處理程序(查系統(tǒng)調(diào)用表、存儲\恢復(fù)用戶現(xiàn)場)也需要花銷一些時間,這些時間加起來就是一個系統(tǒng)調(diào)用的響應(yīng)速度。系統(tǒng)調(diào)用不比別的用戶程序,它對性能要求很苛刻,因?yàn)樗枰萑雰?nèi)核執(zhí)行,所以和其他內(nèi)核程序一樣要求代碼簡潔、執(zhí)行迅速。幸好Linux具有令人難以置信的上下文切換速度,使得其進(jìn)出內(nèi)核都被優(yōu)化得簡潔高效;同時所有Linux系統(tǒng)調(diào)用處理程序和每個系統(tǒng)調(diào)用本身也都非常簡潔。
絕大多數(shù)情況下,Linux系統(tǒng)調(diào)用性能是可以接受的,但是對于一些對性能要求非常高的應(yīng)用來說,它們雖然希望利用系統(tǒng)調(diào)用的服務(wù),但卻希望加快相應(yīng)速度,避免陷入/返回和系統(tǒng)調(diào)用處理程序帶來的花銷,因此采用由內(nèi)核直接調(diào)用系統(tǒng)調(diào)用服務(wù)例程,最好的例子就HTTPD——它為了避免上述開銷,從內(nèi)核調(diào)用socket等系統(tǒng)調(diào)用服務(wù)例程。
-
Linux
+關(guān)注
關(guān)注
87文章
11350瀏覽量
210477 -
系統(tǒng)調(diào)用
+關(guān)注
關(guān)注
0文章
28瀏覽量
8357
原文標(biāo)題:若想成為一名Linux下編程高手,必須能對各種系統(tǒng)調(diào)用有透徹的了解
文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
如何成為一名嵌入式C語言高手?
如何成為一名嵌入式C語言高手?
Linux下C語言編程入門教程
了解各種系統(tǒng)調(diào)用助你成為一名Linux下編程高手
![<b class='flag-5'>了解</b>各種<b class='flag-5'>系統(tǒng)</b><b class='flag-5'>調(diào)用</b><b class='flag-5'>助你</b><b class='flag-5'>成為</b>一名<b class='flag-5'>Linux</b><b class='flag-5'>下</b><b class='flag-5'>編程</b><b class='flag-5'>高手</b>](https://file.elecfans.com/web1/M00/50/97/o4YBAFr4_t2Adh8_AAAQ4P4oYHY755.jpg)
Linux操作系統(tǒng)實(shí)用教程之如何進(jìn)行Linux系統(tǒng)下的編程管理
![<b class='flag-5'>Linux</b>操作<b class='flag-5'>系統(tǒng)</b>實(shí)用教程之如何進(jìn)行<b class='flag-5'>Linux</b><b class='flag-5'>系統(tǒng)</b><b class='flag-5'>下</b>的<b class='flag-5'>編程</b>管理](https://file.elecfans.com/web1/M00/6A/7A/o4YBAFvaa7iANzAGAABWpCNcfQs600.png)
LINUX系統(tǒng)教程之如何在Linux系統(tǒng)下進(jìn)行編程
需要了解Linux下的文件I/O編程
Linux下系統(tǒng)調(diào)用的技巧
如何區(qū)分xenomai、linux系統(tǒng)調(diào)用/服務(wù)
Linux系統(tǒng)調(diào)用的具體實(shí)現(xiàn)原理
![<b class='flag-5'>Linux</b><b class='flag-5'>系統(tǒng)</b><b class='flag-5'>調(diào)用</b>的具體實(shí)現(xiàn)原理](https://file1.elecfans.com/web2/M00/A1/B2/wKgZomT28fCAPIkHAAAd7eEyePc89.jpeg)
評論