微型計算機(jī)原理與接口技術(shù)(第三版)馮博琴主編-課后答案_第1頁
微型計算機(jī)原理與接口技術(shù)(第三版)馮博琴主編-課后答案_第2頁
微型計算機(jī)原理與接口技術(shù)(第三版)馮博琴主編-課后答案_第3頁
微型計算機(jī)原理與接口技術(shù)(第三版)馮博琴主編-課后答案_第4頁
微型計算機(jī)原理與接口技術(shù)(第三版)馮博琴主編-課后答案_第5頁
已閱讀5頁,還剩16頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

第1章根底知識局部

1.1計算機(jī)中常用的計數(shù)制有哪些?

解:二進(jìn)制、八進(jìn)制、十進(jìn)制(BCD)、十六進(jìn)制。

1.2什么是機(jī)器碼?什么是真值?

解:把符號數(shù)值化的數(shù)碼稱為機(jī)器數(shù)或機(jī)器碼,原來的數(shù)值叫做機(jī)器數(shù)的真值。

1.3完成以下數(shù)制的轉(zhuǎn)換。

微型計算機(jī)的根本工作原理

匯編語言程序設(shè)計

微型計算機(jī)接口技術(shù)

建立微型計算機(jī)系統(tǒng)的整體概念,形成微機(jī)系統(tǒng)軟硬件開發(fā)的初步能力。

解:

⑴166,A6H

(2)0.75

(3)U111101.01B,FD.4H

1.48位和16位二進(jìn)制數(shù)的原碼、補(bǔ)碼和反碼可表示的數(shù)的范圍分別是多少?

解:

原碼(-127~+127)、(-32767~+32767)

補(bǔ)碼(-128-+127)、(-32768-+32767)

反碼(-127-+127)、(-32767~+32767)

15寫出以下真值對應(yīng)的原碼和補(bǔ)碼的形式。

(1)X=-1110011B

(2)X=-71D

(3)X=+1001001B

解:

(1)原碼:11110011補(bǔ)碼:10001101

〔2〕原碼:11000111補(bǔ)碼:10111001

⑶原碼:01001001補(bǔ)碼:01001001

1.6寫出符號數(shù)10110101B的反碼和補(bǔ)碼。

解:11001010,11001011

1.7X和Y的真值,求[X+Y]的補(bǔ)碼。

(1)X=-11101UBY=+1011010B

(2)X=56DY=-21D

解:

⑴11100011

(2)()010()011

1.8X=-1IO1OO1B,Y=-1010110B,用補(bǔ)碼求X-Y的值。

解:11101101

L9請寫出以下字符的ASCH碼。

4A3-!

解:34H,41H,33H,3DH,21H

1.10假設(shè)給字符4和9的ASCII碼加奇校驗,應(yīng)是多少?

解:34H,B9H

111上題中假設(shè)加偶校驗,結(jié)果如何?

解:B4H,39H

1.12計算以下表達(dá)式。

(1)(4EH+10110101B)x(0.0101)BCD=()D

(2)4EH-(24/08H+'B72)=()B

解:

(1)129.5D

(2)101010B

第2章微型計算機(jī)根底

2.6簡述CPU執(zhí)行程序的過程。

解:當(dāng)程序的第一條指令所在的地址送入程序計數(shù)器后,CPU就進(jìn)入取指階段準(zhǔn)備取第一

條指令。在取指階段,CPU從內(nèi)存中讀出指令,并把指令送至指令存放器IR暫存。在取指

階段結(jié)束后,機(jī)器就進(jìn)入執(zhí)行階段,這時,由指令譯碼器對指令譯碼,再經(jīng)控制器發(fā)出相

應(yīng)的控制信號,控制各部件執(zhí)行指令所規(guī)定的具體操作。當(dāng)一條指令執(zhí)行完畢以后,就轉(zhuǎn)

入了下一條指令的取指階段。以上步驟周而復(fù)始地循環(huán),直到遇到停機(jī)指令。

2.7說明8086的EU和BIU的主要功能。在執(zhí)行程序過程中他們是如何相互配合工作的?

解:執(zhí)行單元EU負(fù)責(zé)執(zhí)行指令。EU在工作時不斷地從指令隊列取出指令代碼,對其譯碼后

產(chǎn)生完成指令所需要的控制信息。數(shù)據(jù)在ALU中進(jìn)行運算,運算結(jié)果的特征保存在標(biāo)志存

放器FLAGS中。總線接口單元BIU負(fù)責(zé)CPU與存儲器、I/O接口之間的信息傳送。BIU取出

的指令被送入指令隊列供EU執(zhí)行,BIU取出的數(shù)據(jù)被送入相關(guān)存放器中以便做進(jìn)一步的處

理。

當(dāng)EU從指令隊列中取走指令,指令隊列

出現(xiàn)空字節(jié)時,BIU就自動執(zhí)行一次取指令周期,從內(nèi)存中取出后續(xù)的指令代碼放入隊列

中。當(dāng)EU需要數(shù)據(jù)時,BIU根據(jù)EU給出的地址,從指定的內(nèi)存單元或外設(shè)中取出數(shù)據(jù)供EU

使用。當(dāng)運算結(jié)束時,BIU洛運算結(jié)果送入指定的內(nèi)存單元或存放器。當(dāng)指令隊列空時,

EU就等待,直到有指令為止。假設(shè)BIU正在取指令,EU發(fā)出訪問總線的請求,那么必須等

BIU取指令完畢后,該請求才能得到響應(yīng)。一般情況卜,程序順序執(zhí)行,當(dāng)遇到跳轉(zhuǎn)指令

時,BIU就使指令

隊列復(fù)位,從新地址取出指令,并立即傳送EU去執(zhí)行。

指令隊列的存在使8086/8088的EU和BIU并行工作,從而減少了CPU為取指令而等待的時

間,提高了CPU的利用率,加快了整機(jī)的運行速度。另外也降低了對存儲器存取速度的要

求。

2.8在執(zhí)行指令期間,BIU能直接訪問存儲器嗎?為什么?

解:可以.因為EU和BIU可以并行工作,EU需要的指令可以從指令隊列中獲得,這時BIU預(yù)先從

存儲器中取出并放入指令隊列的。在EU執(zhí)行指令的同時,BIU可以訪問存儲器取下一條指

令或指令執(zhí)行時需要的數(shù)據(jù)。

2.98086與8088CPU的主要區(qū)別有哪些?

解:主要區(qū)別有以下幾點:

①8086的外部數(shù)據(jù)總線有16位,而8088的外部數(shù)據(jù)總線只有8位。

②8086指令隊列深度為6個字節(jié),而8088的指令隊列深度為4個字節(jié).

③因為8086的外部數(shù)據(jù)總線有16位,故8086每個總線周期可以存取兩個字節(jié).而8()88的外部

數(shù)據(jù)總線因為只有8位,所以每個總線周期只能存取1個字節(jié).

④個別引腳信號的含義稍有不同.

2.108088CPU工作在最小模式下:

(1)當(dāng)CPU訪問存儲器時,要利用哪些信號?

⑵當(dāng)CPU進(jìn)行I/O操作時,要利用哪些信號?

(3)當(dāng)HOLD有效并得到響應(yīng)時,CPU的哪些信號置高阻?

解:

(1)要利用信號線包括WR#、RD#、IO/M#、ALE以及AD0~AD7、A8?A19。

(2)同⑴。

(3)所有三態(tài)輸出的地址信號、數(shù)據(jù)信號和控制信號均置為高阻態(tài)。

2.11總線周期中,什么情況下要插入TW等待周期?插入TW周期的個數(shù),取決于什么因

素?

解:在每個總線周期的T3的開始處假設(shè)READY為低電平,那么CPU在T3后插入一個等待周

期TW。在TW的開始時刻,CPU還要檢查READY狀態(tài),假設(shè)仍為低電平,那么再插入一個

TWo此過程一直進(jìn)行到某個TW開始時,READY已經(jīng)變?yōu)楦唠娖?,這時下一個時鐘周期

