《微型計算機(jī)原理與接口技術(shù)》課后答案_第1頁
《微型計算機(jī)原理與接口技術(shù)》課后答案_第2頁
《微型計算機(jī)原理與接口技術(shù)》課后答案_第3頁
《微型計算機(jī)原理與接口技術(shù)》課后答案_第4頁
《微型計算機(jī)原理與接口技術(shù)》課后答案_第5頁
已閱讀5頁,還剩9頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、第1章基礎(chǔ)知識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ā)的初步能力。解:( 1) 166,A6H( 2) 0.75( 3) 11111101.01B,FD.4H(4)5B.AH,(10010001.011000100101)BCD1.4 8位和16位二進(jìn)制數(shù)的原碼、補(bǔ)碼和反碼可表示的數(shù)的范圍分別是多少?解:原碼(-

2、127+127)、(-32767+32767)補(bǔ)碼(-128+127)、(-32768+32767)反碼(-127+127)、(-32767+32767)1.5 寫出下列真值對應(yīng)的原碼和補(bǔ)碼的形式。( 1) X=-1110011B( 2) X=-71D( 3) X=+1001001B解:(1)原碼:11110011補(bǔ)碼:10001101(2)原碼:11000111補(bǔ)碼:10111001(3)原碼:01001001補(bǔ)碼:010010011.6 寫出符號數(shù)10110101B的反碼和補(bǔ)碼。解:11001010,110010111.7 已知X和Y的真值,求X+Y的補(bǔ)碼。( 1) X=-1110111B

3、Y=+1011010B( 2) X=56DY=-21D解: 1) 11100011 2) 2)001000111.8 已知X=-1101001B,Y=-1010110B,用補(bǔ)碼求X-Y的值。解:111011011.9 請寫出下列字符的ASCII碼。4A3-!解:34H,41H,33H,3DH,21H1.10 若給字符4和9的ASCII碼加奇校驗,應(yīng)是多少?解:34H,B9H1.11 上題中若加偶校驗,結(jié)果如何?解:B4H,39H1.12 計算下列表達(dá)式。 1) (4EH+10110101B)x(0.0101)BCD=()D 2) 2)4EH-(24/08H+B/2)=()B解: 1) 129.

4、5D 2) 2)101010B第2章微型計算機(jī)基礎(chǔ)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在工作時

