中國科學院大學操作系統(tǒng)考試思考題答案_第1頁
已閱讀1頁,還剩10頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、1.為什么計算機啟動最開始的時候執(zhí)行的是BIOS代碼而不是操作系統(tǒng)自身的代碼?答:通常我們用C語言寫的用戶程序,必須在操作系統(tǒng)的平臺上執(zhí)行,即操作系統(tǒng)為應用程序創(chuàng)建進程并把應用程序的可執(zhí)行代碼加載到內存。計算機啟動的時候,操作系統(tǒng)并沒有在內存中,我們首先要把操作系統(tǒng)加載到內存,而這個工作最開始的部分,就是由bios程序來實現(xiàn)的。所以計算機啟動最開始執(zhí)行的是bios代碼2.為什么BIOS只加載了一個扇區(qū),后續(xù)扇區(qū)卻是由bootsect代碼

2、加載?為什么BIOS沒有把所有需要加載的扇區(qū)都加載?答:對BIOS而言,“約定”在接到啟動操作系統(tǒng)的命令后,“定位識別”只從啟動扇區(qū)把代碼加載到0x7c00這個位置。后續(xù)扇區(qū)則由bootsect代碼加載,這些代碼由編寫系統(tǒng)的用戶負責,與BIOS無關。這樣構建的好處是站在整個體系的高度,統(tǒng)一設計和統(tǒng)一安排,簡單而有效。BIOS和操作系統(tǒng)的開發(fā)都可以遵循這一約定,靈活地進行各自的設計。例如,BIOS可以不用知道內核鏡像的大小以及其在軟盤的分

3、布等等信息,減輕了BIOS程序的復雜度,降低了硬件上的開銷。而操作系統(tǒng)的開發(fā)者也可以按照自己的意愿,內存的規(guī)劃,等等都更為靈活。另外,如果要使用BIOS進行加載,而且加載完成之后再執(zhí)行,則需要很長的時間,因此Linux采用的是邊執(zhí)行邊加載的方法。3.為什么BIOS把bootsect加載到0x07c00,而不是0x00000?加載后又馬上挪到0x90000處,是何道理?為什么不一次加載到位?答:因為BIOS首先會把中斷向量表加載到0x00

4、0000x003ff的1KB的內存空間,在加載bootsect時約定加載到0x07c00處,符合內存布局,如下。加載之后挪到0x90000處的原因如下:首先內核會使用啟動扇區(qū)中的一些數(shù)據(jù),如第508、509字節(jié)處的ROOT_DEV;其次,依據(jù)系統(tǒng)對內存的規(guī)劃,內核占用0x0000開始的空間,因此0x7c00可能會被覆蓋。因為加載到0x07c00是BIOS約定好的,操作系統(tǒng)只能遵守這個約定。4.bootsect、setup、head程序之

5、間是怎么銜接的?給出代碼證據(jù)。答:bootsect首先利用int0x13中斷分別加載setup程序及system模塊,待行,需要借助BIOS分別加載bootsect、setup及system模塊,然后利用這3個程序來完成內存規(guī)劃、建立IDT和GDT、設置分頁機制等等,并實現(xiàn)從開機時的16位實模式到main函數(shù)執(zhí)行需要的32位保護模式之間的轉換。當計算機處在32位的保護模式狀態(tài)下時,調用main的條件才算準備完畢。9.為什么不用call,

6、而是用ret“調用”main函數(shù)?畫出調用路線圖,給出代碼證據(jù)。答:CALL指令會將EIP的值自動壓棧,保護返回現(xiàn)場,然后執(zhí)行被調函數(shù),檔執(zhí)行到被調函數(shù)的ret指令時,自動出棧給EIP并還原現(xiàn)場,繼續(xù)執(zhí)行CALL的下一行指令。在由head程序向main函數(shù)跳轉時,是不需要main函數(shù)返回的;同時由于main函數(shù)已經是最底層的函數(shù)了,沒有更底層的支撐函數(shù)支持其返回。所以要達到既調用main又不需返回,就不采用call而是選擇了ret“調用

7、”了。調用線路圖見P42圖146。代碼如下:(見P36最下面)setup_paging:…ret10.保護模式的“保護”體現(xiàn)在哪里?答:打開了保護模式后,CPU的尋址模式發(fā)生了變化,需要依賴于GDT去獲取代碼或數(shù)據(jù)段的基址。從GDT可以看出,保護模式除了段基址外,還有段限長,這樣相當于增加了一個段位寄存器。既有效地防止了對代碼或數(shù)據(jù)段的覆蓋,又防止了代碼段自身的訪問超限,明顯增強了保護作用。同時,保護模式中特權級的引入對于操作系統(tǒng)內核提

8、供了強有力的保護。Intel從硬件上禁止低特權級代碼段使用一些關鍵性指令,還提供了機會允許操作系統(tǒng)設計者通過一些特權級的設置,禁止用戶進程使用cli、sti等對掌控局面至關重要的指令。有了這些基礎,操作系統(tǒng)可以把內核設計成最高特權級,把用戶進程設計成最低特權級。這樣,操作系統(tǒng)可以訪問GDT、LDT、TR,而GDT、LDT是邏輯地址形成線性地址的關鍵,因此操作系統(tǒng)可以掌控線性地址。物理地址是由內核將線性地址轉換而成的,所以操作系統(tǒng)可以訪問

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論