計算機原理與設(shè)計習題_第1頁
計算機原理與設(shè)計習題_第2頁
計算機原理與設(shè)計習題_第3頁
計算機原理與設(shè)計習題_第4頁
計算機原理與設(shè)計習題_第5頁
已閱讀5頁,還剩25頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

簡述RISC和CISC的主要差別。CISC(ComplexInstructionSetComputer)是對那些具有復雜指令系統(tǒng)的CPU的總稱,CISC指令系統(tǒng)往往提供豐富的尋址方式,每條指令長短不一,常用的指令較短,不常用的指令較長,設(shè)計CPU時往往采用微程序的方法來實現(xiàn)這些指令,CISC的優(yōu)點是代碼緊湊,使用較少的存儲器,缺點是實現(xiàn)復雜的指令需要較多的芯片面積而且不利于流水線操作。RISC(ReducedInstructionSetComputer)是對那些具有簡單指令系統(tǒng)的CPU的總稱,RISC指令系統(tǒng)的特點有兩個,一是指令長度固定,這有利于流水線CPU的設(shè)計,二是所謂的Load/Store結(jié)構(gòu)。1假設(shè)我們有兩臺計算機M1和M2。M1的主頻是1GHz,M2的主頻是2GHz。每臺計算機的指令都有4類,它們的CPI分別為1、2、3和4。當同樣一個用高級語言編寫的程序在兩臺機器上分別編并譯執(zhí)行時,我們得到下表所列的結(jié)果。

計算機主頻CPI執(zhí)行指令數(shù)1234M11GHz50%35%10%5%20200000M22GHz10%10%30%50%22000000其中的百分比是執(zhí)行時每類指令出現(xiàn)的頻率。試分別計算該程序在兩臺機器上的執(zhí)行時間。如果單從執(zhí)行時間上考慮,哪一臺機器的性能更好?2解題思路:解:3試計算上題中兩臺計算機的MIPS(MillionInstructionsPerSecond),即每秒能執(zhí)行多少百萬條指令。解題思路:解:4如果使用1000000個CPU構(gòu)建一個并行系統(tǒng)并想得到單CPU系統(tǒng)500000倍的性能,那么程序中允許出現(xiàn)的串行執(zhí)行的代碼的比例應(yīng)該不超過多少才行?解題思路:解:5試用多個32位二選一多路器mux2x32設(shè)計一個32位的八選一多路器mux8x32。解題思路:解:ys2s10s11s00a0a1s01a2a3s02a4a5s03a6a76試分別用結(jié)構(gòu)描述、數(shù)據(jù)流描述和功能描述三種風格寫出帶有使能端的3-8譯碼器的VerilogHDL代碼。提示:功能描述風格的語句可用e=ena<<n。結(jié)構(gòu)描述

decoder3egate.v數(shù)據(jù)流描述

decoder3dataf.v功能描述

decoder3func.v7用VerilogHDL設(shè)計一個異步清零再加上使能端e的32位D觸發(fā)器(dffe32)。參考代碼dffe32.v參考代碼addsub32.v試設(shè)計一個32位的加減法器,增加一個輸出信號v來指出結(jié)果是否上溢。8用補碼計算下列各式中兩個數(shù)的和。

(1)x=0.11001y=-0.10111

(2)x=0.10010y=0.11000

解:9用補碼計算下列各式中兩個數(shù)的差。

(1)x=-0.01111y=0.00101

(2)x=0.11011y=-0.10010

解:10用補碼Booth乘法計算x=0.1010,y=-0.0110

