?? page40.html
字號:
<html>
<head>
<meta http-equiv=Content-Type content="text/html; charset=gb2312">
<title>第3章 中斷調用與子程序</title>
</head>
<body>
<style type="text/css">
body {
background-color: #c0c0c0;
}
table {
background-color: #c0c0c0;
line-height: 24px;
}
</style>
<!導航條>
<p><a href="content1.html">目錄</a> <a href="page39.html">上一頁</a> <a href="page41.html">下一頁</a> <a href="page45.html">下一章</a></p>
<table border=0 align="center" width=800 frame="box" rules="none">
<!標尺行>
<tr>
<td width=3%></td><td width=6%></td><td width=1%></td>
<td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td>
<td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td>
<td width=1%></td><td width=6%></td><td width=3%></td>
</tr>
<!頁眉行>
<tr height=60 valign="bottom">
<td></td><td>-40-</td><td></td> <!頁碼>
<td colspan=6>PC機匯編語言實戰精解</td><td colspan=4></td><td colspan=6 align="right"><img src="icons/flag.gif"></td> <!書名>
<td></td><td></td><td></td> <!右側空白>
</tr>
<!頁眉線>
<tr valign="top">
<td></td><td colspan=20><hr></td><td></td>
</tr>
<!正文>
<font face="宋體" lang="ZH-CN" size=3>
<tr height=20><td colspan=22></td></tr> <!頂部空白>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
我們繼續使用"T"命令跟蹤RET指令:
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>-t</td><td colspan=16><font face="楷體_GB2312" size="2">注意堆棧指針SP寄存器恢復成FFFEH</font></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>AX=0161</td><td colspan=2>BX=0001</td><td colspan=2>CX=0000</td><td colspan=2>DX=6131</td><td colspan=2>SP=FFFE</td><td colspan=2>BP=0000</td><td colspan=2>SI=0000</td><td colspan=2>DI=0000</td><td colspan=2></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>DS=0A3E</td><td colspan=2>ES=0A3E</td><td colspan=2>SS=0A3E</td><td colspan=2>CS=0A3E</td><td colspan=2>IP=0107</td>
<td colspan=5>NV UP EI PL ZR NA PE CY</td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>0A3E:0107</td><td colspan=2>3C1B</td><td colspan=6 align="center">CMP AL,1B</td><td colspan=4></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2></td><td colspan=12 align="center"><font face="楷體_GB2312" size="2">可以看到CPU確實返回到0107處執行CMP指令</font></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
前面我們編寫過一些程序用RET指令返回DOS,RET為什么會有這樣的功能呢?<br>
如果在啟動DEBUG之后注意觀察SP寄存器的初值,就會發現DOS將程序調入內存執行時已事先在堆棧中放入了數據,這個數據就是:
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan="3">-dfffe</td><td colspan="10" align="center"><font face="楷體_GB2312" size=2>DOS預先存于堆棧中的返回地址</td><td colspan="5"></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan="2">0A3E:FFF0</td><td></td><td colspan="10"> 00 00</td><td></td><td colspan="4"> ..</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
當CPU執行RET指令時,這個"0"將被彈到IP寄存器中,也就是說CPU將從CS:0處繼續執行指令。那么在CS:0處有沒有指令呢?我們可以把CS:0處的指令"反匯編"出來。在"-"后打入"U0"并回車:
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>-u0[Enter]</td><td colspan=16></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>0A3E:0000</td><td colspan=3>CD20</td><td colspan=2>INT</td><td colspan=4>20</td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>0A3E:0002</td><td colspan=3>FF9F009A</td><td colspan=2>CALL</td><td colspan=4>FAR [BX+9A00]</td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>0A3E:0006</td><td colspan=3>F0</td><td colspan=2>LOCK</td><td colspan=4></td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>0A3E:0007</td><td colspan=3>FE1D</td><td colspan=2>CALL</td><td colspan=4>FAR [DI]</td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>0A3E:0009</td><td colspan=3>F0</td><td colspan=2>LOCK</td><td colspan=4></td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>0A3E:000A</td><td colspan=3>4F</td><td colspan=2>DEC</td><td colspan=4>DI</td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>0A3E:000B</td><td colspan=3>038D048A</td><td colspan=2>ADD</td><td colspan=4>CX,[DI+8A04]</td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2></td><td colspan=3></td><td colspan=2>.</td><td colspan=4></td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2></td><td colspan=3></td><td colspan=2>.</td><td colspan=4></td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2></td><td colspan=3></td><td colspan=2>.</td><td colspan=4></td><td colspan=3></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=3 align="center"><img src="icons/attention.gif"></td>
<td colspan=15><font face="楷體_GB2312">
當我們用A命令輸入指令時,這些指令都被DEBUG編譯成機器碼。我們要想通過機器碼重新獲得指令,就必須"Unassembled"(反匯編),這就是命令碼"U"的來歷。<br>
此命令可以將內存中任意位置開始的機器碼反匯編成指令,若打入"U100[Enter]",那么DEBUG將把CS:100處開始的指令顯示在屏幕上。<br>
"反"出來的指令和我們當初輸入的指令應該是相同的。那些緊挨著邏輯地址后面的16進制數就是指令編譯后的機器碼。我們可以大概了解一些常用指令對應的機器碼是什么,比如"INT"和"CD"之間的關系。<br>
</font></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
反匯編的結果真是不可思意,CS:0處竟然有一條"INT 20"指令。為什么會有這樣的一條指令呢?<br>
前面已經提到過,在我們的程序之前,DOS保留了256字節的內存空間安排了一些重要的數據,這個"CD 20"就是DOS打的小埋伏。這是因為在DOS正式成為PC機的標準操作系統之前,已有人編寫了一個稱為"CP/M-86"的操作系統,遺憾的是這個可憐的軟件沒能競爭DOS。不過
</td>
<td></td><td></td> <!右邊距>
</tr>
</font>
<!頁腳線>
<tr valign="top">
<td></td><td colspan=20><hr></td><td></td>
</tr>
<!頁腳>
<tr height=60 valign="top">
<td></td><td></td>
<td colspan=9><i>Copyright © 2004-2005 <a href="mailto:webmaster@nucstorm.com">Chunk Lee</a></i></td>
<td colspan=9 align="right"><i><a href="http://www.nucstorm.com" target="_top">www.nucstorm.com</a></i></td>
<td></td><td></td>
</tr>
</table>
<!導航條>
<p align="right"><a href="content1.html">目錄</a> <a href="page39.html">上一頁</a> <a href="page41.html">下一頁</a> <a href="page45.html">下一章</a></p>
</body>
</html>
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -