【我所認知的BIOS】—>實模式&保護模式
LightSeed
2009-6-17
回顧一下blog里的第一篇文章【我所認知的BIOS】—>ADU.EXE,
http://blog.csdn.net/lightseed/archive/2009/05/26/4216113.aspx
在這篇文章我有提到關於Memory的訪問,在ADU中有關於“real mode”和“Flat mode”兩種形式去訪問內存。那麼這張起我就來談談我對實模式(real mode)和保護模式(protect mode)的理解。(筆者:主要把訪問內存的方式作為切入點。)不過爲什麽要說說這兩個模式,我在這裡就先提一下。BIOS code大部分都是在real mode下寫的,但當有需求存取1MB以上的memory時(其實經常會遇到),big real mode(下一節介紹)是個不錯的選擇。雖然我們熟悉的protected mode也可以達成存取4GB內存的目的,但如果程式本身執行的環境是DOS或BIOS的話,打開protected mode反而會造成麻煩。例如無法呼叫原來在real mode下呼叫的一些routines,或是必須頻頻在兩個mode下切換! 要談清楚地把Big Real Mode說明的話,我想protect mode是必修課。(筆者:如果不深究爲什麽會出來Big Real Mode,不瞭解protect mode也是可以做到的。)
1、物理地址
CPU要訪問內存必須要通過時,要給出內存單元的地址。所有的內存單元組成在一起是一個呈線性的空間。每個空間裏面存儲著我們的數據,而且這每一個空間都有一個唯一的地址,我們將這個唯一的地址就稱為物理地址。(筆者:這段話主要是參考《匯編語言》王爽老師著)
2、實模式(real mode)下訪問內存
2.1 訪問實例
在實模式下,我們訪問內存是通過segment:offset找到內存的。舉個例子:如果我們訪問的內存是 D000H:0FC0H處的內存,那麼我們實際訪問到的物理地址是(D000H*16+0FC0H)處內存。為了說明清楚問題,見圖1:
圖1 實模式下訪問內存截圖