才轉(zhuǎn)入T4。

可以看出,插入TW周期的個數(shù)取決于READY電平維持的時間。

2.12假設(shè)8088工作在單CPU方式下,在教材第91頁的表中填入不同操作時各控制信號的狀

態(tài)。

解:結(jié)果如表所示。

2.13在8086/8088CPU中,標(biāo)志存放器包含哪些標(biāo)志位?各位為0(為1)分別表示什么含

義?

解:(略),見書第49頁。

2.148086/8088CPU中,有哪些通用存放器和專用存放器?說明它們的作用。

解:通用存放器包含以下8個存放器:

AX、BX、CX和DX存放器一般用于存放參與運算的數(shù)據(jù)或運算的結(jié)果。除此之外:

AX:主要存放算術(shù)邏輯運算中的操作數(shù),以及存放I/O操作的數(shù)據(jù)。

BX:存放訪問內(nèi)存時的基地址。

CX:在循環(huán)和串操作指令中用作計數(shù)器。

DX:在存放器間接尋址的I/O指令中存放I/O地址。在做雙字長乘除法運算時,DX與AX合

起來存放一個雙字長數(shù)。

SP:存放棧頂偏移地址。

BP:存放訪問內(nèi)存時的基地址。

SP和BP也可以存放數(shù)據(jù),但它們的默認(rèn)段存放器都是SS。

SI:常在變址尋址方式中作為源地址指針。

DI:常在變址尋址方式中作為目標(biāo)地址指針。

專用存放器包括4個段存放器和兩個控制存放器:

CS:代碼段存放器,用于存放代碼段的段基地址。

DS:數(shù)據(jù)段存放器,用于存放數(shù)據(jù)段的段基地址。

SS:堆棧段存放器,用于存放堆棧段的段基地址。

ES:附加段存放器,用于存放附加段的段基地址。

IP:指令指針存放器,用于存放下一條要執(zhí)行指令的偏移地址。

FLAGS:標(biāo)志存放器,用于存放運算結(jié)果的特征。

2.158086/8088系統(tǒng)中,存儲器為什么要分段?一個段最大為多少個字節(jié)?最小為多少個

字節(jié)?

解:分段的主要目的是便于存儲器的管理,使得可以用16位存放器來尋址20位的內(nèi)存空間。

一個段最大為64KB,最小為16B。

2.16在8086/8088CPU中,物理地址和邏輯地址是指什么?邏輯地址為1F00:38AOH,如

何計算出其對應(yīng)的物理地址?

解:物理地址時CPU存取存儲器所用的地址。邏輯地址是段和偏移地址形式的地址,即匯

編語言程序中使用的存儲器地址。

假設(shè)邏輯地址為1F00:38A0H,那么對應(yīng)的物理地址=lF00HxI6+38AOH=228AOH.

2.17存儲器物理地址為78A00H,計算出它所對應(yīng)的邏輯地址。此結(jié)果惟一嗎?

解:物理地址可以對應(yīng)于不同的邏輯地址。78A00H對應(yīng)的邏輯地址可以是7000H:8A00H,

78OOH:0A00H,78A0H:0000H等。結(jié)果不是惟一的《

2.18設(shè)當(dāng)前數(shù)據(jù)段位于存儲器的A8000H?B7FFFH,DS段存放器的內(nèi)容應(yīng)是什么?

解:因為A8000H到B7FFFH之間的地址范圍大小為64KB,未超出一個段的最大范圍。故要

訪問此地址范圍的數(shù)據(jù),數(shù)據(jù)段的起始地址(即段首地址)應(yīng)為A8000H,那么DS段存放

器為A800H。

2.19假設(shè)CS=8OOOH,那么當(dāng)前代碼段可尋址的存儲空間的范圍是多少?

解(CS)=8000H口寸,當(dāng)前代碼段可司址的存儲空間范圍為80000H-8FFFFH。

2.208086/8088CPU在最小模式下構(gòu)成計算機(jī)系統(tǒng)至少應(yīng)包括哪幾個根本局部(器件)?

解:其至少應(yīng)包括:8088CPU、8284時鐘發(fā)生器、8282鎖存器(3片)和8286雙向總線驅(qū)動

器。

第3章8088/8086指令系統(tǒng)

3.1什么叫尋址方式?8086/8088CPU共有哪幾種尋址方式?

解:尋址方式主要是指獲得操作數(shù)所在地址的方法.8086/8088CPU具有:立即尋址、直接

尋址、存放器尋址、存放器間接尋址、存放器相對尋址、基址一變址尋址、基址一變址一

相對尋址以及隱含尋址等8種尋址方式。

3.2?(DS)=6000H,(ES)=2000H,(SS)=1500H,(Si)=00A0H,(BX)=O8OOH,(BP)=1200H,

數(shù)據(jù)變量VAR為0050H.請分別指出以下各條指令源操作數(shù)的尋址方式?它的物理地址是

多少?

(1)MOVAX,BX(2)MOVDL,80H

(3)MOVAX,VAR(4)MOVAX,VAR[BX][SI]

⑸MOVAL;B'(6)MOVDI,ES:[BX]

(7)MOVDX,[BP](8)MOVBX,20H[BX]

解:

⑴存放器尋址。因源操作數(shù)是存放器,故存放器BX就是操作數(shù)的地址.

⑵立即尋址。操作數(shù)80H存放于代碼段中指令碼MOV之后。

(3)直接尋址。

(4)基址一變址一相對尋址.

操作數(shù)的物理地址二(DS)X16+(SI)+(BX)+VAR

=60000H+00A0H+0800H+0050H=608F0H

(5)立即尋址

(6)存放器間接尋址.

操作數(shù)的物理地址二(ES)X16+(BX)

=2OOOOH+O8OOH=20800H

⑺存放器間接尋址。

操作數(shù)的物理地址=(SS)x164-(BP)

=15000H+1200H=16200H

(8)存放器相對尋址.

操作數(shù)的物理地址=(DS)X16+(BX)+20H

=6()()()0H+080()H4-20H=60820H

