計算機(jī)探秘(二)——計算機(jī)啟動過程

前一篇文章描述了Intel x86計算機(jī)主板和內(nèi)存映射圖蕊玷,現(xiàn)在我們來解說一下計算機(jī)啟動的幾個階段氓英。下面是一個簡單圖表馋吗。

計算機(jī)啟動過程

按下電源按鈕后計算機(jī)開始啟動,主板加電以后它開始初始化自己的固件胯府,固件是一些固化在芯片組上面的程序介衔,它會試圖去啟動CPU。如果這一步失敗了(例如CPU壞了或者沒插好)盟劫,你的計算機(jī)會死機(jī)并且給出錯誤信息(但是風(fēng)扇會一直轉(zhuǎn))。有些版本的主板固件還會發(fā)出蜂鳴警告与纽。這種狀態(tài)被稱為“zombie-with-fans”侣签。注意有時候USB或者其他設(shè)備也有可能導(dǎo)致這種結(jié)果,調(diào)試的時候最好拔掉所有非必要可能導(dǎo)致問題的外設(shè)急迂。

那么如果沒問題的話CPU就開始加電工作了影所,在多CPU或者多核CPU情況下,某一個CPU會被隨機(jī)抽選到作為啟動CPU(bootstrap processor僚碎,BSP)運(yùn)行BIOS和內(nèi)核初始化部分的代碼猴娩。其余的CPU(被稱作application processor,AP)勺阐,會保持停機(jī)狀態(tài)直到操作系統(tǒng)內(nèi)核顯式地使用它們卷中。

CPU啟動之后首先進(jìn)入的是實模式,這種模式下CPU處理的是物理內(nèi)存地址渊抽,也就是說MMU沒有開啟分頁功能蟆豫,而且最多只能訪問1MB的內(nèi)存。

不過這時候絕大多數(shù)的CPU寄存器已經(jīng)能夠正常使用了懒闷,其中EIP寄存器是指向CPU要執(zhí)行的指令內(nèi)存地址的寄存器十减。啟動之后,Intel CPU會有一個特殊的行為愤估,那就是對EIP的初始值加一個基寄存器的值帮辟,讓CPU跳轉(zhuǎn)到0xFFFFFFF0這個地址執(zhí)行那里的第一條指令。之所以稱之特殊行為是因為這個地址其實大于實模式下1MB的內(nèi)存限制玩焰。0xFFFFFFF0這個地址也因此被稱為重置向量(reset vector)由驹。

接下來主板上的固件會保證位于重置向量處的指令是一條jump指令,該指令清空了加在EIP上的基寄存器的值昔园,讓CPU繼續(xù)跳轉(zhuǎn)到BIOS代碼的開始處(物理地址0xF0000)開始執(zhí)行BIOS荔棉。這里讓我們來回顧一下內(nèi)存映射理解整個過程,見圖蒿赢。

物理內(nèi)存映射圖

接下來CPU就開始執(zhí)行BIOS里面的指令了润樱,包括初始化一些硬件和加電自檢(POST)。如果找不到內(nèi)存或者鍵盤都有可能讓BIOS停止工作并且打印一些相關(guān)的錯誤信息羡棵,如果找不到顯卡BIOS會發(fā)出蜂鳴警告(因為此時無法顯示畫面)壹若。

現(xiàn)代BIOS往往會遵循高級配置電源接口(Advanced Configuration Power Interface,ACPI)來在內(nèi)存中設(shè)置好一系列的數(shù)據(jù)來描述硬件信息,以便被操作系統(tǒng)內(nèi)核利用店展。

自檢以后BIOS會試圖加載操作系統(tǒng)养篓,它會從硬盤,光驅(qū)赂蕴,軟驅(qū)柳弄,網(wǎng)絡(luò)等幾個地方依次尋找操作系統(tǒng)(優(yōu)先級往往可在BIOS內(nèi)設(shè)定)。如果找不到操作系統(tǒng)概说,BIOS也會停機(jī)并給出錯誤信息碧注。