的積x*y。解:11使用功能描述風格的VerilogHDL(casex)重新設(shè)計AlU并仿真。參考代碼alufunc.v在ALU中添加一位標志位v(輸出),判斷帶符號數(shù)計算時的溢出。參考代碼alu_v.v12試實現(xiàn)sla(ShiftLeftArithmetic)指令(算術(shù)左移、保持正負不變)。參考代碼sla.v用功能描述風格的VerilogHDL設(shè)計單周期CPU。參考代碼sccpu.v13假定某變量x存放在寄存器R1中為11111111111111111111101111000000B,則變量x在屏幕上用16進制顯示為0xFFFFFBC0。若x的類型為int,則x的值為-1088;對R1進行算術(shù)左移4位后的值在屏幕上顯示為0xFFFFBC00;對R1算術(shù)右移4位后為0xFFFFFFBC;對R1邏輯右移4位后為0x0FFFFFBC。14以下是用C語言寫的一個傳統(tǒng)的While語句:while(save[i]==k)i+=1;假設(shè)i和k對應(yīng)于寄存器$s3和$s5,數(shù)組save的基址存放在$s6中,對應(yīng)的MIPS匯編代碼為:假定loop的開始位置在內(nèi)存80000處,則上述循環(huán)的MIPS機器碼為:根據(jù)上述給出的敘述,回答下列問題。(1)上述給出的MIPS機器碼中有一處錯誤,你能找出來嗎?(2)MIPS內(nèi)存空間的編址單位是多少?(3)解釋為什么指令“sll$t1,$s3,2”能實現(xiàn)4*i的功能?(4)該循環(huán)中哪些是R-型指令?哪些是I-型指令?(5)$t0和$s6的編號各為多少?(6)Exit的值是多少?要求說明其含義和計算過程。(7)指令“jloop”的操作碼是什么(用二進位表示)?(8)MIPS中分支指令和跳轉(zhuǎn)指令的跳轉(zhuǎn)范圍分別是什么?(9)數(shù)組save的每個元素占幾個字節(jié)?15(1)上述給出的MIPS機器碼中有一處錯誤,你能找出來嗎?答:第一條指令中的倒數(shù)第二個字段的值應(yīng)該是2,而不是4,表示左移的位數(shù)。(2)MIPS內(nèi)存空間的編址單位是多少?答:字節(jié)。從上圖可看出,每條指令32位,占4個地址,所以一個地址中有8位。(3)解釋為什么指令“sll$t1,$s3,2”能實現(xiàn)4*i的功能。答:因為這是左移指令,左移2位,相當于乘22=4。(4)該循環(huán)中哪些是R-型指令?哪些是I-型指令?答:從上圖可看出,第1-2條為R-型,第3-5條為I-型。(5)$t0和$s6的編號各為多少?答:從第3和4條指令,可看出$t0的編號為8,第2條指令看出$s6的編號為22。16(6)Exit的值是多少?要求說明其含義和計算過程。答:Exit的值是80024,其含義是循環(huán)結(jié)束時跳出循環(huán)后執(zhí)行的首條指令的地址,由當前條件轉(zhuǎn)移指令(分支指令)的地址80012,加上4得到下條指令的地址,然后再加上相對位移量2*4得到。80012+4+2*4=80024。(如果答Exit為2也算對,此時其含義就是轉(zhuǎn)移到的目標指令相對于當前條件轉(zhuǎn)移指令的指令條數(shù),所以計算時,需要將指令條數(shù)轉(zhuǎn)換為地址位移量,所以要乘以4。)(7)指令“j20000”的操作碼是什么(用二進位表示)?答:其操作碼為“000010”。17(8)MIPS中分支指令和跳轉(zhuǎn)指令的跳轉(zhuǎn)范圍分別是什么?答:因為分支指令(條件轉(zhuǎn)移指令)的相對位移量的范圍為:-215到+(215-1),但這是相對于分支指令的下條指令而言的,所以,相對于當前分支指令而言,轉(zhuǎn)移范圍為:-(215-1)到+215條指令。即:往前跳,最多跳到第32767條指令(相當于32767x4=131068個單元),往后跳,最多跳到第32768條指令(相當于32768x4=131072個單元)。因為無條件跳轉(zhuǎn)指令的目標地址范圍為:0到226-1(相對于下條指令),所以,相對于本條指令而言,其轉(zhuǎn)移范圍為:1到226條指令。即:相對于當前跳指令而言,最近就跳到下條指令,最遠跳到后面的第226條指令。(9)數(shù)組save的每個元素占幾個字節(jié)?答:因為每次循環(huán)取數(shù),其下標地址都要乘以4,所以是4個字節(jié)。18假設(shè)各主要功能單元的操作時間為:

