linux 啟動全接觸(轉)
linux 啟動全接觸(轉)[@more@]關於Windows啟動過程介紹的文章可謂多如牛毛,而對於Linux的介紹卻是鳳毛麟角。凡是曾經使用過Linux的使用者可能都會注意到,當計算機啟動時,螢幕上會出現很多資訊。一般情況下,這些資訊我們可以透過以下的命令看到:cat /var/log/dmesg | more這些資訊究竟有什麼含義?這個問題看起來似乎很容易回答,因為只要在Linux參考書裡查詢一下,就會找出一個類似於這樣的答案:“這是一些核心啟動資訊……”。但是“核心啟動資訊”到底是什麼意思呢?要想對Linux內部工作有所瞭解,就必須要對Linux核心的體系結構有一個全面的瞭解。下面我們就去揭開它的秘密。在此,我不想解釋Linux核心的體系結構,只想解釋(或者說是試圖去解釋)計算機系統啟動程式中一些最基本的概念。這裡所說的啟動過程是指從按下開關到提示符出現的整個過程。啟動指的是什麼在作業系統的詞彙裡,啟動是指透過處理器執行一些指令,把作業系統的一部分放入到主存中。在啟動過程中,Linux內部的資料結構會被初始化,會被賦給一些初始值,並且某些程式會被建立。因為當計算機電源開啟時,所有的硬體裝置都處於一種不可預知的狀態,記憶體也處於一種不活動的隨機狀態,所以,計算機的啟動過程可以說是一個長且複雜的任務。因此,我們必須知道,之所以叫“啟動”主要是因為計算機體系結構的原因。在此提請讀者注意:1.對計算機內部的工作和核心的操作有一個基本的瞭解,對自己非常有益。2.這篇文章中提到的所有檔案,指的都是Linux核心2.4.2-2版本里的檔案。這些檔案對於所有的Linux核心來說都是相同的,並且可以在任何一個Linux系統裡找到它們,此處我使用的是Red Hat 7.1。3.在本文裡,討論範圍限於IBM PC體系結構。BIOS及其功能當計算機開啟電源時,記憶體裡包含的是一些隨機的資料,所有的東西都沒有被初始化,作業系統也沒有被載入。開始整個啟動過程的是一個特殊的硬體電路,它觸發 CPU的Reset腳的邏輯值。然後,一些CPU的暫存器比如CS(一個分段暫存器:程式碼段暫存器,它指向含有程式指令的段),eip(在執行指令過程中,當CPU檢測到一個意外事故發生時,它會做出三種型別的判斷:錯誤、陷阱、中止,這取決於eip暫存器的值,它儲存在核心模組棧裡)就會被給定一個值。接著,實體地址為0xfffffff0的程式碼將被執行。這個地址被儲存在一個只讀儲存器(ROM)裡。BIOS(基本輸入/輸出系統)實際上是一段儲存在ROM裡的程式。它包含了一系列可以被某些作業系統呼叫,用於處理計算機各種硬體裝置的中斷驅動和低階程式。其中微軟的DOS就是這樣的一種作業系統。Linux是否使用附於計算機系統的BIOS來初始化硬體裝置?或者說,是否有其它的東西來完成同樣的任務?不過這個問題沒有那麼簡單,必須要了解一些知識。我們從80386模式開始。Intel微處理器實現地址翻譯(從邏輯地址->線性地址->實體地址)有兩種不同的途徑,分別稱作真實模式和保護模式。真實模式存在主要是為了使得處理器可以和較老的處理相相容。事實上,所有的BIOS程式都是在真實模式下執行的。但是,Linux核心是在保護模式下執行,而不是在真實模式下。因此,一旦初始化完成後,Linux就不再使用BIOS,而是完全由自己來為計算機上的所有硬體提供驅動程式(這點和DOS是不一樣的)。那麼什麼時候Linux使用保護模式?為什麼BIOS不能使用相同的模式?BIOS使用真實模式是因為其在操作過程中使用的是真實模式地址,並且在計算機剛開啟電源時,只有真實模式地址可用。一個真實模式地址由段地址和偏移地址組成,因此,相應的實體地址就為段地址×(2×8)+偏移。那麼,這是不是意味著在整個啟動過程中,Linux就從來不使用BIOS了呢?答案是否定的。在啟動階段,Linux從硬碟或者其它外部裝置載入核心時,需要使用BIOS。讓我們來看一下啟動時BIOS主要做了哪些操作:1.BIOS要對硬體進行一系列徹底的檢測。這個步驟主要是檢查系統安裝有哪些裝置,以及它們工作是否正常。通常把這個步驟叫做自檢(Power-On Self-Test,POST),這時會顯示版本及其它很多相關的硬體資訊。2.BIOS要對硬體進行初始化。這一步非常重要,因為它要保證所有的硬體裝置在IRQ(中斷請求)和I/O埠操作時都沒有衝突。等這步完成以後,它會顯示一個已經安裝的PCI裝置表。3.接著到了作業系統,BIOS將查詢一個可以引導的作業系統。這取決於BIOS的設定,它可以從軟盤、硬碟或者光碟啟動。4.一旦發現一個合法的裝置,BIOS就會把其第一扇區的內容複製到實體地址,即從0x00007c00開始的記憶體中,然後跳至剛載入的地址並執行之。到此為止,BIOS所要做的工作就全部完成了。自舉程式及其功用BIOS呼叫一個專門的程式,這個程式的任務就是把作業系統的核心調入記憶體。這個程式就叫做自舉程式(Boot Loader)。在我們繼續下面內容之前,先來看一下啟動系統的不同途徑。1.從軟盤啟動Linux從軟盤啟動時,儲存在軟盤第一扇區的指令將被載入並執行。這個指令然後就會把其餘的核心複製到記憶體中。Linux核心可以裝在1.44MB的軟盤裡,不過為了減少磁碟佔用量,它們都進行了壓縮。這個壓縮過程是在編譯時完成的,而解壓縮的過程則由自舉程式完成。從軟盤啟動Linux時,自舉程式要做的工作非常簡單。它是一個位於/usr/src/linux- 2.4.2/arch/i386/boot/bootsect.S的組合語言檔案。當我們編譯Linux核心原始碼,或者獲取一個新的核心時,這個可執行的彙編程式碼就會被放在核心程式的前端。由此可見,要製作一個可啟動的Linux軟盤其實很簡單。我們只要從磁碟的第一個扇區複製Linux核心,就可以建立一個可啟動軟盤。當BIOS載入軟盤的第一個扇區時,它實際上複製的是自舉程式。自舉程式由BIOS呼叫(跳到實體地址為0x00007c00的位置),然後執行以下的操作:(1)把自已從地址0x00007c00移動到0x00090000;(2)使用地址0x00003ff4,建立“真實模式”棧;(3)設定磁碟參數列,這裡使用的是BIOS提供的軟盤驅動程式;(4)透過呼叫BIOS程式顯示“Loading”資訊;(5)自舉程式呼叫BIOS程式來載入軟盤上核心的setup()函式,並把它放在起始地址為0x00090200的記憶體中;(6)接下來自舉程式呼叫一個BIOS程式,這個程式從軟盤載入剩餘的核心程式,並將其放入起始地址為0x00010000(所謂的低地址)或者0x00100000(所謂的高地址);(7)然後,跳轉到setup()函式。2.從硬碟啟動Linux當系統從硬碟啟動時,啟動過程又有所不同。硬碟的第一個扇區叫做MBR(Master Boot Record),其上儲存著分割槽表和一個小程式。這個程式載入儲存由作業系統的第一扇區來開始啟動。Linux是一個高度靈活且非常優秀的軟體,所以在 MBR裡,它使用一個叫做LILO的程式來代替上述的那個程式。LILO允許使用者選擇所要啟動的作業系統。一般來說,Linux是從硬碟啟動的。這就需要不同的自舉程式。在Intel系統裡,用得最多的自舉程式就是LILO。對於其它的體系結構,還存在著別的自舉程式。LILO可以安裝在MBR上(請注意:在安裝Red Hat Linux時,有一個步驟會讓使用者選擇把LILO安裝到MBR或者引導扇區)或一個活動分割槽的引導扇區上。由於LILO太大,MBR無法容納,所以它被分成兩部分。MBR(或者磁碟分割槽的引導扇區)包含有一個小的自舉程式,它被BIOS載入到起始地址為 0x00007c00的記憶體中。然後,這個小程式再把自己移到0x0009a000地址處,接著設定真實模式棧,最後載入第二部分的LILO自舉程式(請注意:真實模式棧地址範圍是0x0009b000 到 0x0009a200)。第二部分的LILO會從磁碟讀取所有可用的作業系統,並且給使用者列出,以選擇所要啟動的系統。一旦使用者選擇完成,自舉程式就會載入相應的扇區內容到記憶體中並且執行之。自舉程式被BIOS呼叫時(跳到實體地址為0x00007c00處),要執行以下操作:(1)把自已從地址0x00007c00移動到0x00090000;(2)使用地址0x00003ff4,建立“真實模式”棧;(3)設定磁碟參數列。這裡使用的是BIOS提供的軟盤驅動程式;(4)透過呼叫BIOS程式顯示“Loading Linux”資訊;(5)自舉程式呼叫BIOS程式來載入軟盤上核心的setup()函式,並把它放在起始地址為0x00090200的記憶體中;(6)接下來自舉程式呼叫一個BIOS程式,這個程式從軟盤載入剩餘的核心程式,並將其放入起始地址為0x00010000或者0x00100000;(7)然後,跳轉到setup()函式。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8225414/viewspace-938988/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 動態生成select選項全接觸 (轉)
- 托盤程式設計全接觸(轉)程式設計
- 托盤程式設計全接觸 (轉)程式設計
- 入侵檢測術語全接觸(轉)
- 動態生成select選項全接觸
- 全接觸SQLServer異常與孤立事務! (轉)SQLServer
- MicrosoftSecurityEssentials測試版全接觸ROS
- html5全接觸(一)HTML
- 作業系統全接觸之UNIX系統(轉)作業系統
- 交換機配置全接觸――技術專家與您同步(轉)
- XML相關知識全接觸(一)XML
- IT質量我保障——IT測試全接觸
- docker 及 linux 初接觸DockerLinux
- 全面接觸SQL語法(轉)SQL
- 接觸postgresqlSQL
- 巨人網路啟動無接觸招聘:不出家門,遠端入職
- MVVM初接觸MVVM
- WebSocket初接觸Web
- 初次接觸 CookieCookie
- SCSS初接觸CSS
- 駭客初步接觸之網站的入侵(轉)網站
- linux啟動項(轉)Linux
- 微軟Windows 7 RC十大創新特性全接觸微軟Windows
- 初次接觸express框架Express框架
- 一、初次接觸javaJava
- ITextSharp 初次接觸
- 個人計算機使用者隱私保護全接觸(1)計算機
- 駭客零接觸(第二章 入侵之IPC$)(轉)
- iris 的 websocket 初始接觸Web
- 接觸el-admin
- MyBatis TypeHandler的初次接觸MyBatis
- 再次接觸物件導向物件
- 剛接觸JAVA 問問Java
- 再次接觸tts的特性TTS
- Linux的啟動過程(轉)Linux
- 在Windows下啟動Linux(轉)WindowsLinux
- Microsoft .Net Remoting系列專題之三:Remoting事件處理全接觸ROSREM事件
- PL/SQL程式設計接觸SQL程式設計