5、不斷地從指令隊列取出指令代碼,對其譯碼后產(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就等待,直到有指

6、令為止。若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可以訪問存

7、儲器取下一條指令或指令執(zhí)行時需要的數(shù)據(jù)。2.9 8086與8088CPU的主要區(qū)別有哪些?解:主要區(qū)別有以下幾點:8086的外部數(shù)據(jù)總線有16位,而8088的外部數(shù)據(jù)總線只有8位。8086指令隊列深度為6個字節(jié),而8088的指令隊列深度為4個字節(jié).因為8086的外部數(shù)據(jù)總線有16位,故8086每個總線周期可以存取兩個字節(jié).而8088的外部數(shù)據(jù)總線因為只有8位,所以每個總線周期只能存取1個字節(jié).個別引腳信號的含義稍有不同.2.10 8088CPU工作在最小模式下:(1)當(dāng)CPU訪問存儲器時,要利用哪些信號?(2)當(dāng)CPU進(jìn)行I/O操作時,要利用哪些信號?(3)當(dāng)HOLD有效并得到響應(yīng)時,CPU的

8、哪些信號置高阻?解:(1)要利用信號線包括WR#、RD#、IO/M#、ALE以及AD0AD7、A8A19。(2)同(1)。(3)所有三態(tài)輸出的地址信號、數(shù)據(jù)信號和控制信號均置為高阻態(tài)。2.11 總線周期中,什么情況下要插入TW等待周期?插入TW周期的個數(shù),取決于什么因素?解:在每個總線周期的T3的開始處若READY為低電平,則CPU在T3后插入一個等待周期TW。在TW的開始時刻,CPU還要檢查READY狀態(tài),若仍為低電平,則再插入一個TW。此過程一直進(jìn)行到某個TW開始時,READY已經(jīng)變?yōu)楦唠娖?,這時下一個時鐘周期才轉(zhuǎn)入T4??梢钥闯觯迦隩W周期的個數(shù)取決于READY電平維持的時間。2.12

9、 若8088工作在單CPU方式下,在教材第91頁的表中填入不同操作時各控制信號的狀態(tài)。解:結(jié)果如表所示。2.13 在8086/8088CPU中,標(biāo)志寄存器包含哪些標(biāo)志位?各位為0(為1)分別表示什么含義?解:(略),見書第49頁。2.14 8086/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

10、/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.1

11、5 8086/8088系統(tǒng)中,存儲器為什么要分段?一個段最大為多少個字節(jié)?最小為多少個字節(jié)?解:分段的主要目的是便于存儲器的管理,使得可以用16位寄存器來尋址20位的內(nèi)存空間。一個段最大為64KB,最小為16B。2.16 在8086/8088CPU中,物理地址和邏輯地址是指什么?已知邏輯地址為1F00:38A0H,如何計算出其對應(yīng)的物理地址?解:物理地址時CPU存取存儲器所用的地址。邏輯地址是段和偏移地址形式的地址,即匯編語言程序中使用的存儲器地址。若已知邏輯地址為1F00:38A0H,則對應(yīng)的物理地址=1F00Hx16+38A0H=228A0H。2.17 已知存儲器物理地址為78A00H,計

12、算出它所對應(yīng)的邏輯地址。此結(jié)果惟一嗎?解:物理地址可以對應(yīng)于不同的邏輯地址。78A00H對應(yīng)的邏輯地址可以是7000H:8A00H,7800H:0A00H,78A0H:0000H等。結(jié)果不是惟一的。2.18 設(shè)當(dāng)前數(shù)據(jù)段位于存儲器的A8000HB7FFFH,DS段寄存器的內(nèi)容應(yīng)是什么?解:因為A8000H到B7FFFH之間的地址范圍大小為64KB,未超出一個段的最大范圍。故要訪問此地址范圍的數(shù)據(jù),數(shù)據(jù)段的起始地址(即段首地址)應(yīng)為A8000H,WJDS段寄存器為A800H。2.19 若CS=8000H,則當(dāng)前代碼段可尋址的存儲空間的范圍是多少?解(CS)=8000H時,當(dāng)前代碼段可尋址的存儲空

13、間范圍為80000H8FFFFH。2.20 8086/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 設(shè)(DS)=6000H,(ES)=2000H,(SS)=15

14、00H,(Si)=00A0H,(BX)=0800H,(BP)=1200H,數(shù)據(jù)變量VAR為0050H.請分別指出下列各條指令源操作數(shù)的尋址方式?它的物理地址是多少?(1)MOVAX,BX(2)MOVDL,80H(3)MOVAX,VAR(4)MOVAX,VARBXSI(5)MOVAL,'B'(6)MOVDI,ES:BX(7)MOVDX,BP(8)MOVBX,20HBX解:(1)寄存器尋址。因源操作數(shù)是寄存器,故寄存器BX就是操作數(shù)的地址.(2)立即尋址。操作數(shù)80H存放于代碼段中指令碼MOV之后。(3)直接尋址。(4)基址一變址一相對尋址操作數(shù)的物理地址=(DS)X16+(SI)

15、+(BX)+VAR=60000H+00A0H+0800H+0050H=608F0H(5)立即尋址(6)寄存器間接尋址.操作數(shù)的物理地址=(ES)X16+(BX)=20000H0800H=20800H(7)寄存器間接尋址。操作數(shù)的物理地址=(SS)X16+(BP)=15000H1200H=16200H(8)寄存器相對尋址操作數(shù)的物理地址=(DS)X16+(BX)+20H=60000H0800H20H=60820H3.3假設(shè)(DS)=212AH,(CS)=0200H,(IP)=1200H,(BX)=0500H,位移量DATA=40H,(217A0H)=2300H,(217E0H)=0400H,(2

16、17E2H)=9000H試確定下列轉(zhuǎn)移指令的轉(zhuǎn)移地址.(1) JMP2300H(2) JMPWORDPTRBX(3) JMPDWORDPTRBX+DATA解:轉(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(2)段內(nèi)間接轉(zhuǎn)移。轉(zhuǎn)移的物理地址=(CS)X16+B

17、X=(CS)X16+(217A0H)=02000H+2300H=04300H(3)段間間接轉(zhuǎn)移。轉(zhuǎn)移的物理地址=BX+DATA=(217E2H)X16+(217E0H)=90000H+0400H=90400H3.4 試說明指令MOVBX,5BX與指令LEABX,5BX的區(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í)行指令PUSHB

18、X及POPAX之后,(SP)=?(AX)=?(BX)=?解:堆棧指針SP總是指向棧頂,每執(zhí)行一次PUSH指令SP-2,執(zhí)行一次POP指令SP+2.所以,執(zhí)行PUSHAX指令后,(SP)=22FEH;再執(zhí)行PUSHBX及POPAX后,(SP)=22FEH,(AX)=(BX)=1234H3.6 指出下列指令的錯誤:(1) MOVAH,CX(2)MOV33H,AL(3)MOVAX,SIDI(4)MOVBX,SI(5)ADDBYTEPTRBP,256(6)MOVDATASI,ES:AX(7)JMPBYTEPTRBX(8)OUT230H,AX(9)MOVDS,BP(10)MUL39H解:(1)指令錯。兩

19、操作數(shù)字長不相等(2)指令錯。MOV指令不允許目標(biāo)操作數(shù)為立即數(shù)(3) 指令錯。在間接尋址中不允許兩個間址寄存器同時為變址寄存器。(4)指令錯。MUV指令不允許兩個操作數(shù)同時為存儲器操作數(shù)。(5)指令錯。ADD指令要求兩操作數(shù)等字長。(6)指令錯。源操作數(shù)形式錯,寄存器操作數(shù)不加段重設(shè)符。(7)指令錯。轉(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

20、、CF、OF、PF、SF和ZF的值各為多少?解:AF=1,CF=0,OF=1,PF=0,SF=l,ZF=03.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))和

21、段間調(diào)用。在執(zhí)行調(diào)用指令后,CPU要保護(hù)斷點。對段內(nèi)調(diào)用是將其下一條指令的偏移地址壓人堆棧,對段間調(diào)用則要保護(hù)其下一條指令的偏移地址和段基地址,然后將子程序人口地址賦給IP(或CS和IP).中斷指令是因一些突發(fā)事件而使CPU暫時中止它正在運行的程序,轉(zhuǎn)去執(zhí)行一組專門的中斷服務(wù)程序,并在執(zhí)行完后返回原被中止處繼續(xù)執(zhí)行原程序。它是隨機(jī)的。在響應(yīng)中斷后CPU不僅要保護(hù)斷點(即INT指令下一條指令的段地址和偏移地址),還要將標(biāo)志寄存器FLAGS壓入堆棧保存。3.9 試判斷下列程序執(zhí)行后,BX中的內(nèi)容MOVCL,3MOVBX,0B7HROLBX,1RORBX,CL解:該程序段是首先將BX內(nèi)容不帶進(jìn)位循環(huán)

22、左移1位,再循環(huán)右移3位。即相當(dāng)于將原BX內(nèi)容不帶進(jìn)位循環(huán)右移2位,故結(jié)果為:(BX)=0C02DH3.10 按下列要求寫出相應(yīng)的指令或程序段。(1)寫出兩條使AX內(nèi)容為0的指令。(2)使BL寄存器中的高4位和低4位互換。(3)屏蔽CX寄存器的bll,b7和b3位。(4)測試DX中的b0和b8位是否為1。解:(1)MOVAX,0XORAX,AX;AX寄存器自身相異或,可使其內(nèi)容清0(2)MOVCL,4ROLBL,CL;將BL內(nèi)容循環(huán)左移4位,可實現(xiàn)其高4位和低4位的互換(3)ANDCX,0F777H;將CX寄存器中需屏蔽的位“與”0。也可用“或”指令實現(xiàn)(4)ANDDX,0101H;將需側(cè)試的

23、位“與”1,其余“與”0屏蔽掉CMPDX,0101H;與0101H比較JZONE;若相等則表示b0和b8位同時為1.3.11分別指出以下兩個程序段的功能:(1) (2)MOVCX,l0CLDLEASI,FIRSTLEADI,1200HLEADI,SECONDMOVCX,0FOOHSTDXORAX,AXREPMOVSBREPSTOSW解:(1)該段程序的功能是:將數(shù)據(jù)段中FIRST為最高地址的10個字節(jié)數(shù)據(jù)按減地址方向傳送到附加段SECOND為最高地址的向前10個單元中。(2)將附加段中偏移地址為1200H單元開始的0FOOH個字單元清0。1.12 執(zhí)行以下兩條指令后,標(biāo)志寄存器FLAGS的六個

24、狀態(tài)位各為什么狀態(tài)?MOVAX,84A0HADDAX,9460H解:執(zhí)行ADD指令后,6個狀態(tài)標(biāo)志位的狀態(tài)分別為:在兩個16位數(shù)進(jìn)行加法運算時,對CF、ZF、SF和OF會產(chǎn)生影響,但對PF和AF標(biāo)志位,只有其低8位的運算影響它們的狀態(tài)。各標(biāo)志位的狀態(tài)分別為:AF=0,PF=1,CF=1,ZF=0,SF=0,OF=1。1.13 將+46和-38分別乘以2,可應(yīng)用什么指令來完成?如果除以2呢?解:因為對二進(jìn)制數(shù),每左移一位相當(dāng)于乘以2,右移一位相當(dāng)于除以2。所以,將+46和-38分別乘以2,可分別用邏輯左移指令(SHL)和算術(shù)左移指令(SAL)完成。SHL指令針對無符號數(shù),SAL指令針對有符號數(shù)。

25、當(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的運算。1.14 已知AX=8060H,DX=03F8H,端口PORT1的地址是48H,內(nèi)容為40H;PORT2的地址是84H,內(nèi)容為85H。請指出下列指令執(zhí)行后的結(jié)果。(1)OUTDX,AL(2) INAL,PORT1(3) OUTDX,AX(4) INAX,48H(5) OUTPORT2,AX解:(1)將60H輸出到地址為03F8H的端口中。(2) 從PORT

26、1讀入一個字節(jié)數(shù)據(jù),執(zhí)行結(jié)果:(AL)=40H。(3) 將AX=8060H輸出到地址為03F8H的端口中。(4)由48H端口讀人16位二進(jìn)制數(shù)。(5)將8060H輸出到地址為84H的端口中。第4章匯編語言程序設(shè)計4.1 請分別用DB、DW、DD偽指令寫出在DATA開始的連續(xù)8個單元中依次存放數(shù)據(jù)11H、22H、33H、44H、55H、66H、77H、88H的數(shù)據(jù)定義語句.解:DB,DW,DD偽指令分別表示定義的數(shù)據(jù)為字節(jié)類型、字類型及雙字型.其定義形式為:DATADB11H,22H,33H,44H,55H,66H,77H,88HDATADW2211H,4433H,6655H,8877HDATA

27、DD44332211H,88776655H4.2 若程序的數(shù)據(jù)段定義如下,寫出各指令語句獨立執(zhí)行后的結(jié)果:DSEGSEGMENTDATA1DB10H,20H,30HDATA2DW10DUP(?)STRINGDB123DSEGENDS(1) MOVAL,DATA1(2) MOVBX,OFFSETDATA2(3) LEASI,STRINGADDDI,SI解:取變量DATA1的值.指令執(zhí)行后,(AL)=10H.變量DATA2的偏移地址.指令執(zhí)行后,(BX)=0003H.(3)先取變量STRING的偏移地址送寄存器SI,之后送SI的內(nèi)容與DI的內(nèi)容相加并將結(jié)果送DI.指令執(zhí)行后,(SI)=0017H;

28、(DI)=(DI)+0017H.4.3 試編寫求兩個無符號雙子長數(shù)之和的程序.兩數(shù)分別在MEM1和MEM2單元中,和放在SUM單元.解:DSEGSEGMENTMEM1DW1122H,3344HMEM2DW5566H,7788HSUMDW2DUP(?)DSEGENDSCSEGSEGMENTASSUMECS:CSEG,DS:DSEGSTART:MOVAX,DSEGMOVDS,AXLEABX,MEM1LEASI,MEM2LEADI,SUMMOVCL,2CLCAGAIN:MOVAX,BXADCAX,SIMOVDI,AXADDBX,2ADDSI,2ADDDI,2LOOPAGAINHLTCSEGENDSE

29、NDSTART4.4 試編寫程序,測試AL寄存器的第4位(bit4)是否為0?解:測試寄存器AL中某一位是否為0,可使用TEST指令、AND指令、移位指令等幾種方法實現(xiàn)。如:TESTAL,10HJZNEXTNEXT:或者:MOVCL,4SHLAL,CLJNCNEXT.NEXT:4.7 執(zhí)行下列指令后,AX寄存器的內(nèi)容是多少?TABLEDW10,20,30,40,50ENTRYDW3MOVBX,OFFSETTABLEADDBX,ENTRYMOVAX,BX解:(AX)=1E00H4.12畫圖說明下列語句分配的存儲空間及初始化的數(shù)據(jù)值。 1) DATA1DBBYTE,12,12H,2DUP(0,?,

30、3) 2) 2)DATA2DW4DUP(0,1,2),?,-5,256H解:(1)存儲空間分配情況如圖(a)所示。(2)存儲空間分配情況如圖(b)所示。第5章存儲器系統(tǒng)1.1 內(nèi)部存儲器主要分為哪兩類?它們的主要區(qū)別是什么?解:(1)分為ROM和RAM。(2)它們之間的主要區(qū)別是:ROM在正常工作時只能讀出,不能寫入。RAM則可讀可寫。斷電后,ROM中的內(nèi)容不會丟失,RAM中的內(nèi)容會丟失。1.6 若采用6264芯片構(gòu)成上述的內(nèi)存空間,需要多少片6264芯片?解:每個6264芯片的容量位8KB,故需432/8=54片。1.7 設(shè)某微型機(jī)的內(nèi)存RAM區(qū)的容量位128KB,若用2164芯片構(gòu)成這樣的