3.3假設(shè)(DS尸212AH,(CS尸0200H,(IP尸1200H,(BX尸0500H,位移量DATA=40H,(217A0H)

=23()()H,(217E0H)=()4()()H,(217E2H)=9000H

試確定以下轉(zhuǎn)移指令的轉(zhuǎn)移地址.

(1)JMP2300H

⑵JMPWORDPTRfBX]

(3)JMPDWORDPTR[BX+DATAJ

解:轉(zhuǎn)移指令分為段內(nèi)轉(zhuǎn)移和段間轉(zhuǎn)移,根據(jù)其尋址方式的不同,又有段內(nèi)的直接轉(zhuǎn)移和

間接轉(zhuǎn)移,以及段間的直接轉(zhuǎn)移和間接轉(zhuǎn)移地址。對直接轉(zhuǎn)移,其轉(zhuǎn)移地址為當(dāng)前指令的

偏移地址(即IP的內(nèi)容)加上位移量或由指令中直接得出;對間接轉(zhuǎn)移,轉(zhuǎn)移地址等于指

令中存放器的內(nèi)容或由存放器內(nèi)容所指向的存儲單元的內(nèi)容。

(1)段內(nèi)直接轉(zhuǎn)移。轉(zhuǎn)移的物理地址二(CS)X16+2300H

=02000H+2300H=04300H

⑵段內(nèi)間接轉(zhuǎn)移。轉(zhuǎn)移的物理地址二(CS)X16+[BX]

=(CS)X16H217A0H)

=02000H+2300H=04300H

⑶段間間接轉(zhuǎn)移。轉(zhuǎn)移的物理地址=出*+口人丁慶]

=(217E2H)x16+(217E0H)

=90000H+0400H=90400H

3.4試說明指令MOVBX,5[BX]與指令LEABX,5[BX]的區(qū)別。

解:前者是數(shù)據(jù)傳送類指令,表示將數(shù)據(jù)段中以(BX+5)為偏移地址的16位數(shù)據(jù)送存放器BX.

后者是取偏移地址指令,執(zhí)行的結(jié)果是(BX)=(BX)+5,即操作數(shù)的偏移地址為(BX)+5。

3.5設(shè)堆棧指針SP的初值為2300H,(AX)=50ABH,(BX)=1234H。執(zhí)行指令PUSHAX后,

(SP)=?,再執(zhí)行指令PUSHBX及POPAX之后,(SP)=?(AX)=?(BX)=?

解:堆棧指針SP總是指向棧頂,每執(zhí)行一次PUSH指令SP-2,執(zhí)行一次POP指令SP+2.所以,

執(zhí)行PUSHAX指令后,(SP)二22FEH;再執(zhí)行PUSHBX及POPAX后,(SP)=22FEH,

(AX)=(BX)=1234H

3.6指出以下指令的錯誤:

(l)MOVAH,CX(2)MOV33H,AL

(3)MOVAX,[SI][DI](4)MOV[BX],[SI]

(5)ADDBYTEPTR[BP],256(6)MOVDATA[SI],ES:AX

(7)JMPBYTEPTRIBX](8)OUT230H,AX

(9)MOVDS,BP(10)MUL39H

解:

⑴指令錯。兩操作數(shù)字長不相等

⑵指令錯。MOV指令不允許目標(biāo)操作數(shù)為立即數(shù).

⑶指令錯。在間接尋址中不允許兩個間址存放器同時為變址存放器。

(4)指令錯。MUV指令不允許兩個操作數(shù)同時為存儲器操作數(shù)。

⑸指令錯。ADD指令要求兩操作數(shù)等字長。

(6)指令錯。源操作數(shù)形式錯,存放器操作數(shù)不加段重設(shè)符。

⑺指令錯。轉(zhuǎn)移地址的字長至少應(yīng)是16位的。

(8)指令錯。對輸人輸出指令,當(dāng)端口地址超出8位二進(jìn)制數(shù)的表達(dá)范圍(即尋址的端口超出

256個)時,必須采用間接尋址。

(9)指令正確。

(10)指令錯。MUL指令不允許操作數(shù)為立即數(shù)。

3.7(AL)=7BH,(BL)=38H,試問執(zhí)行指令A(yù)DDAL,BL后,AF、CF、OF、PF、SF和ZF的值各

為多少?

解:AF=1,CF=0,OF=1,PF=O,SF=LZF=0

3.8試比擬無條件轉(zhuǎn)移指令、條件轉(zhuǎn)移指令、調(diào)用指令和中斷指令有什么異同?

解:無條件轉(zhuǎn)移指令的操作是無條件地使程序轉(zhuǎn)移到指定的目標(biāo)地址,并從該地址開始執(zhí)

行新的程序段,其轉(zhuǎn)移的目標(biāo)地址既可以是在當(dāng)前邏輯段,也可以是在不同的邏輯段;條

件轉(zhuǎn)移指令是在滿足一定條件下使程序轉(zhuǎn)移到指定的目標(biāo)地址,其轉(zhuǎn)移范圍很小,在當(dāng)前

邏輯段的-128?+127地址范圍內(nèi)。

調(diào)用指令是用于調(diào)用程序中常用到的功能子程序,是在程序設(shè)計中就設(shè)計好的。根據(jù)所調(diào)

用過程人口地址的位置可將調(diào)用指令分為段內(nèi)調(diào)用(入口地址在當(dāng)前邏輯段內(nèi))和段間調(diào)

用。在執(zhí)行調(diào)用指令后,CPU要保護(hù)斷點。對段內(nèi)調(diào)用是將其下一條指令的偏移地址壓人

堆棧,對段間調(diào)用那么要保護(hù)其下一條指令的偏移地址和段基地址,然后將子程序人口地

址賦給IP(或CS和IP).

中斷指令是因一些突發(fā)事件而使CPU暫時中止它正在運行的程序,轉(zhuǎn)去執(zhí)行一組專門的中

斷效勞程序,并在執(zhí)行完后返回原被中止處繼續(xù)執(zhí)行原程序。它是隨機(jī)的。在響應(yīng)中斷后

CPU不僅要保護(hù)斷點(即INT指令下一條指令的段地址和偏移地址),還要將標(biāo)志存放器

FLAGS壓入堆棧保存。

3.9試判斷以下程序執(zhí)行后,BX中的內(nèi)容.

MOVCL,3

MOVBX,0B7H

ROLBXJ

RORBX,CL

解:該程序段是首先將BX內(nèi)容不帶進(jìn)位循環(huán)左移1位,再循環(huán)右移3位。即相當(dāng)于將原BX

內(nèi)容不帶進(jìn)位循環(huán)右移2位,故結(jié)果為:(BX尸0C02DH

3.10按以下要求寫出相應(yīng)的指令或程序段。

⑴寫出兩條使AX內(nèi)容為0的指令。

⑵使BL存放器中的高4位和低4位互換。

⑶屏蔽CX存放器的bH,b7和b3位。

(4)測試DX中的b0和b8位是否為1。

解:

(1)

MOVAX,0

XORAX,AX;AX存放器自身相異或,可使其內(nèi)容清0

(2)

MOVCL,4

ROLBLCL;將BL內(nèi)容循環(huán)左移4位,可實現(xiàn)其高4位和低4位的互換

(3)

ANDCX.0F777H;將CX存放器中需屏蔽的位“與〃0。也可用“或〃指令實現(xiàn)

(4)

ANDDX,0101H;將需側(cè)試的位“與〃1,其余“與〃0屏蔽掉

CMPDX,()1()1H;與0101H比擬

JZONE;假設(shè)相等那么表示bO和b8位同時為1.

3.11分別指出以下兩個程序段的功能:

(1)(2)

MOVCX,10CLD

LEASI,FIRSTLEADI,[1200H1

LEADI,SECONDMOVCX.OFOOH

STDXORAX,AX

REPMOVSBREPSTOSW

解:

(I)該段程序的功能是:將數(shù)據(jù)段中FIRST為最高地址的10個字節(jié)數(shù)據(jù)按減地址方向傳送到

附加段SECOND為最高地址的向前10個單元中。

⑵將附加段中偏移地址為1200H單元開始的OFOOH個字單元清0。

3.12執(zhí)行以下兩條指令后,標(biāo)志存放器FLAGS的六個狀態(tài)位各為什么狀態(tài)?

MOVAX,84A0H

ADDAX,9460H

解:執(zhí)行ADD指令后,6個狀態(tài)標(biāo)志位的狀態(tài)分別為:

在兩個16位數(shù)進(jìn)行加法運算機(jī)對CF、ZF、SF和OF會產(chǎn)生影響,但對PF和AF標(biāo)志位,只有

其低8位的運算影響它們的狀態(tài)。各標(biāo)志位的狀態(tài)分別為:AF=(),PF=1,CF=1,ZF=(),SF=(),

OF=lo

3.13將+46和-38分別乘以2,可應(yīng)用什么指令來完成?如果除以2呢?

解:因為對二進(jìn)制數(shù),每左移一位相當(dāng)于乘以2,右移一位相當(dāng)于除以2。所以,將M6和-38

分別乘以2,可分別用邏輯左移指令(SHL)和算術(shù)左移指令(SAL)完成。SHL指令針對無符

號數(shù),SAL指令針對有符號數(shù)。

當(dāng)然,也可以分別用無符號數(shù)乘法指令MUL和有符號數(shù)乘法指令I(lǐng)MUL完成。

如果是除以2,那么進(jìn)行相反操作,即用邏輯右移指令SHR或無符號數(shù)除法指令DIV實現(xiàn)+46

除以2的運算,用算術(shù)右移指令SAR或有符號數(shù)除法指令I(lǐng)DIV實現(xiàn)?38除以2的運算。

3.14AX=8060H,DX=03F8H,端口PORT1的地址是48H,內(nèi)容為40H;PORT2的地址是84H,

內(nèi)容為85H。請指出以下指令執(zhí)行后的結(jié)果。

(l)OUTDX,AL

(2)INAL,PORT1

(3)OUTDX,AX

(4)INAX,48H

(5)OUTPORT2,AX

解:

⑴將60H輸出到地址為03F8H的端口中。

(2)從PORT1讀入一個字節(jié)數(shù)據(jù),執(zhí)行結(jié)果:(AL)二40H。

⑶將AX=8060H輸出到地址為03F8H的端口中。

(4)由48H端口讀人16位二進(jìn)制數(shù)。

⑸將8060H輸出到地址為84H的端口中。

第4章匯編語言程序設(shè)計

4」請分別用DB、DW、DD偽指令寫出在DATA開始的連續(xù)8個單元中依次存放數(shù)據(jù)UH、

22H、33H、44H、55H、66H、77H、88H的數(shù)據(jù)定義語句.

解:DB,DW,DD偽指令分別表示定義的數(shù)據(jù)為字節(jié)類型、字類型及雙字型.其定義形式為:

DATADB11H,22H,33H,44H,55H,66H,77H,88H

DATADW2211H4433H,6655H,8877H

DATADD44332211H,88776655H

4.2假設(shè)程序的數(shù)據(jù)段定義如下,寫出各指令語句獨立執(zhí)行后的結(jié)果:

DSEGSEGMENT

DATA1DB10H,20H,30H

DATA2DW10DUP(?)

STRINGDB"23'

DSEGENDS

(l)MOVAL,DATA1

(2)MOVBX,OFFSETDATA2

⑶LEASI,STRING

ADDDI,SI

解:

取變量DATA1的值.指令執(zhí)行后,(AL)=10H.

變量DATA2的偏移地址.指令執(zhí)行后,(BX尸0003H.

⑶先取變量STRING的偏移地址送存放器SI,之后送SI的內(nèi)容與DI的內(nèi)容相加并將結(jié)果送DL

指令執(zhí)行后,(SI)=0017H;(DI)=(DI)+0017H.

4.3試編寫求兩個無符號雙子長數(shù)之和的程序.兩數(shù)分別在MEM1和MEM2單元中,和放在

SUM單元.

解:

DSEGSEGMENT

MEM1DWU22H,3344H

MEM2DW5566H,7788H

SUMDW2DUP(?)

DSEGENDS

CSEGSEGMENT

ASSUMECS:CSEG,DS:DSEG

START:MOVAX,DSEG

MOVDS,AX

LEABX,MEM1

LEASI,MEM2

LEADI,SUM

MOVCL,2

CLC

AGAIN:MOVAXJBX]

ADCAX,[SI]

MOV[DI],AX

ADDBX,2

ADDSI,2

ADDDI,2

LOOPAGAIN

HLT

CSEGENDS

ENDSTART

4.4試編寫程序,測試AL存放器的第4位(bit4)是否為0?

解:測試存放器AL中某一位是否為0,可使用TEST指令、AND指令、移位指令等兒種方法實

現(xiàn)。

如:TESTAL,10H

JZNEXT

NEXT:…

或者:MOVCL,4

SHLAL,CL

JNCNEXT

NEXT:...

4.5試編寫程序,將BUFFER中的一個8位二進(jìn)制數(shù)轉(zhuǎn)換為ASCII碼,并按位數(shù)上下順序存放

在ANSWER開始的內(nèi)存單元中。

解:

DSEGSEGMENT

BUFFERDB?

ANSWERDB3DUP(?)

DSEGENDS

CSEGSEGMENT

ASSUMECS:CSEG,DS:DSEG

START:MOVAX,DSEG

MOVDS,AX

MOVCX,3;最多不超過3為十進(jìn)制數(shù)(255)

LEADI,ANSWER;DI指向結(jié)果存放單元

XORAX,AX

MOVAL,BUFFER;取要轉(zhuǎn)換的二進(jìn)制數(shù)

MOVBL,OAH;基數(shù)10

AGAIN:DIVBL;用除10取余的方法轉(zhuǎn)換

ADDAH,30H;十進(jìn)制數(shù)轉(zhuǎn)換成ASCII碼

MOV[DI],AH;保存當(dāng)前的結(jié)果

INCDI;指向下一個位保存單元

ANDAL,AL;商為0?(轉(zhuǎn)換結(jié)束?)

JZSTO;假設(shè)結(jié)束,退出

MOVAH,0

LOOPAGAIN;否則循環(huán)繼續(xù)

STO:MOVAX,4C00H

INT21H;返回DOS

CSEGENDS

ENDSTART

4.6假設(shè)數(shù)據(jù)項定義如卜:

DATA1DB4HELLO!GOODMORNING!'

DATA2DB20DUP(?)

用串操作指令編寫程序段,使其分別完成以下功能:

(1)從左到右將DATA1中的字符串傳送到DATA2中。

(2)傳送完后,比擬DATA1和DATA2中的內(nèi)容是否相同。

(3)把DATA1中的第3和第4個字節(jié)裝入AX。

(4)將AX的內(nèi)容存入DATA2+5開始的字節(jié)單元中。

解:

(1)

MOVAX,SEGDATA1

MOVDS,AX

MOVAX,SEGDATA2

MOVES,AX

LEASI,DATA1

LEADI,DATA2

MOVCX,2()

CLD

REPMOVSB

(2)

LEASI,DATA1

LEADI,DATA2

MOVCX,20

CLD

REPECMPSB

ooo

LEASI,DATA1

ADDSI,2

LODSW

(4)LEADLDATA2

ADDDL5

STOSW

4.7執(zhí)行以下指令后,AX存放器的內(nèi)容是多少?

TABLEDW10,20,30,40,50

ENTRYDW3

MOVBX,OFFSETTABLE

ADDBX,ENTRY

MOVAX,[BX]

解:(AX)=1E00H

4.8編寫程序段,將STRING1中的最后20個字符移到STRING2中(順序不變)。

解:首先確定STRING1中字符串的長度,因為字符串的定義要求以$符號結(jié)尾,

可通過檢測$符確定出字符串的長度,設(shè)串長度為COUNT,那么程序如下:

LEASI,STRING1

LEADI,STRING2

ADDSI,COUNT-20

MOVCX,20

CLD

REPMOVSB

4.9假設(shè)一個48位數(shù)存放在DX:AX:BX中,試編寫程序段,將該48位數(shù)乘以2.

解:可使用移位指令來實現(xiàn)「首先將BX內(nèi)容邏輯左移一位,其最高位移入進(jìn)位位CF,之后

AX內(nèi)容帶進(jìn)位位循環(huán)左移,使AX的最高位移入CF,而原CF中的內(nèi)容(即BX的最高位)

移入AX的最低位,最后再將DX內(nèi)容帶進(jìn)位位循環(huán)左移一位,從而實現(xiàn)AX的最低位移入DX

的最低位。

SHLBX,1

RCLAX,1

RCLDX,1

4.10試編寫程序,比擬AX,BX,CX中帶符號數(shù)的大小,并將最大的數(shù)放在AX中。

解:比擬帶符號數(shù)的大小可使用符號數(shù)比擬指令JG等。

CMPAX,BX

JGNEXT1

XCHGAX,BX

NEXT1:CMPAX,CX

JGSTO

MOVAX,CX

STO:HLT

4.11假設(shè)接口03F8H的第1位(bl)和第3位(B3)同時為1,表示接口03FBH有準(zhǔn)備好的8位

數(shù)據(jù),當(dāng)CPU將數(shù)據(jù)取走后,bl和b3就不再同時為1了,僅當(dāng)又有數(shù)據(jù)準(zhǔn)備好時才再同時為

lo

試編寫程序,從上述接口讀入200字節(jié)的數(shù)據(jù),并順序放在DATA開始的地址中。

解:即當(dāng)從輸入接口03F8H讀入的數(shù)據(jù)滿足xxxx1x1xB時可以從接口03FBH輸入數(shù)

據(jù)。

LEASI,DATA

MOVCX,200

NEXT:MOVDX,03F8H

WAIT:INAL,DX

ANDAL,OAH;判斷bl和b3位是否同時為1

CMPAL,OAH

JNZWAIT;bl和W位同時為1那么讀數(shù)據(jù),否則等待

MOVDX,03FBH

INAL,DX

MOV[SI],AL

INCSI

LOOPNEXT

HLT

4.12畫圖說明以下語句分配的存儲空間及初始化的數(shù)據(jù)值。

(1)DATA1DB'BYTE'12,12H,2DUP(0,?,3)

(2)DATA2DW4DUP(0,1,2),?,-5,256H

解:(1)存儲空間分配情況如圖6)所示。

〔2〕存儲空間分配情況如圖(b)所示。

第5章存儲器系統(tǒng)

5.1內(nèi)部存儲器主要分為哪兩類?它們的主要區(qū)別是什么?

解:

(1)分為ROM和RAMo

(2)它們之間的主要區(qū)別是:

oROM在正常工作時只能讀出,不能寫入。RAM那么可讀可寫。

o斷電后,ROM中的內(nèi)容不會喪失,RAM中的內(nèi)容會喪失。

5.2為什么動態(tài)RAM需要定時刷新?

解:DRAM的存儲元以電容來存儲信息,由于存在漏電現(xiàn)象,電容中存儲的電荷會逐漸泄

漏,從而使信息喪失或出現(xiàn)錯誤。因此需要對這些電容定時進(jìn)行“刷新”。

5.3CPU尋址內(nèi)存的能力最根本的因素取決于o

解:地址總線的寬度。

5.4試?yán)萌刂纷g碼將6264芯片接到8088系統(tǒng)總線上,使其所占地址范圍為32OOOH?

33FFFH。

解:將地址范圍展開成二進(jìn)制形式如以下圖所示。

0011001()000()000()()000

00110011111111111111

6264芯片的容量為8X8KB,需要13根地址線A0?A12。而剩下的高7位地址應(yīng)參加該芯片

的地址譯碼。

電路如下圖:

5.5內(nèi)存地址從20000H?8BFFFH共有多少字節(jié)?

解:共有8BFFFH—20000H+l=6C000H個字節(jié)?;?32KB。

5.6假設(shè)采用6264芯片構(gòu)成上述的內(nèi)存空間,需要多少片6264芯片?

解:每個6264芯片的容量位BKB,故需432/8=54片。

5.7設(shè)某微型機(jī)的內(nèi)存RAM區(qū)的容量位128KB,假設(shè)用2164芯片構(gòu)成這樣的存儲器,需多

少2164芯片?至少需多少根地址線?其中多少根用于片內(nèi)尋址?多少根用于片選譯碼?

解:

(1)每個2164芯片的容量為64Kxibit,共需128/64X8=16片。

(2)128KB容量需要地址線17根。

(3)16根用于片內(nèi)尋址。

(4)1根用于片選譯碼。

注意,用于片內(nèi)尋址的16根地址線要通過二選一多路器連到2164芯片,因為2164芯片是

DRAM,高位地址與低位地址是分時傳送的。

5.8現(xiàn)有兩片6116芯片,所占地址范圍為61000H?61FFFH,試將它們連接到8088系統(tǒng)中。

并編寫測試程序,向所有單元輸入一個數(shù)據(jù),然后再讀出與之比擬,假設(shè)出錯那么顯示

“Wrong!",全部正確那么顯示"OK!

解:連接如以下圖所示。測試程序段如下:

OKDB'OK!\$

WRONGDB'Wrong!

MOVAX,61OOH

MOVES,AX

MOVDI,0

MOVCX,1000H

MOVAL,55H

REPSTOSB

MOVDI,0

MOVCX,1000H

REPZSCASB

JZDISP_OK

LEADX,WRONG

MOVAH,9

INT21H

HLT

DISP_OK:

LEADX,OK

MOVAH,9

INT21H

HLT

5.9甚什么是字?jǐn)U展?什么是位擴(kuò)展?用戶自己購置內(nèi)存條進(jìn)行內(nèi)存擴(kuò)充,是在進(jìn)行何種

