实模式寻址方式
邏輯地址:即邏輯上的地址,實模式下由“段基地址+段內偏移”組成;保護模式下由“段選擇符+段內偏移”組成。
線性地址:邏輯地址經分段機制后就成線性地址,它是平坦的;如果不啟用分頁,那么此線性地址即物理地址。
物理地址:線性地址經分頁轉換后就成了物理地址。
實模式尋址方式
??? 剛才說了8086CPU數據總線為16位,也就是一次最多能取2^16=64KB數據,這個數據也解釋了實模式下為什么每個段最大只有64KB。但剛才還說了其地址總線為20位,這樣它能尋址的能力其實是2^20=1MB,這也就是實模式下CPU的最大尋址能力。既然它有1MB尋址能力,那怎么用16位的段寄存器表示呢?
??? 這就引出了分段的概念,8086CPU將1MB存儲空間分成許多邏輯段,每個段最大限長為64KB(但不一定就是64KB)。這樣每個存儲單元就可以用“段基地址+段內偏移地址”表示。段基地址由16位段寄存器值左移4位表達,段內偏移表示相對于某個段起始位置的偏移量。比如:
SEG=0x07c0
jmpi?offset,?#SEG
offset:?mov?ax,cs
實模式下的尋址舉例:
先找到CS代碼段的地址
mov ax,cs
然后把段地址乘以16,即將16位變成20位。這時因為8086的數據總線是16位的,但是地址總線是20位的。實現方法很簡單,左移4位即可。
shl eax, 4
然后根據你要尋址到的子代碼,加上其對應的偏移地址:
add eax, LABEL_SEG_CODE32
?
這樣便得到了所尋位置的物理地址。
因為地址總線只有20位,所以最大尋址空間只有1M。
8086中含有存儲器.存儲器中每一個單元的地址可以用兩種方法表示:
1.邏輯地址:其表達形式為“段地址:段內偏移地址”.
2.物理地址:CPU與存儲器進行數據交換時在地址總線上提供的20位地址信息稱為物理地址.
物理地址=段地址×10H+段內偏移量
CPU一次處理的數據是16位,地址總線實際上代表CPU的尋址能力,地址線為20條那么CPU實際的尋址能力就是2的20次方就是1M.實際的物理地址是這樣形成的:段地址*10H+偏移地址,偏移地址用IP指向,IP是16位的.
例如段地址是1234H,偏移地址是4321H
那么實際的物理地址怎么算呢:1234H*10H+4321H=12340H+4321H=16661H
實際上可以這么來理解,就是段地址左移一位后加上偏移地址就得出實際的物理地址.
再比如:邏輯地址:1500H先化為2進制 0001 0101 0000 0000
左移四位就是0001 0401 0000 0000 0000,即15000H
若偏移地址為1000H 則物理地址就是16000H
總結
- 上一篇: 汇编语言笔记10-CALL和RET指令
- 下一篇: 两张图看懂GDT、GDTR、LDT、LD