31、存儲器,需多少2164芯片?至少需多少根地址線?其中多少根用于片內(nèi)尋址?多少根用于片選譯碼?解:(1)每個2164芯片的容量為64Kx1bit,共需128/64X8=16片。( 2) 128KB容量需要地址線17根。( 3) 16根用于片內(nèi)尋址。( 4) 1根用于片選譯碼。注意,用于片內(nèi)尋址的16根地址線要通過二選一多路器連到2164芯片,因為2164芯片是DRAM,高位地址與低位地址是分時傳送的。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

32、)當(dāng)存儲芯片每個單元的字長小于所需內(nèi)存單元字長時,需要用多個芯片構(gòu)成滿足字長要求的存儲模塊,這就是位擴(kuò)展。(3)用戶在市場上購買內(nèi)存條進(jìn)行內(nèi)存擴(kuò)充,所做的是字?jǐn)U展的工作。5.10 74LS138譯碼器的接線圖如教材第245頁的圖5-47所示,試判斷其輸出端Y0#、Y3#、Y5#和Y7#所決定的內(nèi)存地址范圍。解:因為是部分地址譯碼(A17不參加譯碼),故每個譯碼輸出對應(yīng)2個地址范圍:Y0#:00000H01FFFH和20000H21FFFHY3#:06000H07FFFH和26000H27FFFHY5#:0A000H0BFFFH和2A000H2BFFFHY7#:0E000H0FFFFH和2E00