存儲器擴(kuò)展?

解:

(1)當(dāng)存儲芯片的容量小于所需內(nèi)存容量時,需要用多個芯片構(gòu)成滿足容量要求的存儲器,

這就是字?jǐn)U展。

(2)當(dāng)存儲芯片每個單元的字長小于所需內(nèi)存單元字長時,需要用多個芯片構(gòu)成滿足字長

要求的存儲模塊,這就是位擴(kuò)展。

(3)用戶在市場上購置內(nèi)存條進(jìn)行內(nèi)存擴(kuò)充,所做的是字?jǐn)U展的工作。

5.1074LS138譯碼器的接線圖如教材第245頁的圖5-47所示,試判斷其輸出端Y0#、Y3#、Y5#

和Y7#所決定的內(nèi)存地址范圍。

解:因為是局部地址譯碼(A17不參加譯碼),故每個譯碼輸出對應(yīng)2個地址范圍:

YO#:OOOOOH?01FFFH和2000()H?21FFFH

Y3#:06000H?07FFFH和26000H?27FFFH

Y5#:0A000H?0BFFFH和2A000H?2BFFFH

Y7#;0E000H?0FFFFH和2E000H~2FFFFH

5.11某8088系統(tǒng)用2764ROM芯片和6264SRAM芯片構(gòu)成16KB的內(nèi)存。其中,ROM的地址