這里我們假設(shè)BIOS在硬盤上找到了操作系統(tǒng),它會首先讀取該硬盤上的大小為512KB的0號扇區(qū)糖赔,這個扇區(qū)被稱作主引導(dǎo)記錄(Master Boot Record萍丐,MBR),它往往包含著兩個重要的部分:第一放典,一小段幫助操作系統(tǒng)啟動的代碼逝变;第二,與磁盤上具體文件系統(tǒng)相關(guān)的磁盤分區(qū)表奋构。下面是一張圖片幫助大家理解MBR的結(jié)構(gòu)壳影。BIOS讀取完磁盤上的MBR之后會把它拷貝到內(nèi)存地址0x7c00這個地方,然后跳轉(zhuǎn)到該內(nèi)存地址執(zhí)行MBR里面的指令弥臼。

MBR的結(jié)構(gòu)

MBR里面有什么指令呢态贤?Windows操作系統(tǒng)里面是Windows啟動器,Linux的話可能是LILO或者GRUB啟動器醋火。而MBR的磁盤分區(qū)表部分則是四個16字節(jié)的結(jié)構(gòu)悠汽,描述了磁盤是如何分區(qū)的(這樣你就可以在同一磁盤的不同分區(qū)上安裝不同的操作系統(tǒng))。所以采用了MBR格式分區(qū)表的文件系統(tǒng)最多能安裝四個操作系統(tǒng)芥驳。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末柿冲,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子兆旬,更是在濱河造成了極大的恐慌假抄,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件丽猬,死亡現(xiàn)場離奇詭異宿饱,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)脚祟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門谬以,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人由桌,你說我怎么就攤上這事为黎∮史幔” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵铭乾,是天一觀的道長剪廉。 經(jīng)常有香客問我,道長炕檩,這世上最難降的妖魔是什么斗蒋? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮笛质,結(jié)果婚禮上泉沾,老公的妹妹穿的比我還像新娘。我一直安慰自己经瓷,他們只是感情好爆哑,可當(dāng)我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布洞难。 她就那樣靜靜地躺著舆吮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪队贱。 梳的紋絲不亂的頭發(fā)上色冀,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天,我揣著相機(jī)與錄音柱嫌,去河邊找鬼锋恬。 笑死,一個胖子當(dāng)著我的面吹牛编丘,可吹牛的內(nèi)容都是我干的与学。 我是一名探鬼主播,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼嘉抓,長吁一口氣:“原來是場噩夢啊……” “哼索守!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起抑片,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤卵佛,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后敞斋,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體截汪,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年植捎,在試婚紗的時候發(fā)現(xiàn)自己被綠了衙解。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡焰枢,死狀恐怖丢郊,靈堂內(nèi)的尸體忽然破棺而出盔沫,到底是詐尸還是另有隱情,我是刑警寧澤枫匾,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布架诞,位于F島的核電站,受9級特大地震影響干茉,放射性物質(zhì)發(fā)生泄漏谴忧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一角虫、第九天 我趴在偏房一處隱蔽的房頂上張望沾谓。 院中可真熱鬧,春花似錦戳鹅、人聲如沸均驶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽妇穴。三九已至,卻和暖如春隶债,著一層夾襖步出監(jiān)牢的瞬間腾它,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工死讹, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留瞒滴,地道東北人。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓赞警,卻偏偏與公主長得像妓忍,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子愧旦,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 8086匯編 本筆記是筆者觀看小甲魚老師(魚C論壇)《零基礎(chǔ)入門學(xué)習(xí)匯編語言》系列視頻的筆記凌停,在此感謝他和像他一樣...
    Gibbs基閱讀 37,218評論 8 114
  • 轉(zhuǎn)載聲明:本文雖然不是本人100%原創(chuàng)粱年,但也是辛辛苦苦整理的,可以轉(zhuǎn)載罚拟,但請注明出處 這篇文章是關(guān)于折騰Windo...
    SOMCENT閱讀 8,026評論 3 37
  • 理論部分 鏡像 一台诗、鏡像的百科定義 1完箩、維基百科 ISO映像是一種光盤的存檔文件(英語:archive file)...
    幻影翔閱讀 1,918評論 4 3
  • 不關(guān)我事弊知,是大腦潛意識做出消極反抗,指使夢魘肆意謀亂粱快,不語不言秩彤,已是夜半。 半清半迷事哭,怎知腦子無意被半截夢劃傷漫雷,醒...
    太陽跑了閱讀 219評論 0 0
  • 繞了一圈 我的生命中還剩下什么 七年若是一周期 新的我又將發(fā)生怎樣的故事 繞了一圈 我改變了軌道
    無墨書生閱讀 258評論 0 0