33、0H2FFFFH5.11 某8088系統(tǒng)用2764ROM芯片和6264SRAM芯片構(gòu)成16KB的內(nèi)存。其中,ROM的地址范圍為0FE000H0FFFFFH,RAM的地址范圍為0F0000H0F1FFFH。試?yán)?4LS138譯碼,畫出存儲器與CPU的連接圖,并標(biāo)出總線信號名稱。解:連接如下圖所示。5.12 敘述EPROM的編程過程,并說明EPROM和EEPROM的不同點。(不要求)解:(1)對EPROM芯片的編程過程詳見教材第215217頁。(2)EPROMSEEPROM勺不同之處為:。EPROM用紫外線擦除,EEPROMffl電擦除。EPROM是整片才S除,EEPROM可以整片擦除,也可以逐

34、個字節(jié)地擦除。5.13試說明FLASHEEPROM芯片的特點及28F040的編程過程。(不要求)解:(1)特點是:它結(jié)合了RAM和ROM的優(yōu)點,讀寫速度接近于RAM,斷電后信息又不會丟失。(2)28F040的編程過程詳見教材第222223頁。第6章輸入輸出和中斷技術(shù)。6.3主機(jī)與外部設(shè)備進(jìn)行數(shù)據(jù)傳送時,采用哪一種傳送方式,CPU的效率最高?(不要求)解:使用DMA傳送方式CPU的效率最高。這是由DMA的工作性質(zhì)所決定的。6.5某輸入接口的地址為0E54H,輸出接口的地址為01FBH,分別利用74LS244和74LS273作為輸入和輸出接口。試編寫程序,使當(dāng)輸入接口的bit1、bit4和bit7