范圍為0FE000H?0FFFFFH,RAM的地址范圍為OFOOOOH?OF1FFFH。試?yán)?4LS138譯碼,

畫出存儲器與CPU的連接圖,并標(biāo)出總線信號名稱。

解:連接如以下圖所示。

5.12表達(dá)EPROM的編程過程,并說明EPROM和EEPROM的不同點。(不要求)

解:

(1)對EPROM芯片的編程過程詳見教材第215?217頁。

(2)EPROM與EEPROM的不同之處為:

oEPROM用紫外線擦除,EEPROM用電擦除。

。EPROM是整片擦除,EEPROM可以整片擦除,也可以逐個字節(jié)地擦除。

5.13試說明FLASHEEPROM芯片的特點及28F040的編程過程。(不要求)

解:

(1)特點是:它結(jié)合了RAM和ROM的優(yōu)點,讀寫速度接近于RAM,斷電后信息又不會喪

失。

(2)28F040的編程過程詳見教材第222?223頁。

5.14什么是Cache?它能夠極大地提高計算機(jī)的處理能力是基于什么原理?

解:

(1)Cache是位于CPU與主存之間的高速小容量存儲器。

(2)它能夠極大地提高計算機(jī)的處理能力,是基于程序和數(shù)據(jù)訪問的局部性原理。