讀存儲器:10ns,寫存儲器:5nsALU和加法器:10ns寄存器堆(讀/寫):5ns而MUX、控制單元、PC、擴展器和傳輸線路沒有延遲,若各類指令的執(zhí)行次數(shù)占總數(shù)的比例為:20%取數(shù)、10%存數(shù)、50%ALU、15%分支、5%跳轉(zhuǎn),則下面實現(xiàn)方式中,哪個更快?快多少?每條指令在一個固定長度的時鐘周期內(nèi)完成每條指令在一個時鐘周期內(nèi)完成,但時鐘周期是可以根據(jù)指令類型動態(tài)變化的。19解:20假設(shè)某臺機器有4級中斷,其硬件排隊優(yōu)先次序為1>2>3>4,中斷處理優(yōu)先次序為3>1>2>4,要求:(1)給出每級中斷的中斷屏蔽碼(假設(shè)“1”表示允許,“0”表示禁止)(2)假設(shè)在執(zhí)行主程序時,1、2、3、4級中斷同時有請求,請畫出CPU執(zhí)行程序的軌跡。21中斷屏蔽位表中斷級別中斷級屏蔽位1級2級3級4級目態(tài)1111第1級0010第2級1010第3級0000第4級111022用戶程序中斷請求中斷處理程序1234①②③④中斷請求處理圖23計算機系統(tǒng)發(fā)生異常事件或外設(shè)完成I/O任務(wù)時,一般都通過中斷方式請求CPU執(zhí)行相應(yīng)的中斷服務(wù)程序來處理。在以下給出的情況中,哪個不會引起中斷? A.鍵盤緩沖滿 B.一個字符打印完 C.運算結(jié)果為0 D.頁面失效(miss)答案:C24試比較單周期CPU與多周期CPU各自的優(yōu)缺點。單周期CPU用一個時鐘周期執(zhí)行一條指令,而確定時鐘周期的時間長度時要考慮執(zhí)行時間最長的指令,以此定出CPU的時鐘頻率,不管指令的復雜程度如何,單周期CPU都花費相同的時間去執(zhí)行,這造成了時間上的浪費;多周期CPU的中心思想是把一條指令的執(zhí)行分成若干個小周期,根據(jù)每條指令的復雜程度使用不同的小周期去執(zhí)行,這可以更有效利用時間,有利于流水線設(shè)計,但控制部件較單周期CPU的更復雜一些。25我們在敘述單周期CPU與多周期CPU的設(shè)計方法時使用了相同的測試程序并給出了測試結(jié)果,從而我們知道了兩種CPU在執(zhí)行相同的測試程序時所用的時間。假設(shè)多周期CPU的一個時鐘周期是4ns,而單周期CPU的一個時鐘周期比多周期CPU的5倍略短一些,比如19ns。試從執(zhí)行時間上比較兩種CPU執(zhí)行測試程序時的性能。26解:測試程序中共執(zhí)行32條指令,其中:CPI5432指令數(shù)11524271、什么是存儲器的帶寬?若存儲器的數(shù)據(jù)總線寬度為16位,存儲周期為100ns,則存儲器的帶寬是多少?答:存儲器的帶寬是指單位時間內(nèi)存儲器所能存取的最大信息量,通常以bps或Bps作為度量單位。數(shù)據(jù)總線寬度為16位,存儲周期為100ns的存儲器的帶寬為:

16b/(100ns)=16b/(100*10-9s)=160Mbps2、一個字長為32位的計算機,其存儲容量為128KB,按字節(jié)編址和按字編址的尋址范圍各是多少?答:128KB=217B,如果按字節(jié)編址,需要217個地址,則需要17位地址線,尋址范圍為0~217-1;若按字編址,則每個字占一個地址,128KB是32K(215)個字,需要15根地址線,尋址范圍為0~215-1。283、一個64K×32位的存儲器,按字節(jié)尋址,其地址線和數(shù)據(jù)線各是多少位?答:32位說明數(shù)據(jù)線為32位;64K=216,按照字節(jié)尋址,需要16+2=18位地址線。4、用2K×4位的存儲芯片構(gòu)成一個具有14根地址線、8根數(shù)據(jù)線的存儲器,試問:

(1)該存儲器的存儲容量是多少KB?

(2)需要幾片上述存儲芯片?答:(1)數(shù)據(jù)線為8根,即按字節(jié)尋址;地址線為14根,即尋址空間大小為214,故存儲容量為16KB。

(2)需要2K×4位的芯片數(shù)目為:

(16K/2K)×(8/4)=8×2=16。295、假定某計算機的cache共16行,開始為空,塊大小為1個字,采用直接映射方式。CPU執(zhí)行某程序時,依次訪問以下地址序列:2,3,11,16,21,13,64,48,19,11,3,22,4,27,6和11。要求:

(1)說明每次訪問是命中或缺失,試計算訪問上述地址序列的命中率。

(2)若cache數(shù)據(jù)區(qū)容量不變,而塊大小改為4個字,則上述地址序列的命中率又如何?30(1)訪問缺失的情況有兩種:一是Cache塊內(nèi)未填充有效數(shù)據(jù)而引發(fā)的缺失;二是Cache塊內(nèi)存在有效數(shù)據(jù),但該數(shù)據(jù)不是需要的數(shù)據(jù),即因采用直接映射方式,其它地址的數(shù)據(jù)映射到并占用此塊,發(fā)生沖突,從而引發(fā)缺失。

將訪存地址序列2,3,11,16,21,13,64,48,19,11,3,22,4,27,6,11對16進行求余,可得到各地址映射對應(yīng)的C

溫馨提示

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

評論

0/150

提交評論