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