5.15假設(shè)主存DRAM的的存取周期為70ns,Cache的存取周期為5ns,有它們構(gòu)成的存儲器

的平均存取周期是多少?

解:平均存取周期約為70X0.1ns+5X0.9ns=11.5nSo

第6章輸入輸出和中斷技術(shù)

6.1I/O接口的主要功能有哪些?有哪兩種編址方式?在8088/8086系統(tǒng)中采用哪一種編址方

式?

解:I/O接口主要需具有以下幾種功能:

11)I/O地址譯碼與設(shè)備選擇。保證任一時刻僅有一個外設(shè)與CPU進(jìn)行數(shù)據(jù)傳送c

(2)信息的輸入輸出,并對外設(shè)隨時進(jìn)行監(jiān)測、控制和管理。必要時,還可以通過I/O接

口向CPU發(fā)出中斷請求。

(3)命令、數(shù)據(jù)和狀態(tài)的緩沖與鎖存。以緩解CPU與外設(shè)之間工作速度的差異,保證信息

交換的同步。

(4)信號電平與類型的轉(zhuǎn)換。I/O接口還要實現(xiàn)信息格式轉(zhuǎn)換、電平轉(zhuǎn)換、碼制轉(zhuǎn)換、傳

送管理以及聯(lián)絡(luò)

挖制等功能。

I/O端口的編址方式通常有兩種:一是與內(nèi)存單元統(tǒng)一編址,二是獨立編址。8088/8086系統(tǒng)

采用I/O端口獨立編址方式。

6.2試比擬4種根本輸入輸出方法的特點。(不要求)

解:在微型計算機(jī)系統(tǒng)中,主機(jī)與外設(shè)之間的數(shù)據(jù)傳送有4種根本的輸入輸出方式:

無條件傳送方式、查詢工作方式、中斷工作方式、直接存儲器存取(DMA)方式。

它們各自具有以下特點:

(1)無條件傳送方式適合與簡單的、慢速的、隨時處于“準(zhǔn)備好〃接收或發(fā)送數(shù)據(jù)的外部

設(shè)備,數(shù)據(jù)交換與指令的執(zhí)行同步,控制方式簡單。

(2)查詢工作方式針對并不隨時“準(zhǔn)備好〃、且滿足一定狀態(tài)才能實現(xiàn)數(shù)據(jù)的輸入/輸出的

簡單外部設(shè)備,其控制方式也比擬簡單,當(dāng)CPU的效率比擬低。

(3)中斷工作方式是由外部設(shè)備作為主動的一方,在需要時向CPU提出工作請求,CPU在

滿足響應(yīng)條件時響應(yīng)該請求并執(zhí)行相應(yīng)的中斷處理程序。這種工作方式使CPU的效率提高,

但控制方式相對較復(fù)雜。

(4)DMA方式適合于高速外設(shè),是4種根本輸入/輸出方式中速度最高的一種。

6.3主機(jī)與外部設(shè)備進(jìn)行數(shù)據(jù)傳送時,采用哪一種傳送方式,CPU的效率最高?(不要求)

解:使用DMA傳送方式CPL-的效率最高。這是由DMA的工作性質(zhì)所決定的。

6.4利用三態(tài)門芯片74LS244作為輸入接口,接口地址為40FBH,試畫出其與8088系統(tǒng)總線

的連接圖。

解:16位地址信號通過譯碼電路與74LS244芯片連接。其連接如以下圖所示。

6.5某輸入接口的地址為0E54H,輸出接口的地址為01FBH,分別利用74LS244和74LS273

作為輸入和輸出接口。試編寫程序,使當(dāng)輸入接口的bill、bi【4和bi【7位同時為1時,CPU將

