色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

以32位系統為例介紹內核空間和用戶空間

Q4MP_gh_c472c21 ? 來源:嵌入式ARM ? 作者:sparkdev ? 2020-11-12 17:41 ? 次閱讀

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

內核空間和用戶空間

對 32 位操作系統而言,它的尋址空間(虛擬地址空間,或叫線性地址空間)為 4G(2的32次方)。也就是說一個進程的最大地址空間為 4G。

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

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

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

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

為什么需要區分內核空間與用戶空間

CPU 的所有指令中,有些指令是非常危險的,如果錯用,將導致系統崩潰,比如清內存、設置時鐘等。如果允許所有的程序都可以使用這些指令,那么系統崩潰的概率將大大增加。

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

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

當進程運行在 Ring3 級別時被稱為運行在用戶態,而運行在 Ring0 級別時被稱為運行在內核態。

內核態與用戶態

好了我們現在需要再解釋一下什么是內核態、用戶態:「當進程運行在內核空間時就處于內核態,而進程運行在用戶空間時則處于用戶態。」

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

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

對于以前的 DOS 操作系統來說,是沒有內核空間、用戶空間以及內核態、用戶態這些概念的。可以認為所有的代碼都是運行在內核態的,因而用戶編寫的應用程序代碼可以很容易的讓操作系統崩潰掉。

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

即便是單個應用程序出現錯誤也不會影響到操作系統的穩定性,這樣其它的程序還可以正常的運行(Linux 可是個多任務系統啊!)。

「所以,區分內核空間和用戶空間本質上是要提高操作系統的穩定性及可用性。」

如何從用戶空間進入內核空間

其實所有的系統資源管理都是在內核空間中完成的。比如讀寫磁盤文件,分配回收內存,從網絡接口讀寫數據等等。

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

比如應用程序要讀取磁盤上的一個文件,它可以向內核發起一個 "系統調用" 告訴內核:"我要讀取磁盤上的某某文件"。

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

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

對于一個進程來講,從用戶空間進入內核空間并最終返回到用戶空間,這個過程是十分復雜的。舉個例子,比如我們經常接觸的概念 "堆棧",其實進程在內核態和用戶態各有一個堆棧。

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

下圖簡明的描述了用戶態與內核態之間的轉換:

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

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

整體結構

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

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

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

運行于用戶空間,執行用戶進程。

運行于內核空間,處于進程上下文,代表某個特定的進程執行。

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

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

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

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

總結

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

責任編輯:xj

原文標題:Linux系統中,為什么需要區分內核空間與用戶空間?

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關注!文章轉載請注明出處。

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

    關注

    5082

    文章

    19104

    瀏覽量

    304823
  • 內核
    +關注

    關注

    3

    文章

    1372

    瀏覽量

    40280
  • Linux
    +關注

    關注

    87

    文章

    11292

    瀏覽量

    209332

