【我所認知的BIOS】—>實模式&保護模式

本文探讨了BIOS中的实模式(real mode)和保护模式(protect mode)的内存访问,强调了段的概念和作用。在实模式下,内存访问通过segment:offset方式,而保护模式则涉及复杂的地址转换,包括分段和分页管理。文章通过实例解释了段基地址、段界限和段属性,并介绍了全局描述符表(GDT)和段选择子在内存访问中的角色。
摘要由CSDN通过智能技术生成

【我所認知的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內存的目的,但如果程式本身執行的環境是DOSBIOS的話,打開protected mode反而會造成麻煩例如無法呼叫原來real mode呼叫的一些routines,或是必須頻頻在兩個mode下切換! 要談清楚地把Big Real Mode說明的話,我想protect mode是必修課。(筆者:如果不深究爲什麽會出來Big Real Mode,不瞭解protect mode也是可以做到的。)

1物理地址

CPU要訪問內存必須要通過時,要給出內存單元的地址。所有的內存單元組成在一起是一個呈線性的空間。每個空間裏面存儲著我們的數據,而且這每一個空間都有一個唯一的地址,我們將這個唯一的地址就稱為物理地址。(筆者:這段話主要是參考《匯編語言》王爽老師著)

2、實模式(real mode)下訪問內存

2.1 訪問實例

在實模式下,我們訪問內存是通過segmentoffset找到內存的。舉個例子:如果我們訪問的內存是 D000H0FC0H處的內存,那麼我們實際訪問到的物理地址是(D000H*16+0FC0H)處內存。為了說明清楚問題,見圖1

 

1 實模式下訪問內存截圖

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值