請問下計算機中的實模式和保護模式有啥區(qū)別?還有他們就是在平時電腦運用時有啥用處?

請問下計算機中的實模式和保護模式有啥區(qū)別?還有他們就是在平時電腦運用時有啥用處?

803

CPU實模式和保護模式有什么區(qū)別

80x

實模式、保護模式和虛86模式有何不同?

百科

這三種都是8086系列CPU的工作模式。實模式是最早的8086系列的CPU的工作模式,當(dāng)時CPU只有20根地址線,**能訪問的內(nèi)存只有1M,段寄存器為16位,段的長度不能超過64KB。

保護模式是80286之后出現(xiàn)的CPU工作模式,當(dāng)時的80286CPU地址線增加到24根,CPU的尋址能力增加了很多,之后又出現(xiàn)了32根地址線的CPU,尋址范圍大大加強,而且引入了段頁的內(nèi)存管理機制,使得內(nèi)存的利用率和管理,保護等得到加強。

現(xiàn)代的操作系統(tǒng)都是工作在保護模式下。虛擬8086是指在windows下,模擬8086的工作模式,在該模式下,只能訪問1M的內(nèi)存,跟8086模式是一樣的。

操作系統(tǒng)實模式和保護模式

實模式下用戶程序可以直至訪問任意內(nèi)存,存在風(fēng)險 除段寄存器外,從16位寄存器,擴展為32位 全局描述符表中,每一個表項是段描述符,大小為64字節(jié)。全局描述符表保存在內(nèi)存中,由GDTR寄存器指向它。

使用lgdt 指令初始化gtdr。

在保護模式中,段寄存器CS、DS、ES、FS、GS、SS不在存放段基址,而是存放一個選擇子,通過選擇子在GDT中找到對應(yīng)的段描述符,獲取段相關(guān)信息。 選擇子結(jié)構(gòu): 廠商為在硬件一級原生支持多任務(wù)而創(chuàng)造的表,一個任務(wù)對應(yīng)一個LDT,保存任務(wù)的私有內(nèi)存段。 每個任務(wù)都有自己的LDT,隨著任務(wù)的切換,也要切換相應(yīng)的LDT。 現(xiàn)代操作系統(tǒng)很少有用到LDT的。

在實模式下,通過 段基址 * 16 + 段內(nèi)偏移地址 尋址,實模式下寄存器都是16位,所以**尋址地址為: 0xffff:ffff 即 0xffff0 + 0xffff = 0x10ffef ,由于8086/8088的地址線是20位 (A0 ~ A19) ,**尋址空間為1MB,即 0x00000~0xfffff 。 由于沒有 A20 地址線,當(dāng) 段基址 * 16 + 段內(nèi)偏移地址 超過**尋址空間時,相當(dāng)于丟掉進位,回到低地址范圍。為兼容與8086/8088,在實模式下,后續(xù)的CPU都關(guān)閉A20地址線,實現(xiàn)地址回繞。