35、位同時為1時,CPU將內(nèi)存中DATA為首址的20個單元的數(shù)據(jù)從輸出接口輸出;若不滿足上述條件則等待。解:首先判斷由輸入接口讀入數(shù)據(jù)的狀態(tài),若滿足條件,則通過輸出接口輸出一個單元的數(shù)據(jù);之后再判斷狀態(tài)是否滿足,直到20個單元的數(shù)據(jù)都從輸出接口輸出。LEASI,DATA;取數(shù)據(jù)偏移地址MOVCL,20;數(shù)據(jù)長度送CLAGAIN:MOVDX,0E54HWAITT:INAL,DX;讀入狀態(tài)值A(chǔ)NDAL,92H;屏蔽掉不相關(guān)位,僅保留bit1、bit4和bit7位狀態(tài)CMPAL,92H;判斷bit1、bit4和bit7位是否全為1JNZWAITT;不滿足bit1、bit4和bit7位同時為1則等待MOV

36、DX,01FBHMOVAL,SIOUTDX,AL;滿足條件則輸出一個單元數(shù)據(jù)INCSI;修改地址指針LOOPAGAIN;若20個單元數(shù)據(jù)未傳送完則循環(huán)6.14單片8259A能夠管理多少級可屏蔽中斷?若用3片級聯(lián)能管理多少級可屏蔽中斷?(不要求)解:因為8259A有8位可屏蔽中斷請求輸入端,故單片8259A能夠管理8級可屏蔽中斷。若用3片級聯(lián),即1片用作主控芯片,兩片作為從屬芯片,每一片從屬芯片可管理8級,則3片級聯(lián)共可管理22級可屏蔽中斷。6.17已知(SP)=0100H,(SS)=3500H,(CS)=9000H,(IP)=0200H,(00020H)=7FH,(00021H)=1AH,(0

37、0022H)=07H,(00023H)=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。中斷服務(wù)子程序的入口地址則存放在中斷向量表(8X4)所指向白連續(xù)4個單元中。所以,在執(zhí)行中斷指令并進(jìn)入響應(yīng)的中斷例程時,以上各寄存器的內(nèi)容分別為:SP=0100H6=00FAHSS=3500HIP=8X4=1A7FHCS=(8X4)+2=6C07HSP=0200H+2=0202H第7章常用數(shù)字接口電路7.10 某8255芯片的地址范圍為A380HA383H,工作于方式0,A口、B口為輸出口,現(xiàn)欲將PC4置0”,PC7置1”,試編寫初始化程序。解:該8255芯片的初始化程序包括置方式控制字及C口的按位

溫馨提示

  • 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

提交評論