亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

Linux系統(tǒng)為什么需要區(qū)分內(nèi)核空間與用戶空間?

工程師 ? 來源:博客園 ? 作者:sparkdev ? 2020-10-14 14:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

作者:sparkdev

本文以 32 位系統(tǒng)為例介紹內(nèi)核空間(kernel space)和用戶空間(user space)。

內(nèi)核空間和用戶空間對 32 位操作系統(tǒng)而言,它的尋址空間(虛擬地址空間,或叫線性地址空間)為 4G(2的32次方)。也就是說一個進程的最大地址空間為 4G。

操作系統(tǒng)的核心是內(nèi)核(kernel),它獨立于普通的應用程序,可以訪問受保護的內(nèi)存空間,也有訪問底層硬件設備的所有權限。為了保證內(nèi)核的安全,現(xiàn)在的操作系統(tǒng)一般都強制用戶進程不能直接操作內(nèi)核。

具體的實現(xiàn)方式基本都是由操作系統(tǒng)將虛擬地址空間劃分為兩部分,一部分為內(nèi)核空間,另一部分為用戶空間。針對 Linux 操作系統(tǒng)而言,最高的 1G 字節(jié)(從虛擬地址 0xC0000000 到 0xFFFFFFFF)由內(nèi)核使用,稱為內(nèi)核空間。而較低的 3G 字節(jié)(從虛擬地址 0x00000000 到 0xBFFFFFFF)由各個進程使用,稱為用戶空間。

對上面這段內(nèi)容我們可以這樣理解:「每個進程的 4G 地址空間中,最高 1G 都是一樣的,即內(nèi)核空間。只有剩余的 3G 才歸進程自己使用。」

「換句話說就是, 最高 1G 的內(nèi)核空間是被所有進程共享的!」下圖描述了每個進程 4G 地址空間的分配情況(此圖來自互聯(lián)網(wǎng)):

為什么需要區(qū)分內(nèi)核空間與用戶空間在 CPU 的所有指令中,有些指令是非常危險的,如果錯用,將導致系統(tǒng)崩潰,比如清內(nèi)存、設置時鐘等。如果允許所有的程序都可以使用這些指令,那么系統(tǒng)崩潰的概率將大大增加。

所以,CPU 將指令分為特權指令和非特權指令,對于那些危險的指令,只允許操作系統(tǒng)及其相關模塊使用,普通應用程序只能使用那些不會造成災難的指令。

比如 Intel 的 CPU 將特權等級分為 4 個級別:Ring0~Ring3。其實 Linux 系統(tǒng)只使用了 Ring0 和 Ring3 兩個運行級別(Windows 系統(tǒng)也是一樣的)。

當進程運行在 Ring3 級別時被稱為運行在用戶態(tài),而運行在 Ring0 級別時被稱為運行在內(nèi)核態(tài)。

內(nèi)核態(tài)與用戶態(tài)好了我們現(xiàn)在需要再解釋一下什么是內(nèi)核態(tài)、用戶態(tài):「當進程運行在內(nèi)核空間時就處于內(nèi)核態(tài),而進程運行在用戶空間時則處于用戶態(tài)?!?/p>

在內(nèi)核態(tài)下,進程運行在內(nèi)核地址空間中,此時 CPU 可以執(zhí)行任何指令。運行的代碼也不受任何的限制,可以自由地訪問任何有效地址,也可以直接進行端口的訪問。

在用戶態(tài)下,進程運行在用戶地址空間中,被執(zhí)行的代碼要受到 CPU 的諸多檢查,它們只能訪問映射其地址空間的頁表項中規(guī)定的在用戶態(tài)下可訪問頁面的虛擬地址,且只能對任務狀態(tài)段(TSS)中 I/O 許可位圖(I/O Permission Bitmap)中規(guī)定的可訪問端口進行直接訪問。

對于以前的 DOS 操作系統(tǒng)來說,是沒有內(nèi)核空間、用戶空間以及內(nèi)核態(tài)、用戶態(tài)這些概念的??梢哉J為所有的代碼都是運行在內(nèi)核態(tài)的,因而用戶編寫的應用程序代碼可以很容易的讓操作系統(tǒng)崩潰掉。

對于 Linux 來說,通過區(qū)分內(nèi)核空間和用戶空間的設計,隔離了操作系統(tǒng)代碼(操作系統(tǒng)的代碼要比應用程序的代碼健壯很多)與應用程序代碼。

即便是單個應用程序出現(xiàn)錯誤也不會影響到操作系統(tǒng)的穩(wěn)定性,這樣其它的程序還可以正常的運行(Linux 可是個多任務系統(tǒng)?。。?/p>

「所以,區(qū)分內(nèi)核空間和用戶空間本質(zhì)上是要提高操作系統(tǒng)的穩(wěn)定性及可用性?!?/p>

如何從用戶空間進入內(nèi)核空間其實所有的系統(tǒng)資源管理都是在內(nèi)核空間中完成的。比如讀寫磁盤文件,分配回收內(nèi)存,從網(wǎng)絡接口讀寫數(shù)據(jù)等等。

我們的應用程序是無法直接進行這樣的操作的。但是我們可以通過內(nèi)核提供的接口來完成這樣的任務。

比如應用程序要讀取磁盤上的一個文件,它可以向內(nèi)核發(fā)起一個 “系統(tǒng)調(diào)用” 告訴內(nèi)核:“我要讀取磁盤上的某某文件”。

其實就是通過一個特殊的指令讓進程從用戶態(tài)進入到內(nèi)核態(tài)(到了內(nèi)核空間),在內(nèi)核空間中,CPU 可以執(zhí)行任何的指令,當然也包括從磁盤上讀取數(shù)據(jù)。具體過程是先把數(shù)據(jù)讀取到內(nèi)核空間中,然后再把數(shù)據(jù)拷貝到用戶空間并從內(nèi)核態(tài)切換到用戶態(tài)。

此時應用程序已經(jīng)從系統(tǒng)調(diào)用中返回并且拿到了想要的數(shù)據(jù),可以開開心心的往下執(zhí)行了。簡單說就是應用程序把高科技的事情(從磁盤讀取文件)外包給了系統(tǒng)內(nèi)核,系統(tǒng)內(nèi)核做這些事情既專業(yè)又高效。

對于一個進程來講,從用戶空間進入內(nèi)核空間并最終返回到用戶空間,這個過程是十分復雜的。舉個例子,比如我們經(jīng)常接觸的概念 “堆?!?,其實進程在內(nèi)核態(tài)和用戶態(tài)各有一個堆棧。

運行在用戶空間時進程使用的是用戶空間中的堆棧,而運行在內(nèi)核空間時,進程使用的是內(nèi)核空間中的堆棧。所以說,Linux 中每個進程有兩個棧,分別用于用戶態(tài)和內(nèi)核態(tài)。

下圖簡明的描述了用戶態(tài)與內(nèi)核態(tài)之間的轉(zhuǎn)換:

既然用戶態(tài)的進程必須切換成內(nèi)核態(tài)才能使用系統(tǒng)的資源,那么我們接下來就看看進程一共有多少種方式可以從用戶態(tài)進入到內(nèi)核態(tài)。

概括的說,有三種方式:系統(tǒng)調(diào)用、軟中斷和硬件中斷。這三種方式每一種都涉及到大量的操作系統(tǒng)知識,所以這里不做展開。

整體結構接下來我們從內(nèi)核空間和用戶空間的角度看一看整個 Linux 系統(tǒng)的結構。它大體可以分為三個部分,從下往上依次為:硬件 -》 內(nèi)核空間 -》 用戶空間。如下圖所示(此圖來自互聯(lián)網(wǎng)):

在硬件之上,內(nèi)核空間中的代碼控制了硬件資源的使用權,用戶空間中的代碼只有通過內(nèi)核暴露的系統(tǒng)調(diào)用接口(System Call Interface)才能使用到系統(tǒng)中的硬件資源。其實,不光是 Linux,Windows 操作系統(tǒng)的設計也是大同小異。

實際上我們可以將每個處理器在任何指定時間點上的活動概括為下列三者之一:

運行于用戶空間,執(zhí)行用戶進程。

運行于內(nèi)核空間,處于進程上下文,代表某個特定的進程執(zhí)行。

運行于內(nèi)核空間,處于中斷上下文,與任何進程無關,處理某個特定的中斷。

以上三點幾乎包括所有的情況,比如當 CPU 空閑時,內(nèi)核就運行一個空進程,處于進程上下文,但運行在內(nèi)核空間。

說明:Linux 系統(tǒng)的中斷服務程序不在進程的上下文中執(zhí)行,它們在一個與所有進程都無關的、專門的中斷上下文中執(zhí)行。

之所以存在一個專門的執(zhí)行環(huán)境,就是為了保證中斷服務程序能夠在第一時間響應和處理中斷請求,然后快速地退出。

總結現(xiàn)代的操作系統(tǒng)大都通過內(nèi)核空間和用戶空間的設計來保護操作系統(tǒng)自身的安全性和穩(wěn)定性。所以在我們閱讀有關操作系統(tǒng)的資料時經(jīng)常遇到內(nèi)核空間、用戶空間和內(nèi)核態(tài)、用戶態(tài)等概念,希望本文能夠幫助您理解這些基本的概念。

責任編輯:haq

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

    關注

    4

    文章

    1432

    瀏覽量

    42355
  • cpu
    cpu
    +關注

    關注

    68

    文章

    11195

    瀏覽量

    222004
  • 數(shù)據(jù)

    關注

    8

    文章

    7305

    瀏覽量

    93645
  • Linux
    +關注

    關注

    88

    文章

    11583

    瀏覽量

    217276
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    通過sysmem接口擴展內(nèi)存空間

    存儲器的訪問接口,在e203_subsys_mems.v文件中可以找到: 同時在這個源文件中實現(xiàn)了一主多從的總線系統(tǒng),可以看到sysmem被分配到0x80000000到0xFFFFFFFF的地址空間
    發(fā)表于 10-24 08:12

    Linux嵌入式和單片機嵌入式的區(qū)別?

    、可定制性、開放源代碼、良好的兼容性、強大的網(wǎng)絡支持、多任務支持、豐富的軟件生態(tài)系統(tǒng)。 架構:應用程序運行在用戶空間,硬件訪問和控制通常在內(nèi)核空間
    發(fā)表于 06-20 09:46

    如何在Linux內(nèi)核5.18版本之后和64位架構中從內(nèi)核空間調(diào)用ioctl?

    我嘗試在最近的內(nèi)核中重新構建以前版本 (4.19) 的 Linux 設備驅(qū)動程序,即嵌入式平臺上的 6.1.22,ARM64 架構。 驅(qū)動程序管理 tty 設備。 當我調(diào)用類似于用戶空間
    發(fā)表于 04-02 06:06

    請問Linux用戶空間可以調(diào)用SCFW API嗎?

    還是僅內(nèi)核空間作? 我想在 Linux 中為 imx8 Quad Max 燒錄保險絲,由于產(chǎn)品的設計,使用 uboot/串行加載器是有問題的。
    發(fā)表于 03-31 07:50

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間用戶空間的數(shù)據(jù)拷貝之獲取用戶空間數(shù)據(jù)

    /environment-setup-cortexa7hf-neon-poky-linux-gnueabi elf@ubuntu:~/work/test/03_內(nèi)核空間用戶
    發(fā)表于 03-22 09:25

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間用戶空間的數(shù)據(jù)拷貝之獲取內(nèi)核空間數(shù)據(jù)

    /environment-setup-cortexa7hf-neon-poky-linux-gnueabi elf@ubuntu:~/work/test/03_內(nèi)核空間用戶
    發(fā)表于 03-21 14:00

    飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間用戶空間的數(shù)據(jù)拷貝之獲取用戶空間數(shù)據(jù)

    /environment-setup-cortexa7hf-neon-poky-linux-gnueabi elf@ubuntu:~/work/test/03_內(nèi)核空間用戶
    發(fā)表于 03-21 13:58

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間用戶空間的數(shù)據(jù)拷貝之數(shù)據(jù)拷貝介紹

    本帖最后由 jf_13411809 于 2025-3-20 14:10 編輯 在Linux系統(tǒng)中,內(nèi)核空間用戶
    發(fā)表于 03-20 11:50

    飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間用戶空間的數(shù)據(jù)拷貝之獲取內(nèi)核空間數(shù)據(jù)

    /environment-setup-cortexa7hf-neon-poky-linux-gnueabi elf@ubuntu:~/work/test/03_內(nèi)核空間用戶
    發(fā)表于 03-20 11:48

    飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間用戶空間的數(shù)據(jù)拷貝之數(shù)據(jù)拷貝介紹

    Linux系統(tǒng)中,內(nèi)核空間用戶空間是兩個獨立的地址空間
    發(fā)表于 03-19 08:55

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-Linux設備驅(qū)動的分類

    內(nèi)核模塊嵌入到Linux內(nèi)核中,位于內(nèi)核空間。它們直接與內(nèi)核進行交互,通過
    發(fā)表于 03-12 10:20

    飛凌嵌入式ElfBoard ELF 1板卡-Linux設備驅(qū)動的分類

    內(nèi)核模塊嵌入到Linux內(nèi)核中,位于內(nèi)核空間。它們直接與內(nèi)核進行交互,通過
    發(fā)表于 03-10 17:00

    Linux下如何管理虛擬內(nèi)存 使用虛擬內(nèi)存時的常見問題

    Linux系統(tǒng)中,虛擬內(nèi)存管理是操作系統(tǒng)內(nèi)核的一個重要功能,負責管理物理內(nèi)存和磁盤上的交換空間。以下是對
    的頭像 發(fā)表于 12-04 09:19 ?1753次閱讀

    ADC12D1000不需要區(qū)分數(shù)字地和模擬地嗎?

    這個芯片不需要區(qū)分數(shù)字地和模擬地嗎?
    發(fā)表于 11-22 08:05

    Linux系統(tǒng)中shell命令解析

    shell是Linux系統(tǒng)用戶界面,提供了用戶內(nèi)核交互的一種接口,它接收用戶輸入的命令并到送
    的頭像 發(fā)表于 11-05 15:40 ?1233次閱讀