內(nèi)存中DATA為首址的20個單元的數(shù)據(jù)從輸出接口輸出;假設(shè)不滿足上述條件那么等待。

解:首先判斷由輸入接口讀入數(shù)據(jù)的狀態(tài),假設(shè)滿足條件,那么通過輸出接口輸出一個單

元的數(shù)據(jù);之后再判斷狀態(tài)是否滿足,直到20個單元的數(shù)據(jù)都從輸出接口輸出。

LEASI,DATA;取數(shù)據(jù)偏移地址

MOVCL,20;數(shù)據(jù)長度送CL

AGAIN:MOVDX,0E54H

WAITT:INAL,DX;讀入狀態(tài)值

ANDAL,92H;屏蔽掉不相關(guān)位,僅保存bill、bit4和bil7位狀態(tài)

CMPAL,92H;判斷向1、bit4和bit7位是否全為1

JNZWAITT;不滿足bitl、bit4和bit7位同時為1那么等待

MOVDX,01FBH

MOVAL,[SI]

OUTDX,AL;滿足條件那么輸出一個單元數(shù)據(jù)

INCSI;修改地址指針

LOOPAGAIN;假設(shè)20個單元數(shù)據(jù)未傳送完那么循環(huán)

6.68088/8086系統(tǒng)如何確定便件中斷效勞程序的入口地址?

解:8088/8086系統(tǒng)的硬件中斷包括非屏蔽和可屏蔽兩種中斷請求。每個中斷源都有一個與

之相對應(yīng)的中斷類型碼n。系統(tǒng)規(guī)定所有中斷效勞子程序的首地址都必須放在中斷向量表

中,其在表中的存放地址=nX4,(向量表的段基地址為0000H)。即子程序的入口地址

為(0000H:nX4)開始的4個單元中,低位字(2個字節(jié))存放入口地址的偏移量,高位

字存放入口地址的段基地址。

6.7中斷向量表的作用是什么?如何設(shè)置中斷向量表?

解:中斷向量表用于存放中斷效勞子程序的入口地址,位于內(nèi)存的最低1K字節(jié)(即內(nèi)存中

OOOOH?003FFH區(qū)域),共有256個表項。

設(shè)置中斷向量表就是將中斷效勞程序首地址的偏移量和段基址放入中斷向量表中。

如:將中斷效勞子程序CLOCK的入口地址置入中斷向量表的程序如下:

MOVAX,0000H

MOVDS,AX;置中斷向量表的段基地址

MOVSI,〈中斷類型碼X4>;置存放子程序入口地址的偏移地址

MOVAX,OFFSETCLOCK

MOV[SI],AX;將子程序入口地址的偏移地址送入中斷向量表

MOVAX,SEGCLOCK

MOV[SI+2],AX;將子程序入口地址的段基址送入中斷向量表

6.8INTR中斷和NMI中斷有什么區(qū)別?

解:INTR中斷為可屏蔽中斷,中斷請求信號高電平有效。CPU能否響應(yīng)該請求要看中斷允

許標(biāo)志位IF的狀態(tài),只有當(dāng)1F=1時,CPU才可能響應(yīng)中斷。

NMI中斷為非屏蔽中斷,請求信號為上升沿有效,對它的響應(yīng)不受IF標(biāo)志位的約束,CPU

只要當(dāng)前指令執(zhí)行結(jié)束就可以響應(yīng)NMI請求。

6.9在中斷效勞程序的入口處,為什么常常要使用開中斷指令?

解:中斷效勞程序分為兩種,一種是在進(jìn)入效勞子程序后不允許被中斷,另一種那么可以

被中斷。在入口處使用開中斷指令表示該中斷效勞程序是允許被中斷的效勞程序,即在進(jìn)

入效勞子程序后允許CPU響應(yīng)比它級別高的中斷請求。

6.10試說明8088CPU可屏蔽中斷的響應(yīng)過程。

解:可屏蔽中斷的響應(yīng)過程主要分為5個步驟,即:

(1)中斷請求。外設(shè)在需要時向CPU的INTR端發(fā)出一個高電平有效的中斷請求信號。

(2)中斷判優(yōu)。假設(shè)IF=1,那么識別中斷源并找出優(yōu)先級最高的中斷源先予以響應(yīng),在

其處理完后,再響應(yīng)級別較低的中斷源的請求。

(3)中斷響應(yīng)。中斷優(yōu)先級確定后,發(fā)出中斷的中斷源中優(yōu)先級別最高的中斷請求就被送

到CPU。

(4)中斷處理。

(5)中斷返回。中斷返回需執(zhí)行中斷返回指令I(lǐng)RET,其操作正好是CPU硬件在中斷響應(yīng)時

自動保護(hù)斷點的逆過程。即CPU會自動地將堆棧內(nèi)保存的斷點信息彈出到IP、CS和FLAG

中,保證被中斷的程序從斷點處繼續(xù)往卜執(zhí)行。

6.11CPU滿足什么條件能夠響應(yīng)可屏蔽中斷?

解:

(1)CPU要處于開中斷狀態(tài),即IF=1,才能響應(yīng)可屏蔽中斷。

(2)當(dāng)前指令結(jié)束。

(3)當(dāng)前沒有發(fā)生復(fù)位(RESET)、保持(HOLD)和非屏蔽中斷請求(NMI)。

(4)假設(shè)當(dāng)前執(zhí)行的指令是開中斷指令(STI)和中斷返回指令(IRET),那么在執(zhí)行完

該指令后再執(zhí)行一條指令,CPU才能響應(yīng)INTR請求。

(5)對前綴指令,如LOCK、REP等,CPU會把它們和它們后面的指令看作一個整體,直

到這個整體指令執(zhí)行完,方可響應(yīng)INTR請求。

6.14單片8259A能夠管理多少級可屏蔽中斷?假設(shè)用3片級聯(lián)能管理多少級可屏蔽中斷?

(不要求)

解:因為8259A有8位可屏蔽中斷請求輸入端,故單片8259A能夠管理8級可屏蔽中斷。假設(shè)

用3片級聯(lián),即1片用作主控芯片,兩片作為附屬芯片,每一片附屬芯片可管理8級,那么3

片級聯(lián)共可管理22級可屏蔽中斷。

6.16具備何種條件能夠作輸入接口?何種條件能夠作輸出接口?

解:對輸入接口要求具有對數(shù)據(jù)的控制能力,對輸出接口要求具有對數(shù)據(jù)的鎖存能力。

6.17(SP)=0100H,(SS)=3500H,(CS)=9000H,(IP)=0200H,(00020H)

=7FH,(00021H)=1AH,(00022H)=07H,(OOO23H)=6CH,在地址為90200H開始

的連續(xù)兩個單元中存放一條兩字節(jié)指令I(lǐng)NT8。試指出在執(zhí)行該指令并進(jìn)入相應(yīng)的中斷例程

時,SP、SS、IP、CS存放器的內(nèi)容以及SP所指向的字單元的內(nèi)容是什么?

解:CPU在響應(yīng)中斷請求時首先要進(jìn)行斷點保護(hù),即要依次將FLAGS和INT下一條指令的