原文標題:Linux系統中,為什么需要區分內核空間與用戶空間?

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    設計相位型空間光調制器生成高帽光束

    、SNR,一致性偏差,雜散光評估 ?建模/設計 —基于迭代傅里葉變換算法(IFTA)設計位相傳遞函數,將高斯光束整形高帽光束 —場追跡:光在空間光調制器像素陣列的衍射。 2.系統圖示 3.建模與設計結果
    發表于 12-12 10:28

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-應用編程示例控制LED燈之sysfs文件系統

    文件系統概念sysfs是Linux2.6以上的內核在發展迭代過程中衍生出來的一個功能,它的作用是通過一個內存文件系統將信息導出到用戶進程空間
    發表于 10-21 09:52

    飛凌嵌入式ElfBoard ELF 1板卡-應用編程示例控制LED燈之sysfs文件系統

    用戶空間文件目錄結構的形式用戶空間提供對這些數據、屬性的訪問支持。下表描述了
    發表于 10-18 09:31

    電壓空間矢量與磁鏈矢量的關系是什么

    電壓空間矢量與磁鏈矢量的關系在電機控制和變頻調速系統中具有重要地位。以下是對這兩者關系的介紹: 一、基本概念 電壓空間矢量 : 又名“空間
    的頭像 發表于 10-12 15:12 ?622次閱讀

    詳解linux內核的uevent機制

    在linux內核中,uevent機制是一種內核用戶空間通信的機制,用于通知用戶空間應用程序各種
    的頭像 發表于 09-29 17:01 ?638次閱讀

    linux驅動程序運行在什么空間

    空間擁有對硬件的直接訪問權限,而用戶空間則受到限制,保護系統的穩定性和安全性。 1. Linux 內核
    的頭像 發表于 08-30 14:37 ?392次閱讀

    高質量激光光束光學系統中的空間濾波

    和精度至關重要。 VirtualLab Fusion獨特的模擬技術使用戶能夠對濾波進行詳細建模,從而評估對光學系統性能和特性的影響。 用于光束切趾的圓形鋸齒光闌 光束切趾在高能激光器和光束傳輸系統
    發表于 08-14 11:54

    操作系統的內存布局介紹

    32操作系統的內存布局很經典,很多書籍都是以32系統例子去講解的。32
    的頭像 發表于 08-07 15:47 ?269次閱讀
    操作<b class='flag-5'>系統</b>的內存布局<b class='flag-5'>介紹</b>

    達實智能AIoT空間場景控制系統概述

    面對當前建筑空間智能化實施運營中存在的子系統不互通、控制延時、運維成本高、面板復雜不統一等問題,達實通過分割整體建筑單元空間,集成空間環境
    的頭像 發表于 07-30 11:27 ?814次閱讀

    地下人防空間環境檢測儀介紹

    地下人防空間環境檢測儀介紹
    的頭像 發表于 07-01 11:05 ?242次閱讀
    地下人防<b class='flag-5'>空間</b>環境檢測儀<b class='flag-5'>介紹</b>

    索尼投影機助力原力全感視聽空間

    。 原力視聽的發展始于與知名音響品牌的合作,此后憑借對聲學設計和視聽技術的專業理解,逐步擴展業務范圍,以為家庭和商業空間設計定制高端影音娛樂系統為主營業務,迄今為止已經成功打造數百個專屬的影音空間。公司門店
    的頭像 發表于 06-16 17:17 ?1261次閱讀

    PCIE的BAR空間介紹

    PCIE是一種高速串行總線接口標準,用于連接計算機內部的各種外設和組件。在PCIe架構中,BAR(Base Address Register)空間是用于映射I/O端口或內存地址空間的一組寄存器。
    的頭像 發表于 04-22 11:00 ?4314次閱讀

    gis中常用的空間分析方法

    GIS中常用的空間分析方法 GIS(地理信息系統)是一種用于收集、存儲、處理、分析和展示地理數據的技術。空間分析是GIS的核心部分,它包括一系列方法和技術,用來研究地理空間數據之間的關
    的頭像 發表于 02-25 13:44 ?5499次閱讀

    arcgis空間參考與數據框不匹配如何解決

    當使用ArcGIS軟件進行空間數據處理時,經常會遇到空間參考與數據框不匹配的問題。這種不匹配可能導致數據顯示不正確,分析結果不準確,甚至引發其他錯誤。本文將詳細介紹空間參考與數據框不匹
    的頭像 發表于 02-25 11:17 ?1.3w次閱讀

    達實空間場景控制系統的常見問題解答

    達實空間場景控制系統自面世以來,憑借其創新的“空間場景”概念,吸引了業界和用戶的廣泛關注。
    的頭像 發表于 01-10 10:44 ?659次閱讀
    主站蜘蛛池模板: 亚洲 无码 在线 专区| 污污内射在线观看一区二区少妇 | 久久免费精品一区二区| 两个吃奶一个添下面视频| 日本xxx护士与黑人| 亚洲AV久久无码精品蜜桃| 69精品人人人人| 国产69精品久久久久麻豆| 精品久久久久中文字幕日本 | 99热国产这里只有精品6| 国产精品高清在线观看93| 久久视频这里只精品99热在线观看 | 久久久精品久久久久久| 青娱乐视觉盛宴国产视频| 亚洲成av人影院| a一级一片免费观看视频| 国内精品七七久久影院| 欧美囗交xx bbb视频| 亚洲欧美综合中文| 糙汉顶弄抽插HHHH| 69人体阴展网| 野花影院手机在线观看| 午夜影视免费| 永久免费在线看mv| 樱花草在线观看影院| 亚洲精品一区国产欧美| 亚洲精品久久久久久偷窥| 激情床戏视频片段有叫声| a视频在线观看免费| 亚洲午夜精品一区二区公牛电影院| 热巴两次用约老师屁股发底线球| 精品国产免费观看久久久| 久久天堂网| 国产精品热久久高潮AV袁孑怡| 国产偷国产偷亚洲高清app| 欧美三级黄色大片| 伊人久久中文| 国产精品美女久久久网站动漫| 欧美不卡一区二区三区| 杨幂被视频在线观看| 国产精品久AAAAA片|