內(nèi)中斷
任何一個(gè)通用的CPU,比如8086,都具備一種能力,可以在執(zhí)行完當(dāng)前正在執(zhí)行的指令之后,檢測(cè)到從CPU外部發(fā)送過(guò)來(lái)的或內(nèi)部產(chǎn)生的一種特殊信息,并且可以立即對(duì)所接收到信息進(jìn)行處理。這種特殊的信息,我們可以稱其為:中斷信息。
中斷的意思是指,CPU不再接著(剛執(zhí)行完的指令)向下執(zhí)行,而是轉(zhuǎn)去處理這個(gè)特殊信息。
注意,這里所說(shuō)的中斷信息,是為了便于理解而采用的一種邏輯上的說(shuō)法。它是對(duì)幾個(gè)具有先后順序的硬件操作所產(chǎn)生的事件的統(tǒng)一描述。
“中斷信息”是要求CPU馬上進(jìn)行某種處理,并向所要進(jìn)行的該種處理提供了必備的參數(shù)的通知信息。
中斷信息可以來(lái)自CPU的內(nèi)部和外部。
內(nèi)中斷的產(chǎn)生
對(duì)于8086CPU,當(dāng)CPU內(nèi)部有下面的情況發(fā)生的時(shí)候,將產(chǎn)生相應(yīng)的中斷信息:
1) 除法錯(cuò)誤,比如:執(zhí)行div指令產(chǎn)生的除法溢出;
2) 單步執(zhí)行;
3) 執(zhí)行int0指令;
4) 執(zhí)行int指令。
8086CPU用稱為中斷類型碼的數(shù)據(jù)來(lái)標(biāo)識(shí)中斷信息的來(lái)源。中斷類型碼為一個(gè)字節(jié)數(shù)據(jù),可以表示256種中斷信息的來(lái)源。以后,我們將產(chǎn)生中斷信息的事件,即中斷信息的來(lái)源,簡(jiǎn)稱為中斷源,上述的4種中斷源,在8086CPU中的中斷類型碼如下:
1) 除法錯(cuò)誤:0
2) 單步執(zhí)行:1
3) 執(zhí)行int0指令:4
4) 執(zhí)行int指令,該指令的格式為int n,指令中的n為字節(jié)型立即數(shù),是提供給CPU的中斷類型碼。
中斷處理程序
CPU收到中斷信息后,需要對(duì)中斷信息進(jìn)行處理。
而如何對(duì)中斷信息進(jìn)行處理,可以由我們編程決定。
我們編寫(xiě)的,用來(lái)處理中斷信息的程序被稱為中斷處理程序。
一般來(lái)說(shuō),需要對(duì)不同的中斷信息編寫(xiě)不同的處理程序。
CPU在收到中斷信息后,應(yīng)該轉(zhuǎn)去執(zhí)行該中斷信息的處理程序。
若要8086CPU執(zhí)行某處的程序,就要將CS:IP指向它的入口(即程序第一條指令的地址)。
可見(jiàn)首要的問(wèn)題是,CPU在收到中斷信息后,如何根據(jù)中斷信息確定其處理程序的入口。
CPU的設(shè)計(jì)者必須在中斷信息和其處理程序的入口地址之間建立某種聯(lián)系,使得CPU根據(jù)中斷信息可以找到要執(zhí)行的處理程序。
中斷信息中包含有標(biāo)識(shí)中斷源的類型碼。根據(jù)CPU的設(shè)計(jì),中斷類型碼的作用就是用來(lái)定位中斷處理程序。
若要定位中斷處理程序,需要知道它的段地址和偏移地址,而如何根據(jù)8位的中斷類型碼得到中斷處理程序的段地址和偏移地址呢?
中斷向量表
CPU用8位的中斷類型碼通過(guò)中斷向量表找到相應(yīng)的中斷處理程序的入口地址。
中斷向量表就是中斷向量的列表,中斷向量,就是中斷處理程序的入口地址。
中斷向量表,就是中斷處理程序入口地址的列表。
中斷向量表在內(nèi)存中保存,其中存放著256個(gè)中斷源所對(duì)應(yīng)的中斷處理程序的入口。
CPU只要知道了中斷類型碼,就可以將中斷類型碼作為中斷向量表的表項(xiàng)號(hào),定位相應(yīng)的表項(xiàng),從而得到中斷處理程序的入口地址。
中斷向量表在內(nèi)存中存放,對(duì)于8086PC機(jī),中斷向量表指定放在內(nèi)存地址0處。從內(nèi)存0000:0000到0000:03e8的1000個(gè)單元中存放著中斷向量表。這是規(guī)定。
一個(gè)表項(xiàng)存放一個(gè)中斷向量,也就是一個(gè)中斷處理程序的入口地址,對(duì)于8086CPU,這個(gè)入口地址包括段地址和偏移地址,所以一個(gè)表項(xiàng)占兩個(gè)字,四個(gè)字節(jié),高地址字存放段地址,低地址字存放偏移地址。
存儲(chǔ)N號(hào)中斷源對(duì)應(yīng)的中斷處理程序入口的偏移地址的內(nèi)存單元的地址為:N*4;
存儲(chǔ)N號(hào)中斷源對(duì)應(yīng)的中斷處理程序入口的段地址的內(nèi)存單元的地址為:N*4+2。
(N從0開(kāi)始。)
中斷過(guò)程
可以用中斷類型碼,在中斷向量表中找到中斷處理程序的入口。
找到這個(gè)入口地址的最終目的是用它設(shè)置CS和IP,使CPU執(zhí)行中斷處理程序。
用中斷類型碼找到中斷向量,并用它設(shè)置CS和IP,這個(gè)工作是由CPU的硬件自動(dòng)完成的。
CPU硬件完成這個(gè)工作的過(guò)得被稱為中斷過(guò)程。
CPU收到中斷信息后,要對(duì)中斷信息進(jìn)行處理,首先將引發(fā)中斷過(guò)程。硬件在完成中斷過(guò)程后,CS:IP將指向中斷處理程序的入口,CPU開(kāi)始執(zhí)行中斷處理程序。
8086CPU在收到中斷信息后,所引發(fā)的中斷過(guò)程:
1)(從中斷信息中)取得中斷類型碼;
2)標(biāo)志寄存器的值入棧;(因?yàn)樵谥袛噙^(guò)程中要改變標(biāo)志寄存器的值,所以先將其保存在棧中。)
3)設(shè)置標(biāo)志寄存器的第8位TF和第9位IF的值為0;
4)CS的內(nèi)容入棧;
5)IP的內(nèi)容入棧;
6)從內(nèi)存地址為中斷類型碼*4和中斷類型碼*4+2的兩個(gè)字單元中讀取中斷處理程序的入口地址設(shè)置IP和CS。
CPU在收到中斷信息之后,到處理該中斷信息,就完成一個(gè)由硬件自動(dòng)執(zhí)行的中斷過(guò)程(程序員無(wú)法改變這個(gè)過(guò)程中所要做的工作)。
中斷過(guò)程的主要任務(wù)就是用中斷類型碼在中斷向量表中找到中斷處理程序的入口地址,設(shè)置CS和IP。
因?yàn)橹袛嗵幚沓绦驁?zhí)行完成后,CPU還要回過(guò)頭來(lái)繼續(xù)執(zhí)行被中斷的程序,所以要在設(shè)置CS、IP之前,先將它們的值保存起來(lái)。
因?yàn)樵趫?zhí)行中斷處理程序后,需要恢復(fù)在進(jìn)入中斷處理程序之前的CPU現(xiàn)場(chǎng)(某一時(shí)刻,CPU中各個(gè)寄存器的值)。所以應(yīng)該在修改標(biāo)記寄存器之前,將它的值入棧保存。
我們更簡(jiǎn)潔地描述中斷過(guò)程,如下:
1) 取得中斷類型碼N;
2) pushf
3) TF=0,IF=0
4) push CS
5) push IP
6) (IP)=(N*4), (CS)=(N*4+2)
在最后一步完成后,CPU開(kāi)始執(zhí)行由程序員編寫(xiě)的中斷處理程序。
中斷處理程序
由于CPU隨時(shí)隨地可能檢測(cè)到中斷信息,也就是說(shuō),CPU隨時(shí)隨地可能執(zhí)行中斷處理程序,所以中斷處理程序必須一直存儲(chǔ)在內(nèi)存某段究竟之中。而中斷處理程序的入口地址,即中斷向量,處理存儲(chǔ)在對(duì)應(yīng)的中斷向量表表項(xiàng)中。
中斷處理程序的編寫(xiě)方法和子程序的比較相似,常規(guī)步驟如下:
1) 保存用到的寄存器。
2) 處理中斷。
3) 恢復(fù)用到的寄存器。
4) 用iret指令返回。
iret指令的功能用匯編語(yǔ)法描述為:
pop IP
pop CS
popf
iret通常和硬件自動(dòng)完成的中斷過(guò)程配合使用。
iret指令執(zhí)行后,CPU回到執(zhí)行中斷處理程序前的執(zhí)行點(diǎn)繼續(xù)執(zhí)行程序。
除法錯(cuò)誤中斷的處理
當(dāng)CPU執(zhí)行div等除法指令的時(shí)候,如果發(fā)生了除法溢出錯(cuò)誤,將產(chǎn)生中斷類型碼為0的中斷信息,CPU將檢測(cè)到這個(gè)信息,然后引發(fā)中斷過(guò)程,轉(zhuǎn)去執(zhí)行0號(hào)中斷所對(duì)應(yīng)的中斷處理程序。
mov ax,1000h
mov bh,1
div bh
編程處理0號(hào)中斷
編程:當(dāng)發(fā)生除法溢出時(shí),在屏幕中間顯示“overflow!”,返回DOS。
分析:
(1)當(dāng)發(fā)生除法溢出的時(shí)候,產(chǎn)生0號(hào)中斷信息,從而引發(fā)中斷過(guò)程。
此時(shí),CPU將進(jìn)行以下工作:
1)取得中斷類型碼0;
2)標(biāo)志寄存器入棧,TF、IF設(shè)置為0;
3)CS、IP入棧;
4)(IP)=(0*4), (CS)=(0*4+2)。
(2)可見(jiàn),當(dāng)中斷0發(fā)生時(shí),CPU將轉(zhuǎn)去執(zhí)行中斷處理程序。
只要按如下步驟編寫(xiě)中斷處理程序,當(dāng)中斷0發(fā)生時(shí),即可顯示“overflow!”。
1)相關(guān)處理。
2)向顯示緩沖區(qū)送字符串“overflow!”。
3)返回DOS。
我們將這段程序稱為:do0。
(3)現(xiàn)在的問(wèn)題是:do0應(yīng)存放在內(nèi)存中。因?yàn)槌ㄒ绯鲭S時(shí)可能發(fā)生,CPU隨時(shí)都可能將CS:IP指向do0的入口,執(zhí)行程序。
那么do0應(yīng)該放在哪里呢?
由于我們是在操作系統(tǒng)之上使用計(jì)算機(jī),所有的硬件資源都在操作系統(tǒng)的管理之下,所以我們要想得到一塊內(nèi)存區(qū)存放do0,應(yīng)該向操作系統(tǒng)申請(qǐng)。
n 但在這里出于兩個(gè)原因我們不想這樣做:
n 過(guò)多地討論申請(qǐng)內(nèi)存將偏離問(wèn)題的主線;
我們學(xué)習(xí)匯編的一個(gè)重要目的就是要獲得對(duì)計(jì)算機(jī)底層的編程體驗(yàn)。所以,在可能的情況下,我們不去理會(huì)操作系統(tǒng),而直接面向硬件資源。
問(wèn)題變得簡(jiǎn)單而直接,我們只需找到一塊別的程序不會(huì)用到的內(nèi)存區(qū),將do0傳送到其中即可。
內(nèi)存0000:0000~0000:03E8,大小約1KB的空間是系統(tǒng)存放中斷處理程序入口地址的中斷向量表。8086支持256個(gè)中斷,但是,實(shí)際上,系統(tǒng)中要處理的中斷事件遠(yuǎn)沒(méi)有達(dá)到256個(gè)。所以在中斷向量表中,有許多單元是空的。
中斷向量表是PC系統(tǒng)中最重要的內(nèi)存區(qū),只用來(lái)存放中斷處理程序的入口地址,DOS系統(tǒng)和其他應(yīng)用程序都不會(huì)隨便使用這段空間。我們可以利用中斷向量表中的空閑單元來(lái)存放我們的程序。一般情況下,從0000:0200至0000:0300的256個(gè)字節(jié)。
結(jié)論:我們可以將do0傳送到內(nèi)存0000:0200處。
(4)我們將中斷處理程序do0放到0000:0200后,若要使得除法溢出發(fā)生的時(shí)候,CPU轉(zhuǎn)去執(zhí)行do0,則必須將do0的入口地址,即0000:0200登記在中斷向量表的對(duì)慶表項(xiàng)中。因?yàn)槌ㄒ绯鰧?duì)應(yīng)的中斷類型碼為0,它的中斷處理程序的入口地址應(yīng)該從0×4字單元開(kāi)始存放,段地址存放在0×4+2字單元中,偏移地址存放在0×4字單元中。也就是說(shuō)要將do0的段地址0存放在0000:0002字單元中,將偏移地址200H存放在0000:0000字單元中。
總結(jié)上面的分析,我們要做以下幾件事情:
(1)編寫(xiě)可以顯示“overflow!”的中斷處理程序:do0;
(2)將do0送入內(nèi)存0000:0200處;
(3)將do0的入口地址0000:0200存儲(chǔ)在中斷向量表0號(hào)表項(xiàng)中。
程序的框架如下:
assume cs:code
code segment
start: do0安裝程序
設(shè)置中斷向量表
mov ax,4c00h
int 21h
do0: 顯示字符串“overflow!”
mov ax,4c00h
int 21h
code ends
end start
上面的程序分為兩部分:
(1)安裝do0,設(shè)置中斷向量的程序;
(2)do0。
do0的代碼是不執(zhí)行的,它只是作為do0安裝程序所要傳送的數(shù)據(jù)。
首先執(zhí)行do0安裝程序,將do0的代碼拷貝到內(nèi)存0:200處,然后設(shè)置中斷向量表,將do0的入口地址,即偏移地址200H和段地址0,保存在0號(hào)項(xiàng)中。這兩部分工作完成后,程序就返回了。
程序的目的就是在內(nèi)存0:200處安裝do0的代碼,將0號(hào)中斷處理程序的入口地址設(shè)置為0:200。do0的代碼雖然在程序中,卻不在程序執(zhí)行的時(shí)候執(zhí)行。它是在除法溢出發(fā)生的時(shí)候才得以執(zhí)行的中斷處理程序。
do0部分代碼的最后兩條指令是依照我們的編程要求,用來(lái)返回DOS的。
現(xiàn)在,我們?cè)俜催^(guò)來(lái)從CPU的角度看一下,什么是中斷處理程序?我們來(lái)看一下do0是如何變成0號(hào)中斷的中斷處理程序的:
(1)主程序在執(zhí)行時(shí),被加載到內(nèi)存中,此時(shí)do0的代碼在程序所在的內(nèi)存空間中,它只是存放在主程序代碼段中的一段要被傳送到其他單元中的數(shù)據(jù),我們不能說(shuō)它是0號(hào)中斷的中斷處理程序;
(2)主程序中安裝do0的代碼執(zhí)行完后,do0的代碼被從主程序的代碼段中拷貝到0:200處。此時(shí),我們也不能說(shuō)它是0號(hào)中斷的中斷處理程序,它只不過(guò)是存放在0:200處的一些數(shù)據(jù);
(3)主程序中設(shè)置中斷向量表的代碼執(zhí)行完后,在0號(hào)表項(xiàng)中填入了do0的入口地址0:200,此時(shí)0:200處的信息,即do0的代碼,就變成了0號(hào)中斷的中斷處理程序。因?yàn)楫?dāng)除法溢出(即0號(hào)中斷)發(fā)生時(shí),CPU將執(zhí)行0:200處的代碼。
回憶以下:
如何讓一個(gè)內(nèi)存單元成為棧頂?將它的地址放入SS、SP中;
如何讓一個(gè)內(nèi)存單元中的信息被CPU當(dāng)作指令來(lái)執(zhí)行?將它的地址放入CS、IP中;
如何讓一段程序成為N號(hào)中斷的中斷處理程序?將它的入口地址放入中斷向量表的N號(hào)表項(xiàng)中。
安裝
使用movsb指令,將do0的代碼送入0:200處。程序如下:
assume cs:code
code segment
start: 設(shè)置es:di指向目的地址
設(shè)置ds:si指向源地址
設(shè)置cx為傳輸長(zhǎng)度
設(shè)置傳輸方向?yàn)檎?/span>
rep movsb
設(shè)置中斷向量表
mov ax,4c00h
int 21h
do0: 顯示字符串“overflow!”
mov ax,4c00h
int 21h
code ends
end start
用rep movsb指令的時(shí)候要確定的信息如下:
(1)傳送的原始位置,段地址:code,偏移地址:offset do0;
(2)傳送的目的位置:0:200;
(3)傳送的長(zhǎng)度:do0部分代碼的長(zhǎng)度;
(4)傳送的方向:正向。
更明確的程序如下:
assume cs:code
code segment
start: mov ax,cs
mov ds,ax
mov si,offset do0 ;設(shè)置ds:si指向源地址
mov ax,0
mov es,ax
mov di,200h ;設(shè)置es:di指向目的地址
mov cx do0部分代碼的長(zhǎng)度 ;設(shè)置cx為傳輸長(zhǎng)度
cld ;設(shè)置傳輸方向?yàn)檎?/span>
rep movsb
設(shè)置中斷向量表
mov ax,4c00h
int 21h
do0: 顯示字符串“overflow!”
mov ax,4c00h
int 21h
code ends
end start
如何知道do0代碼的長(zhǎng)度?
可以利用編譯器來(lái)計(jì)算do0的長(zhǎng)度,如下所示:
assume cs:code
code segment
start: mov ax,cs
mov ds,ax
mov si,offset do0 ;設(shè)置ds:si指向源地址
mov ax,0
mov es,ax
mov di,200h ;設(shè)置es:di指向目的地址
mov cx,offset do0end-offset do0 ;設(shè)置cx為傳輸長(zhǎng)度
cld ;設(shè)置傳輸方向?yàn)檎?/span>
rep movsb
設(shè)置中斷向量表
mov ax,4c00h
int 21h
do0: 顯示字符串“overflow!”
mov ax,4c00h
int 21h
do0end: nop
do0end:
code ends
end start
“-”是編譯器識(shí)別的運(yùn)算符號(hào),編譯器可以用它來(lái)進(jìn)行了兩個(gè)常數(shù)的減法。比如:
指令:mov ax,8-4,被編譯器處理為指令:mov ax,4
匯編編譯器可以處理表達(dá)式,比如:
指令:mov ax,(5+3)*5/10,被編譯器處理為指令:mov ax,4
do0
do0程序的主要任務(wù)是顯示字符串,程序如下:
do0: 設(shè)置ds:si指向字符串
mov ax,0b800h
mov es,ax
mov di,12*150+36*2 ;設(shè)置es:di指向顯存空間的中間位置
mov cx,9 ;設(shè)置cx為字符串長(zhǎng)度
s: mov al,[si]
mov es:[di],al
inc si
add di,2
loop s
do0end:nop
mov ax,4c00h
int 21h
程序?qū)懞昧耍梢@示的字符串放在哪里呢?
assume cs:code
data:segment
db “overflow!”
data ends
code segment
start: mov ax,cs
mov ds,ax
mov si,offset do0 ;設(shè)置ds:si指向源地址
mov ax,0
mov es,ax
mov di,200h ;設(shè)置es:di指向目的地址
mov cx, offset do0end-offset do0 ;設(shè)置cx為傳輸長(zhǎng)度
cld ;設(shè)置傳輸方向?yàn)檎?/span>
rep movsb
設(shè)置中斷向量表
mov 4c00h
int 21h
do0: mov ax,data
mov ds,ax
mov si,0 ;設(shè)置ds:si指向字符串
mov ax,0b800h
mov es,ax
mov di,12*160+36*2 ;設(shè)置es:di指向顯存空間中的中間位置
mov cx,9 設(shè)置cx為字符串長(zhǎng)度
s: mov al,[si]
move s:[di],al
inc si
add di,2
loop s
mov ax,4c00h
int 21h
do0end:nop
code ends
end start
上述程序有一處大錯(cuò),注意字符串“overflow!”,是在data段中。程序執(zhí)行完成后返回,它所占用的內(nèi)存空間被系統(tǒng)釋放,而在其中存放的“overflow!”也將很可能被別的信息覆蓋。
而do0程序被放到了0:200處,隨時(shí)都會(huì)因發(fā)生了除法溢出而被CPU執(zhí)行,很難保證do0程序從原來(lái)程序所處的空間中取得的是要顯示的字符串“overflow”。
因?yàn)?/span>do0程序隨時(shí)可能被執(zhí)行,而它要用到字符串“overflow”,所以該字符串也應(yīng)該放在一段不會(huì)被覆蓋的空間中。正確的程序如下:
assume cs:code
code segment
start: mov ax,cs
mov ds,ax
mov si,offset do0 ;設(shè)置ds:si指向源地址
mov ax,0
move s,ax
mov di,200h ;設(shè)置es:di指向目的地址
mov cx,offset do0end-offset do0 ;設(shè)置cx為傳輸長(zhǎng)度
cld ;設(shè)置傳輸方向?yàn)檎?/span>
rep movsb
設(shè)置中斷向量表
mov 4c00h
int 21h
do0: jmp short do0start
db “overflow!”
do0start: mov ax,cs
mov ds,ax
mov si,202h ;設(shè)置ds:si指向字符串
mov ax,0b800h
mov es,ax
mov di,12*160+36*2 ;設(shè)置es:di指向顯存空間的中間位置
mov cx,9 ;設(shè)置cx為字符串長(zhǎng)度
s: mov al,[si]
mov es:[di],al
inc si
add di,2
loop s
mov ax,4c00h
int 21h
do0end:nop
code ends
end start
上面的程序,將字符串“overflow!”放到了do0程序中,在程序執(zhí)行時(shí),將標(biāo)號(hào)do0到標(biāo)號(hào)do0end之間的內(nèi)容送到0000:0200處。
注意,因?yàn)樵?/span>do0程序開(kāi)始處的“overflow!”不是可以執(zhí)行的代碼,所以在“overflow!”之前加上一條jmp指令,轉(zhuǎn)移到正式的do0程序,當(dāng)除法溢出發(fā)生時(shí),CPU執(zhí)行0:200處的jmp指令,路過(guò)后面的字符串,轉(zhuǎn)到正式的do0程序執(zhí)行。
do0程序執(zhí)行過(guò)程中必須要找到“overflow!”,那么它在哪里呢?首先來(lái)看段地址,”overflow!”和do0的代碼處于同一個(gè)段中,而除法溢出發(fā)生時(shí),CS中必須存放do0的段地址,也就是“overflow!”的段地址;再來(lái)偏移地址,0:200處的指令為jmp short do0start,這條指令占兩個(gè)字節(jié),所以“overflow!”的偏移地址為202h。
設(shè)置中斷向量
將do0的入口地址0:200,寫(xiě)入中斷向量表的0號(hào)表項(xiàng)中,使do0成為0號(hào)中斷的中斷處理程序。
0號(hào)表項(xiàng)的地址為0:0,其中0:0字單元存放偏移地址,0:2字單元存放段地址。程序如下:
mov ax,0
mov es,ax
mov word ptr es:[0*4],200h
mov word ptr es:[0*4+2],0
單步中斷
CPU在執(zhí)行完一條指令之后,如果檢測(cè)到標(biāo)志寄存器的TF位為1,則產(chǎn)生單步中斷,引發(fā)中斷過(guò)程。單步中斷的中斷類型碼為1,則它所引發(fā)的中斷過(guò)程如下:
(1)取得中斷類型碼1;
(2)標(biāo)志寄存器入棧,TF、IF設(shè)置為0;
(3)CS、IP入棧;
(4)(IP)=(1*4),(CS)=(1*4+2)。
如果TF=1,則執(zhí)行一條指令后,CPU就要轉(zhuǎn)去執(zhí)行1號(hào)中斷處理程序。
在進(jìn)入單步中斷處理程序之前,設(shè)置TF=0,從而避免CPU在執(zhí)行中斷處理程序的時(shí)候發(fā)生單步中斷。這就是為什么在中斷過(guò)程中有TF=0這個(gè)步驟,再來(lái)看一下中斷過(guò)程:
CPU為什么要提供這樣的功能呢?
CPU提供單步中斷功能的原因就是,為單步跟蹤程序的執(zhí)行過(guò)程,提供了實(shí)現(xiàn)機(jī)制。
響應(yīng)中斷的特殊情況
一般情況下,CPU在執(zhí)行完當(dāng)前指令后,如果檢測(cè)到中斷信息,就響應(yīng)中斷,引發(fā)中斷過(guò)程。
但是,在有些情況下,CPU在執(zhí)行完當(dāng)前執(zhí)行后,即便是發(fā)生中斷,也不會(huì)響應(yīng)。比如:
在執(zhí)行完向ss寄存器傳送數(shù)據(jù)的指令后,即便是發(fā)生中斷,CPU也不會(huì)響應(yīng)。這樣做的主要原因是,ss:sp聯(lián)合指向棧頂,而對(duì)它們的設(shè)置應(yīng)該連續(xù)完成。