CS、IP存放器內(nèi)容壓入堆棧,亦即棧頂指針減6,而SS的內(nèi)容不變。INT8指令是一條兩字

節(jié)指令,故其下一條指令的IP=0200H+2=0202H。

中斷效勞子程序的入口地址那么存放在中斷向量表(8X4)所指向的連續(xù)4個單元中。所以,

在執(zhí)行中斷指令并進(jìn)入響應(yīng)的中斷例程時,以上各存放器的內(nèi)容分別為:

SP=0100H-6=00FAH

SS=3500H

IP=[8X4]=1A7FH

CS=[(8X4)+2]=6C07H

[SP]=()200H+2=0202H

第7章常用數(shù)字接口電路

7.1一般來講,接口芯片的讀寫信號應(yīng)與系統(tǒng)的哪些信號相連?

解:一般來講,接口芯片的讀寫信號應(yīng)與系統(tǒng)總線信號中的#IOR(接口讀)或#IOW(接口

寫)信號相連。

7.2試說明8253芯片的六種工作方式。其時鐘信號CLK和門控信號GATE分別起什么作用?

解:可編程定時/計數(shù)器8253具有六種不同的工作方式,其中:

方式0:軟件啟動、不自動重復(fù)計數(shù)。在寫入控制字后OUT端變低電平,計數(shù)結(jié)束后OUT

端輸出高電平,可用來產(chǎn)生中斷請求信號,故也稱為L數(shù)結(jié)束產(chǎn)生中斷的工作方式。

方式1:硬件啟動、不自動重復(fù)計數(shù)。所謂硬件啟動是在寫入計數(shù)初值后并不開始計數(shù),而

是要等門控信號GATE出現(xiàn)由低到高的跳變后,在下一個CLK脈沖的下降沿才開始計數(shù),此

時OUT端立刻變?yōu)榈碗娖?。計?shù)結(jié)束后,OUT端輸出高電平,得到一個寬度為計數(shù)初值N

個CLK脈沖周期寬的負(fù)脈沖。

方式2:既可軟件啟動,也可以硬件啟動。可自動重復(fù)計數(shù)。

在寫入控制字后,OUT端變?yōu)楦唠娖?。計?shù)到最后一個時鐘脈沖時OUT端變?yōu)榈碗娖?,?/p>

經(jīng)過一個CLK周期,計數(shù)值減到零,OUT又恢復(fù)為高電平。之后再自動轉(zhuǎn)入計數(shù)初值,并

重新開始新的一輪計數(shù)。方式2卜OUT端會連續(xù)輸出寬度為Tclk的負(fù)脈沖,其周期為NX

Tclk,所以方式2也稱為分頻器,分頻系數(shù)為計數(shù)初值N。

方式3:也是一種分頻器,也有兩種啟動方式,自動重夏計數(shù)。當(dāng)計數(shù)初值N為偶數(shù)時,連

續(xù)輸出對稱方波(即N/2個CLK脈沖低電平,N/2個CLK執(zhí)沖高電平),頻率為(1/N)XFclk。

假設(shè)N為奇數(shù),那么輸出波形不對稱,其中(N+1)/2個時鐘周期高電平,(N-1)/2

個時鐘周期低電平。

方式4和方式5都是在計數(shù)結(jié)束后輸出一個CLK脈沖周期寬的負(fù)脈沖,且均為不自動重復(fù)計

數(shù)方式。區(qū)別在方式4是軟件啟動,而方式5為硬件啟動。

時鐘信號CLK為8253芯片的工作基準(zhǔn)信號。GATE信號為門控信號。在軟件啟動時要求

GATE在計數(shù)過程中始終保持高電平;而對硬件啟動的工作方式,要求在寫入計數(shù)初值后

GATE端出現(xiàn)一個由低到高的正跳變,啟動計數(shù)。

7.38253可編程定時7計數(shù)器有兩種啟動方式,在軟件啟動時,要使計數(shù)正常進(jìn)行,GATE端

必須為()電平,如果是硬件啟動呢?

解:在軟件啟動時,要使計數(shù)正常進(jìn)行,GATE端必須為高電平;如果是硬件啟動,那么要

在寫入計數(shù)初值后使GATE端出現(xiàn)一個由低到高的正跳變,以啟動計數(shù)。

7.4假設(shè)8253芯片的接口地址為D0D0H?D0D3H,時鐘信號頻率為2MHz。現(xiàn)利用計數(shù)器0、

1、2分別產(chǎn)生周期為l()us的對稱方涉及每1ms和1s產(chǎn)生一個負(fù)脈沖,試畫出其與系統(tǒng)的電路

連接圖,并編寫包括初始化在內(nèi)的程序。

解:根據(jù)題目要求可知,計數(shù)器01CNT0)工作于方式3,計數(shù)器1(CNT1)和計數(shù)器2(CNT2)

工作于方式2。時鐘頻率2MHz,即周期為0.5us,從而得出各計數(shù)器的計數(shù)初值分別為:

CNTO:

10us/0.5us=20

CNT1:

l:ns/0.5us=2000

CNT2:

ls/().5us=2x1(X)0000

顯然,計數(shù)器2的計數(shù)初值已超出了16位數(shù)的表達(dá)范圍,需經(jīng)過一次中間分頻,可將OUT1

端的輸出脈沖作為計數(shù)器2的時鐘頻率。這樣,CNT2的計數(shù)初值就等于ls/lms=1000。線

路連接如下圖。

8253

8253的初始化程序如下:

MOVDX,0D0D3H

MOVAL,16H;計數(shù)器0,低8位計數(shù),方式3

OUTDX,AL

MOVAL,74H;計數(shù)器1,雙字節(jié)計數(shù),方式2

OUTDX,AL

MOVAL,0B4H;計數(shù)器2,雙字節(jié)計數(shù),方式2

OUTDX,AL

MOVDX,0D0D0H

MOVAL,20;送計數(shù)器()的計數(shù)初值

OUTDX,AL

MOVDX,0D0D1H

MOVAX,2000;送計數(shù)器1的計數(shù)初值

OUTDX,AL

MOVAL,AH

OUTDX,AL

MOVDX,0D0D2H

MOVAX,1000;送計數(shù)器2的計數(shù)初值

OUTDX,AL

MOVAL,AH

OUTDX,AL

7.5某一計算機(jī)應(yīng)用系統(tǒng)采用8253芯片的計數(shù)器。作頻率發(fā)生器,輸出頻率為500Hz;用計

數(shù)器1產(chǎn)生1000Hz的連續(xù)方波信號,輸入8253的時鐘頻率為1.19MHz。

試問:初始化時送到計數(shù)器()和計數(shù)器1的計數(shù)初值分別為多少?計數(shù)器1工作于什么方式

下?

解:計數(shù)器0工作于方式2,其計數(shù)初值=1.19MHz/5()0Hz=238()

干數(shù)器1工作于方式3,其計數(shù)初值=1.19MHz/lKHz=l190

7.6假設(shè)所用8253芯片用軟

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論