版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第5章中央處理器本章內(nèi)容:CPU的組成和功能指令周期時(shí)序產(chǎn)生器和控制方式微程序控制器微程序設(shè)計(jì)技術(shù)硬布線控制器傳統(tǒng)和現(xiàn)代CPU介紹5.1CPU的功能和組成CPU的功能程序是存放在內(nèi)存儲(chǔ)器中能夠解決某個(gè)問題的一組指令序列,計(jì)算機(jī)中能夠完成自動(dòng)取出指令并執(zhí)行指令的部件稱為中央處理器,簡(jiǎn)稱CPU。CPU有如下基本功能:-指令控制:保證機(jī)器按順序執(zhí)行程序-操作控制:把指令的各種操作信號(hào)送往相應(yīng)的部件,從而控制這些部件按指令的要求進(jìn)行動(dòng)作。-時(shí)間控制:保證指令的各種操作信號(hào)按照嚴(yán)格的時(shí)序關(guān)系送往相應(yīng)的部件,使計(jì)算機(jī)有條不紊的按序工作。-數(shù)據(jù)加工:數(shù)據(jù)加工就是對(duì)數(shù)據(jù)進(jìn)行算術(shù)運(yùn)算和邏輯運(yùn)算處理,這是CPU的基本功能。CPU的基本組成-傳統(tǒng)CPU基本組成:運(yùn)算器、控制器。(在諾曼機(jī)的定義中)-現(xiàn)代CPU基本組成:運(yùn)算器、控制器、浮點(diǎn)運(yùn)算器和Cache??刂破鞯慕M成:程序計(jì)數(shù)器、指令寄存器、指令譯碼器、時(shí)序產(chǎn)生器和操作控制器??刂破鞯闹饕δ埽?)從內(nèi)存中取出指令,并指出下一條指令在內(nèi)存中的位置。2)對(duì)指令進(jìn)行譯碼并產(chǎn)生相應(yīng)的控制信號(hào)啟動(dòng)規(guī)定的動(dòng)作。3)控制CPU與內(nèi)存或CPU與輸入/輸出設(shè)備之間數(shù)據(jù)傳遞。運(yùn)算器的組成:算術(shù)邏輯單元(ALU)、通用寄存器、數(shù)據(jù)緩沖寄存器和狀態(tài)寄存器。運(yùn)算器的主要功能:1)執(zhí)行所有的算術(shù)運(yùn)算。2)執(zhí)行所有的邏輯運(yùn)算。CPU內(nèi)部的主要寄存器程序計(jì)數(shù)器PC用來確定下一條待執(zhí)行的指令在指令存儲(chǔ)器中的地址,順序?qū)ぶ稰C+1->PC;跳躍尋址將指令中的地址碼裝入。數(shù)據(jù)緩沖寄存器用來暫存ALU的運(yùn)算結(jié)果或者由內(nèi)存讀出或者向內(nèi)存寫入的數(shù)據(jù)或者指令狀態(tài)寄存器用來保存上次算術(shù)或邏輯結(jié)果的某些特性,例如運(yùn)算結(jié)果是否有進(jìn)位、運(yùn)算結(jié)果是否溢出等。指令譯碼器對(duì)指令的操作碼進(jìn)行測(cè)試,向操作控制器發(fā)送具體操作的信號(hào)。通用寄存器組,暫存參加運(yùn)算的操作數(shù)或運(yùn)算結(jié)果,為ALU提供工作區(qū)。目前的CPU中有16個(gè)、32個(gè)或者更多的累加寄存器構(gòu)成通用寄存器組??刂破鬟\(yùn)算器數(shù)據(jù)地址寄存器用來保存CPU所訪問的數(shù)據(jù)存儲(chǔ)器單元的地址,在CPU讀寫數(shù)據(jù)存儲(chǔ)器的期間驅(qū)動(dòng)數(shù)據(jù)地址總線上的地址信息。Cache指令寄存器保存當(dāng)前執(zhí)行的指令,是指令譯碼器的輸入。CPU取指時(shí)通過指令總線將指令送指令寄存器。操作控制器與時(shí)序產(chǎn)生器
在CPU中有很多寄存器,信息從什么地方開始,中間經(jīng)過哪個(gè)寄存器,最后傳送到哪個(gè)寄存器,都要加以控制。在各寄存器之間建立數(shù)據(jù)通路的任務(wù),這是由稱為操作控制器的部件來完成的。操作控制器的功能:根據(jù)指令操作碼和時(shí)序信號(hào),產(chǎn)生各種操作控制號(hào),以便正確地建立數(shù)據(jù)通路,從而完成取指令和執(zhí)行指令的控制。根據(jù)設(shè)計(jì)方法不同,操作控制器可分為:1)采用時(shí)序邏輯技術(shù)實(shí)現(xiàn)的硬布線控制器
2)采用存儲(chǔ)邏輯實(shí)現(xiàn)的微程序控制器3)前兩種方式的組合的控制器
操作控制器對(duì)各部件產(chǎn)生的控制信號(hào)必須嚴(yán)格遵守時(shí)序關(guān)系,這是由時(shí)序產(chǎn)生器的部件完成的。時(shí)序產(chǎn)生器的功能:對(duì)各種操作實(shí)施時(shí)間上的限制。5.2
指令周期
CPU從內(nèi)存取出一條指令并執(zhí)行該指令;緊接著又是取指令,執(zhí)行指令……,如此周而復(fù)始構(gòu)成了一個(gè)封閉的循環(huán)。除非遇到停機(jī)指令,否則這個(gè)循環(huán)將一直繼續(xù)下去,所以計(jì)算機(jī)能夠自動(dòng)的工作下去。開始取指令執(zhí)行指令
指令和數(shù)據(jù)都以二進(jìn)制的形式存放在內(nèi)存中,CPU能夠準(zhǔn)確的判斷哪些是指令,哪些是數(shù)據(jù)并送往相應(yīng)的寄存器并進(jìn)行相應(yīng)的操作,這是計(jì)算機(jī)自動(dòng)工作的前提。本節(jié)討論一些典型指令的工作周期,加深對(duì)CPU工作過程的理解。指令周期的概念-時(shí)鐘周期:時(shí)鐘周期是CPU的基本時(shí)間計(jì)量單位,它是CPU一切操作的計(jì)時(shí)標(biāo)準(zhǔn)和基本控制信號(hào),它由計(jì)算機(jī)的主頻決定。
8086的主頻為5MHZ,則一個(gè)時(shí)鐘周期為200ns80486主頻為100MHZ,則一個(gè)時(shí)鐘周期為10ns-機(jī)器周期(CPU周期):CPU通過總線從內(nèi)存讀取一個(gè)機(jī)器字的時(shí)間稱為一個(gè)CPU周期,一般需要4個(gè)時(shí)鐘周期,分別稱為T1、T2、T3、T4狀態(tài)。機(jī)器周期T1T2T3T4CLK時(shí)鐘周期CLK該機(jī)器周期讀取的一個(gè)機(jī)器字可以是指令也可以是數(shù)據(jù)。如果是指令,該機(jī)器周期稱取指周期-指令周期:執(zhí)行一條指令需要經(jīng)過讀取指令,指令譯碼及指令執(zhí)行的過程,把執(zhí)行一條指令所需要的時(shí)間稱為指令周期。不同指令的指令周期是不等長(zhǎng)的,最短時(shí)間為兩個(gè)機(jī)器周期,一個(gè)機(jī)器周期取指令,一個(gè)機(jī)器周期執(zhí)行指令;有的復(fù)雜的指令需要更多機(jī)器周期。CLK機(jī)器周期機(jī)器周期機(jī)器周期
(取指令)(取有效地址)(執(zhí)行指令)指令周期T1T2T3T4T1T2T3T4T1T2T3T4非訪存指令T1T2T3T4T1T2T3T4機(jī)器周期(取指令)指令周期機(jī)器周期
(執(zhí)行指令)訪存指令
下面給出6條指令組成的一個(gè)程序,通過每一條指令的取指階段和執(zhí)行階段的分解動(dòng)作,了解指令的指令周期和CPU執(zhí)行程序的過程。
內(nèi)存地址
助記符說明
101
MOVR0,R1傳送指令:非訪存指令
102
LADR1,6取數(shù)指令:訪存指令
103
ADDR1,R2加法指令:非訪存指令
104
STOR2,(R3)存數(shù)指令:訪存指令
105
JMP101跳轉(zhuǎn)指令:程序控制指令
106ANDR1,R3與指令:非訪存指令指令存儲(chǔ)器數(shù)據(jù)存儲(chǔ)器
內(nèi)存地址
數(shù)據(jù)說明
5
***
6
100LAD指令的操作數(shù)
7
***
8***
…
…
3040STO指令的操作數(shù)MOV指令的指令周期
MOV是一條典型的RR指令,屬于非訪存指令,它需要兩個(gè)機(jī)器周期,其中取指令階段需要一個(gè)機(jī)器周期,執(zhí)行指令階段需要一個(gè)機(jī)器周期。第一個(gè)機(jī)器周期(取指令):
-從指存取出指令
-程序計(jì)數(shù)器PC加1-對(duì)操作碼譯碼并測(cè)試第二個(gè)機(jī)器周期(執(zhí)行指令):操作控制器按照指令的要求發(fā)出控制信號(hào),完成指令要求的操作,在R0和R1之間傳遞數(shù)據(jù)。MOV指令取值周期102+100101012030MOVR0,R110040MOV指令執(zhí)行周期10200102030MOVR0,R1101010040LAD指令的指令周期
LAD是一條RS型訪存指令,它需要三個(gè)機(jī)器周期,其中取指令階段需要一個(gè)機(jī)器周期,過程與MOV指令完全相同,執(zhí)行指令階段需要兩個(gè)機(jī)器周期。第一個(gè)機(jī)器周期(取指令):
-從指存取出指令
-程序計(jì)數(shù)器PC加1-對(duì)操作碼譯碼并測(cè)試第二個(gè)機(jī)器周期(執(zhí)行指令):將指令中的地址碼6送數(shù)據(jù)地址寄存器驅(qū)動(dòng)數(shù)存。第三個(gè)機(jī)器周期(執(zhí)行指令):從數(shù)存6單元取數(shù)并送寄存器R1。LAD指令取值周期103+110101022030LADR1,610040LAD指令執(zhí)行周期10310102030LADR1,6610040100100ADD指令的指令周期
ADD是一條RR型非訪存指令,它需要兩個(gè)機(jī)器周期,其中取指令階段需要一個(gè)機(jī)器周期,過程與MOV指令完全相同,執(zhí)行指令階段需要一個(gè)機(jī)器周期。第一個(gè)機(jī)器周期(取指令):
-將PC寄存器中的103送指令地址總線,啟動(dòng)讀命令
-所選指存103單元的ADD指令經(jīng)指令總線送入指令寄存器IR
-程序計(jì)數(shù)器PC加1,變?yōu)?04,為下一條指令做好準(zhǔn)備-指令寄存器的操作碼(OP)送指令譯碼器被譯碼測(cè)試第二個(gè)機(jī)器周期(執(zhí)行指令):
-選中R1和R2通用寄存器,R1為源寄存器,R2為目標(biāo)寄存器
-ALU做R1和R2的加法運(yùn)算
-ALU送結(jié)果120到數(shù)據(jù)總線
-將數(shù)據(jù)總線的數(shù)據(jù)打入緩沖寄存器DR,運(yùn)算結(jié)果特征位保存在狀態(tài)寄存器PSW中
-將緩沖寄存器DR中的數(shù)據(jù)打入R2,R2的內(nèi)容變?yōu)?20ADD指令執(zhí)行周期1041002030ADDR1,R21201010040120STO指令的指令周期
ST0是一條RS型訪存指令,它需要三個(gè)機(jī)器周期,其中取指令階段需要一個(gè)機(jī)器周期,整個(gè)過程與MOV指令完全相同,執(zhí)行指令階段需要兩個(gè)機(jī)器周期。第一個(gè)機(jī)器周期(取指令):
-從指存取出指令
-程序計(jì)數(shù)器PC加1-對(duì)操作碼譯碼并測(cè)試第二個(gè)機(jī)器周期(執(zhí)行指令):將通用寄存器R3中的地址碼30送數(shù)據(jù)地址寄存器驅(qū)動(dòng)數(shù)存。第三個(gè)機(jī)器周期(執(zhí)行指令):從寄存器R2中的數(shù)據(jù)120送數(shù)據(jù)總線寫入數(shù)存30單元。STO指令執(zhí)行周期10510030STOR2,(R3)101004030120120JMP指令的指令周期
JMP是一條程序控制指令,需要兩個(gè)機(jī)器周期,其中取指令階段需要一個(gè)機(jī)器周期,執(zhí)行指令階段需要一個(gè)機(jī)器周期。第一個(gè)機(jī)器周期(取指令):
-從指存取出指令
-程序計(jì)數(shù)器PC加1-對(duì)操作碼譯碼并測(cè)試第二個(gè)機(jī)器周期(執(zhí)行指令):將JMP指令的地址碼101送程序計(jì)數(shù)器PC。JMP指令執(zhí)行周期10610030JMP10110100120120101用方框圖語言表示指令周期-方框代表一個(gè)CPU周期,方框中的內(nèi)容表示數(shù)據(jù)通路的操作或某種控制操作。-菱形表示某種判別或測(cè)試,不過時(shí)間上它依附于緊接它的前面一個(gè)方框的CPU周期,而不單獨(dú)占用一個(gè)CPU周期。-~符號(hào)是公操作符號(hào),表示一條指令已經(jīng)執(zhí)行完畢而轉(zhuǎn)入公操作(CPU每執(zhí)行完一條指令,都要測(cè)試外部設(shè)備有無中斷請(qǐng)求,DMA控制器有無DMA請(qǐng)求,這些操作稱為公操作)。如果沒有公操作,CPU轉(zhuǎn)入下一條指令的執(zhí)行。-DBUS表示數(shù)據(jù)總線-IBUS表示指令總線-ABUS(D)表示數(shù)據(jù)地址總線-ABUS(I)表示指令地址總線-RD(I)表示讀指存,RD(D)表示讀數(shù)存,-WE(D)表示寫數(shù)存取指周期MOVLADADDSTOJMPR1->ALUALU->DRDR->R0IR->PCIR->ARAR->ABUS(D)M->DRDR->R1RD(D)R1->ALUR2->ALUALU->DRDR->R2執(zhí)行周期WE(D)R3->ARR2->MPC->ABUS(I)M->IBUS->IRPC+1->PC譯碼測(cè)試RD(I)例:某計(jì)算機(jī)有如下部件:ALU,主存M,數(shù)據(jù)寄存器DR,地址寄存器AR,程序計(jì)數(shù)器PC,指令寄存器IR,通用寄存器R0—R3,暫存器C和D。1)請(qǐng)將各邏輯部件組成一個(gè)計(jì)算機(jī)的數(shù)據(jù)通路,并標(biāo)明數(shù)據(jù)流向。2)畫出“ADDR1,(R2)”指令的指令周期流程圖,指令功能是將R1中的數(shù)據(jù)和R2所指內(nèi)存單元的數(shù)據(jù)相加結(jié)果送R1(假設(shè)該指令地址已在PC中)。移位器DCPCIRR3R2R1R0ARMDRALU+1移位器DCPCIRR3R2R1R0ARMDRALU+1ADDR1,[R2]指令的指令周期流程圖如下所示,該指令功能是將R1中的數(shù)據(jù)和R2所指內(nèi)存單元的數(shù)據(jù)相加結(jié)果送R1。M→DR→IR(R1)→C(R2)→ARM→DR→D(C)+(D)→R1
譯碼(PC)→AR,(PC)+1送當(dāng)前指令地址到AR,PC+1取當(dāng)前指令到IR,指令譯碼取R1操作數(shù)→C暫存器R2中的內(nèi)容是內(nèi)存地址從內(nèi)存取出數(shù)→D暫存器暫存器C和D中的數(shù)相加后送R1例:某32位CPU其內(nèi)部結(jié)構(gòu)如下圖所示,其中一個(gè)累加寄存器AC,一個(gè)狀態(tài)條件寄存器和其它四個(gè)寄存器,各部分之間的連線表示數(shù)據(jù)通路,箭頭表示信息傳送方向。標(biāo)出A~D四個(gè)寄存器的名稱。寫出CPU從內(nèi)存中讀取指令的全過程。CPU主存儲(chǔ)器MACACBDALU狀態(tài)寄存器指令譯碼器+15.3時(shí)序產(chǎn)生器時(shí)序信號(hào)的理解
CPU從內(nèi)存取出的指令送指令寄存器,取出的數(shù)據(jù)送累計(jì)器AC或運(yùn)算器ALU,但指令和數(shù)據(jù)都是以二進(jìn)制形式存放在存儲(chǔ)器中,CPU如何知道取得的是指令還是數(shù)據(jù)?
CPU識(shí)別指令和數(shù)據(jù)的方法:從時(shí)間上來說,取指令事件發(fā)生在指令周期的第一個(gè)CPU周期中,即發(fā)生在“取指令”階段,而取數(shù)據(jù)事件發(fā)生在指令周期的后面幾個(gè)CPU周期中,即發(fā)生在“執(zhí)行指令”階段。不僅如此,CPU還將一個(gè)機(jī)器周期分為分為若干個(gè)更小的時(shí)間段(1個(gè)機(jī)器周期一般等于4個(gè)時(shí)鐘周期),同時(shí)規(guī)定在1個(gè)時(shí)間段內(nèi)CPU的動(dòng)作。這種時(shí)間的約束對(duì)CPU來說是必要的而且非常嚴(yán)格,這種時(shí)間約束就是時(shí)序控制,是由時(shí)序產(chǎn)生器的時(shí)序信號(hào)來控制的。CLKT1T2T3T4時(shí)鐘周期機(jī)器周期機(jī)器周期T1T2T3T4T1T2T3T4時(shí)序產(chǎn)生器如何生成規(guī)律的T1,T2,T3,T4信號(hào)和其他信號(hào)序列呢?時(shí)序產(chǎn)生器的構(gòu)成時(shí)序信號(hào)產(chǎn)生器由:時(shí)鐘源、環(huán)形脈沖發(fā)生器、節(jié)拍脈沖和讀寫時(shí)序譯碼邏輯、啟??刂七壿嫷炔糠纸M成。
環(huán)形脈沖發(fā)生器時(shí)鐘脈沖源節(jié)拍脈沖和讀寫時(shí)序譯碼邏輯RD’WE’啟??刂七壿婻D0WE0T10T30T20T40啟動(dòng)停止RDWET1T3T2T4C1C2C3C4時(shí)鐘周期CLK-時(shí)鐘源時(shí)鐘源用來為環(huán)形脈沖發(fā)生器提供頻率穩(wěn)定且電平匹配的方波時(shí)鐘脈沖信號(hào)。它通常由石英晶體振蕩器和與非門組成的正反饋振蕩電路組成,其輸出送至環(huán)形脈沖發(fā)生器。設(shè)時(shí)鐘源的頻率為5MHZ,則時(shí)鐘源的脈沖周期為1/5M=200ns時(shí)鐘周期是CPU的基本時(shí)間計(jì)量單位-環(huán)形脈沖發(fā)生器環(huán)形脈沖發(fā)生器的作用是產(chǎn)生一組有序的間隔相等或不等的脈沖序列,通過譯碼電路來產(chǎn)生最后所需的節(jié)拍脈沖。為了在節(jié)拍脈沖上不帶干擾毛刺,環(huán)形脈沖發(fā)生器通常采用循環(huán)移位寄存器形式。
CLK0123457689C4C1C2C3時(shí)鐘周期在環(huán)形脈沖發(fā)生器的作用下,4個(gè)D型觸發(fā)器的輸出分別如下:-節(jié)拍脈沖譯碼為了在一個(gè)機(jī)器周期內(nèi)產(chǎn)生4個(gè)等間隔的節(jié)拍脈沖,我們給出譯碼邏輯如下:T10=C1·C2T20=C2·C3T30=C3T40=C1C4C1C2C3T10=C1·C2T10T20=C2·C3T20CLK0123457689C4C1C2C3T30=C3T30T40=C1T40CLK0123457689
在譯碼電路的作用下,一個(gè)機(jī)器周期內(nèi)產(chǎn)生4個(gè)等間隔的節(jié)拍脈沖。T10T20T30T40機(jī)器周期CLK0123457689注意:T10、T20、T30、T40信號(hào)在機(jī)器加電后,即時(shí)鐘脈沖源接通電源后便按照順序周而復(fù)始的產(chǎn)生機(jī)器需要的原始的機(jī)器周期序列。
其中RD0,WE0是經(jīng)過譯碼邏輯產(chǎn)生的對(duì)存儲(chǔ)器進(jìn)行讀/寫操作的時(shí)序信號(hào)。RD’和WE’是來自控制器的控制信號(hào),他們的持續(xù)時(shí)間都是一個(gè)機(jī)器周期。RD’CLK0123457689C2C3WE’-讀寫信號(hào)譯碼存儲(chǔ)器的讀/寫信號(hào)必須符合時(shí)序的要求,下面給出讀寫信號(hào)的譯碼邏輯:RD0=(C2∪C3)·RD’
WE0=(C2∪C3)·WE’RD
0WE0-啟??刂七壿嬘捎赥10~T40信號(hào)在機(jī)器加電后便按照順序周而復(fù)始的產(chǎn)生,然而只有在啟動(dòng)機(jī)器運(yùn)行的時(shí)候才需要CPU工作的機(jī)器周期信號(hào)。利用啟停電路控制T10~T40的發(fā)送,經(jīng)過啟停電路的T10~T40我們記做T1、T2、T3、T4。這是CPU工作時(shí)需要的機(jī)器周期的4個(gè)T狀態(tài)。讀寫信號(hào)一般為低電平有效,所以啟??刂七壿嬤€要將RD0和WE0轉(zhuǎn)化為RD和WE.這才是讀寫存儲(chǔ)器的信號(hào)。T1T2T3T4CLK0123457689RDWE控制方式機(jī)器指令的指令周期是由數(shù)目不等的機(jī)器周期組成,一條指令使用的機(jī)器周期的多少反映了指令動(dòng)作的復(fù)雜程度;對(duì)一個(gè)機(jī)器周期而言,由數(shù)目不等的操作控制信號(hào)組成,操作控制信號(hào)所需的時(shí)間也不相同。不同操作控制信號(hào)的時(shí)序控制方法稱為控制器的控制方式-同步控制方式指令執(zhí)行的機(jī)器周期數(shù)固定不變,稱為同步控制方式。同步控制方式有下面三種選擇方案:1)采用完全統(tǒng)一的機(jī)器周期執(zhí)行各種不同的指令。以控制信號(hào)最復(fù)雜繁瑣的指令的機(jī)器周期作為標(biāo)準(zhǔn),意味著對(duì)簡(jiǎn)單的操作和指令有時(shí)間的浪費(fèi)。2)采用不定長(zhǎng)機(jī)器周期。對(duì)簡(jiǎn)單指令用較短的機(jī)器周期完成。對(duì)較復(fù)雜的指令利用較長(zhǎng)的機(jī)器周期完成。
機(jī)器周期機(jī)器周期(取指令)(執(zhí)行指令)指令周期T1T2T3T4T1T2T3機(jī)器周期機(jī)器周期(取指令)(執(zhí)行指令)T1T2T3T4T1T2T3T4TT延長(zhǎng)3)
采用中央控制和局部控制的方式。大部分指令安排在固定的機(jī)器周期內(nèi)完成。對(duì)復(fù)雜的指令利用較長(zhǎng)的機(jī)器周期。
-異步控制方式?jīng)]有嚴(yán)格的時(shí)鐘周期和機(jī)器周期,每條指令、每個(gè)操作控制信號(hào)需要多少時(shí)間就占用多少時(shí)間,當(dāng)控制器發(fā)出某一操作控制信號(hào)后,等待執(zhí)行部件完成操作后發(fā)“回答”信號(hào),再開始新的操作。-聯(lián)合控制方式該方式為同步控制和異步控制相結(jié)合的方式。1)大部分指令安排在固定的機(jī)器周期中,對(duì)某些時(shí)間難以確定的操作則以執(zhí)行部件的“回答”信號(hào)作為本次操作的結(jié)束;2)機(jī)器周期的節(jié)拍脈沖數(shù)固定,但是各條指令周期的機(jī)器周期數(shù)不固定。目前廣泛采用,一個(gè)機(jī)器周期有4個(gè)節(jié)拍脈沖,即4個(gè)T狀態(tài),指令周期可能是2、3或者4個(gè)機(jī)器周期。5.4微程序控制器根據(jù)設(shè)計(jì)方法不同,操作控制器可分為:1)采用時(shí)序邏輯技術(shù)實(shí)現(xiàn)的硬布線控制器(組合邏輯控制器)
2)采用存儲(chǔ)邏輯實(shí)現(xiàn)的微程序控制器優(yōu)點(diǎn):微程序控制器同硬布線控制器相比較具有規(guī)整性、靈活性、可維護(hù)性等一系列優(yōu)點(diǎn),因而在計(jì)算機(jī)設(shè)計(jì)中逐漸取代了早期采用的硬布線控制器,并已被廣泛地應(yīng)用?;舅枷耄何⒊绦蛟O(shè)計(jì)技術(shù)是利用軟件方法來設(shè)計(jì)硬件的一門技術(shù)。即仿照通常的解題程序的方法,把操作控制信號(hào)編成所謂的“微指令”,存放到一個(gè)只讀存儲(chǔ)器里。當(dāng)機(jī)器運(yùn)行時(shí)一條又—條地讀出這些“微指令”,從而產(chǎn)生全機(jī)所需要的各種操作控制信號(hào),使相應(yīng)部件執(zhí)行所規(guī)定的操作。微命令和微操作一臺(tái)計(jì)算機(jī)分為兩個(gè)部分,控制部件和執(zhí)行部件,控制器就是控制部件,而運(yùn)算器,存儲(chǔ)器,外圍設(shè)備對(duì)控制器來說就是執(zhí)行部件??刂撇考蛨?zhí)行部件的聯(lián)系:1)控制部件通過控制總線向執(zhí)行部件發(fā)送的各種控制信號(hào)稱為微命令,執(zhí)行部件接受信號(hào)后所進(jìn)行的操作稱為微操作。2)執(zhí)行部件通過反饋線向控制部件反映操作的情況,使控制部件根據(jù)執(zhí)行部件的“狀態(tài)”下達(dá)新的微命令。由于數(shù)據(jù)通路的結(jié)構(gòu)關(guān)系,微操作可以分為兩類:1)相容性微操作,指在同時(shí)或同一個(gè)CPU周期內(nèi)可以并行執(zhí)行的微操作。2)相斥性微操作,指不能在同時(shí)或不能在同一個(gè)CPU周期內(nèi)并行執(zhí)行的微操作。
相斥操作相容操作相斥操作相斥操作微指令在機(jī)器的一個(gè)CPU周期中,一組實(shí)現(xiàn)一定操作功能的微命令的組合,構(gòu)成一條微指令。微指令字長(zhǎng)23位11微指令中如果操作控制字段的某一位的信息為“1”時(shí),表示發(fā)出微命令,為“0”時(shí),表示不發(fā)出微命令。某條微指令的二進(jìn)制編碼是:
10011000010000000******完成的四個(gè)微操作是:
R1->XR3->Y+LDR1運(yùn)算器完成了R1+R3->R1的操作。非訪存指令A(yù)DDR1,R3的執(zhí)行周期:PC->AR->ABUSDBUS->DR->IRPC+1->PC開始譯碼測(cè)試R1->ALUR3->ALUALU->R1ADD
為了在第二個(gè)機(jī)器周期執(zhí)行該指令,微指令給出R1->X的選通信號(hào)4’,R3->Y的選通信號(hào)5’,ALU的加信號(hào)+’和R1的選通信號(hào)1’,它們都在一個(gè)機(jī)器周期內(nèi)有效,但這4個(gè)信號(hào)的到來有嚴(yán)格的時(shí)間順序關(guān)系,由時(shí)序信號(hào)T1,T2,T3,T4來控制。微指令:10011000010000000******T1T2T3T4CLK4’5’+’1’45+1設(shè)4=T1·4’,5=T1·5’,+=(T2∪T3)·+’,1=T4·1’微指令的操作控制字段決定給出的微命令,時(shí)序產(chǎn)生器決定微命令的時(shí)序關(guān)系
一條微指令就能完成一條機(jī)器指令嗎?
考慮ADDR2,30的執(zhí)行過程,ADD指令需要三個(gè)機(jī)器周期組成,第一個(gè)是取指周期,后兩個(gè)是執(zhí)行周期,微操作如下所示:取指周期:PC->ARAR->ABUSRAM->DRDR->IRPC+1->PC第一個(gè)執(zhí)行周期:IR->AR(指令的地址碼送地址寄存器)第二個(gè)執(zhí)行周期:AR->ABUSRAM->DRDR->ALU(X端)R2->ALU(Y端)ALU完成加運(yùn)算
ALU->R2微指令01000011010000000******完成微程序一條機(jī)器指令的功能是用許多條微指令組成的序列來實(shí)現(xiàn)的,這個(gè)微指令序列通常叫做微程序。
完成一條機(jī)器指令微操作命令1微操作命令2微操作命令n……微指令110100000…微程序00010010………微操作命令n+1微指令n微程序控制器的結(jié)構(gòu)微程序控制器主要由控制存儲(chǔ)器、微地址寄存器、微命令寄存器和地址轉(zhuǎn)移邏輯構(gòu)成。
將微程序存入到高速的只讀存儲(chǔ)器中,機(jī)器指令的解釋執(zhí)行通過讀取對(duì)應(yīng)的微程序來完成,存儲(chǔ)邏輯實(shí)現(xiàn)的控制器稱為微程序控制器。
微指令的操作控制部分決定給出的微命令,順序控制部分決定下一條微指令在只讀存儲(chǔ)器中的地址,由P測(cè)試字段和后續(xù)直接地址構(gòu)成。如果判別測(cè)試字段全為0,后續(xù)直接地址給出下一條微指令的地址;否則修改后續(xù)直接地址作為下一條微指令的地址??刂拼鎯?chǔ)器:存放實(shí)現(xiàn)全部指令系統(tǒng)的微程序,它是一種只讀型存儲(chǔ)器。要求速度快,讀出周期短。微地址寄存器:存放讀出微指令的直接地址,決定要讀取的下一條微指令的地址。微命令寄存器:保存讀出微指令的操作控制字段和判別測(cè)試字段的信息。地址轉(zhuǎn)移邏輯:承擔(dān)自動(dòng)完成修改微地址的任務(wù)??刂谱侄?/p>
P字段
直接地址
微指令地址轉(zhuǎn)移邏輯:P1=0,P2=0,不修改微地址寄存器中的直接地址,是下一條微指令地址。P1=1,P2=0,則指令寄存器中的指令的操作碼的后四位修改微地址寄存器的四位地址,給出16路分支。如某條指令的操作碼是00001010,則下一條微指令的地址是1010。P1稱為操作碼測(cè)試。P1=0,P2=1,則利用進(jìn)位標(biāo)志CY求反修改微地址寄存器的最后一位。微程序舉例下面以一個(gè)“十進(jìn)制”加法的機(jī)器指令來說明微程序以及微程序的控制。“十進(jìn)制”加法指令就是利用BCD碼讓運(yùn)算器完成十進(jìn)制的加法運(yùn)算。4位2進(jìn)制數(shù)BCD碼00000000110010200113010040101501106011171000810019在計(jì)算機(jī)中,可以用4位二進(jìn)制數(shù)表示1位十進(jìn)制數(shù),這種代碼稱為BCD碼。BCD碼只有0~9十種編碼,對(duì)于二進(jìn)制數(shù)1010~1111在BCD碼中無意義BCD碼調(diào)整原理00001000+0000011100001111(0F)例如:8+7=15BCD碼是逢10進(jìn)1,4位二進(jìn)制數(shù)是逢16進(jìn)1,如果1位BCD碼所對(duì)應(yīng)的4位二進(jìn)制數(shù)超過9,可以補(bǔ)加一個(gè)6。+00000110
00010101(15)運(yùn)算器進(jìn)行BCD碼的加法運(yùn)算時(shí),將被加數(shù)、加數(shù)相加后再加6,如果低4位向高4位有進(jìn)位,不需要調(diào)整;否則得到的和減6。00000111+0000011000001101(0D)例如:7+6=13+00000110
00010011(13)有進(jìn)位正確00000011+0000010100001000(08)例如:3+5=8+00000110
00001110(0E)無進(jìn)位不正確-00000110
00001000(08)正確模型機(jī)及控制信號(hào)第一條微指令對(duì)應(yīng)的操作:取指過程第一條微指令的二進(jìn)制編碼是:00000000000010101100000這條微指令的操作控制字段對(duì)應(yīng)4個(gè)微操作13位:指存讀命令15位:IBUS->IR17位:PC+1->PC這條微指令的順序控制字段對(duì)應(yīng)1個(gè)P1測(cè)試P1=1,表明后4位給出的不是下一條微指令的地址,根據(jù)P1測(cè)試的修改地址的規(guī)則,如果十進(jìn)制加法指令的操作碼是00001010,則下一條微指令地址1010。第二條微指令對(duì)應(yīng)的操作:兩數(shù)相加(被加數(shù)在R1中,加數(shù)在R2中)。該微指令的地址是1010第二條微指令的二進(jìn)制編碼是01010010010000000001001這條微指令的操作控制字段對(duì)應(yīng)4個(gè)微操作4位:R1->X7位:R2->Y10位:加操作2位:LDR2’完成R1+R2->R2的操作。這條微指令的順序控制字段沒有P測(cè)試表明后4位給出的是下一條微指令的地址,則下一條微指令地址1001第三條微指令對(duì)應(yīng)的操作:和加6(和在R2中,加數(shù)6在R3中)。該微指令的地址是1001第三條微指令的二進(jìn)制編碼是01001100010000000010000這條微指令的操作控制字段對(duì)應(yīng)4個(gè)微操作6位:R2->X5位:R3->Y10位:加操作2位:LDR2’完成R2+R3->R2的操作。這條微指令的順序控制字段有P2測(cè)試P2=1,根據(jù)P2測(cè)試的修改地址的規(guī)則,測(cè)試進(jìn)位標(biāo)志CY,如果CY=1下一條微指令地址0000,如果CY=0,則下一條微指令地址是0001。第四條微指令對(duì)應(yīng)的操作:減6調(diào)整,調(diào)整的結(jié)果在R2中。該微指令的地址是0001第四條微指令的二進(jìn)制編碼是01001100000100000000000這條微指令的操作控制字段對(duì)應(yīng)4個(gè)微操作6位:R2->X5位:R3->Y12位:減操作2位:LDR2’完成R2-R3->R2的操作。這條微指令的順序控制字段P沒有測(cè)試,下一條微指令的地址就是0000,轉(zhuǎn)入公操作或者取指操作。如果CY=1,下一條微指令地址0000,轉(zhuǎn)入公操作或者取指的微指令,取下一條指令。機(jī)器指令、微指令、微操作的關(guān)系對(duì)于十進(jìn)制加法指令來說由4條微指令構(gòu)成,其中:第一條微指令的二進(jìn)制編碼是
00000000000010101100000第二條微指令的二進(jìn)制編碼是
01010010010000000001001第三條微指令的二進(jìn)制編碼是
010001001
10000000010000第四條微指令的二進(jìn)制編碼是
01000100100100000000000機(jī)器指令微程序1)一條機(jī)器指令對(duì)應(yīng)一個(gè)微程序,這個(gè)微程序是由若干條微指令序列組成的。因此,一條機(jī)器指令的功能是由若干條微指令組成的序列來實(shí)現(xiàn)的。2)從指令與微指令,程序與微程序,地址與微地址的一一對(duì)應(yīng)關(guān)系來看,前者與內(nèi)存儲(chǔ)器有關(guān),后者與控制存儲(chǔ)器有關(guān)。3)每一個(gè)CPU周期就對(duì)應(yīng)一條微指令。程序計(jì)數(shù)器PC+1指令存儲(chǔ)器地址譯碼指令寄存器IROP指令地址微指令微地址微地址寄存器控制存儲(chǔ)器地址譯碼地址轉(zhuǎn)換邏輯控制字段……微命令信號(hào)P字段狀態(tài)信號(hào)P字段直接地址例:A、B、C、I四條微指令的地址如圖所示,P1測(cè)試處的微指令轉(zhuǎn)移利用指令寄存器的指令操作碼的IR5IR6修改微地址寄存器的最后兩位uA1和uA0,P2測(cè)試處的微指令轉(zhuǎn)移利用進(jìn)位標(biāo)志CY修改微地址寄存器的uA2。寫出控制存儲(chǔ)器中所有微指令P測(cè)試位和直接地址的內(nèi)容??刂拼鎯?chǔ)器操作控制位P1P2uA0~uA3P測(cè)試位直接地址******地址0000000100100011010001010110011110001001101010111100110111101111******************************************************************************************000001A1010**B000100H000101I000101N000000O001110J010*11C000101D001101E000010F001111K001100G000101L000100MABEGKMFHDCIJLNOIR5IR6=00IR5IR6=01IR5IR6=10IR5IR6=11CY=0CY=100000001P1P210000011
了解了微程序控制器的原理,我們知道確定微指令的結(jié)構(gòu)是設(shè)計(jì)微程序的關(guān)鍵,也是控制器設(shè)計(jì)的關(guān)鍵,也是CPU的關(guān)鍵,同樣也是指令系統(tǒng)的關(guān)鍵。一個(gè)良好的微指令結(jié)構(gòu)應(yīng)該滿足:1)有利于縮短微指令字的長(zhǎng)度2)有利于減少控制存儲(chǔ)器的容量3)有利于提高微程序的執(zhí)行速度4)有利于微指令的修改5)有利于提高微程序的靈活性-微指令編碼直接表示法:特點(diǎn)是操作控制宇段中的每一位代表一個(gè)微命令。這種方法的優(yōu)點(diǎn)是簡(jiǎn)單直觀,其輸出直接用于控制。缺點(diǎn)是微指令字較長(zhǎng),因而使控制存儲(chǔ)器容量較大。
編碼表示法:編碼表示法是把一組相斥性的微命令信號(hào)組成一個(gè)字段,然后通過字段譯碼器對(duì)每一個(gè)微命令信號(hào)進(jìn)行譯碼,譯碼輸出作為操作控制信號(hào)。優(yōu)點(diǎn)是可以用較小的二進(jìn)制信息位表示較多的微命令信號(hào),可使微指令字大大縮短。缺點(diǎn)是微程序的執(zhí)行速度稍稍減慢。
字段1字段2……P字段下一個(gè)微地址譯碼譯碼譯碼………微操作微程序設(shè)計(jì)技術(shù)
某計(jì)算機(jī)有8條微指令I(lǐng)1—I8,每條微指令所包含的微命令控制信號(hào)見下表所示,a—j分別對(duì)應(yīng)10種不同性質(zhì)的微命令信號(hào)。假設(shè)一條微指令的控制字段僅限8位,請(qǐng)安排微指令的控制字段格式。微指令abcdefghijI1I2I3I4I5I6I7I8√√√√√√√√√√√√√√√√√√√√√√√√√
經(jīng)分析(d,i,j)和(e,f,h)可分別組成兩個(gè)小組或兩個(gè)字段,然后進(jìn)行譯碼,可得六個(gè)微命令信號(hào),剩下的a,b,c,g四個(gè)微命令信號(hào)可進(jìn)行直接控制,其整個(gè)控制字段組成如下:
-微地址的形成方式多路轉(zhuǎn)移方式:在微指令順序執(zhí)行的時(shí)候,后續(xù)微指令的地址由順序控制字段的直接地址給出;出現(xiàn)分支轉(zhuǎn)移時(shí),由順序控制字段的判別測(cè)試位來選擇跳轉(zhuǎn)的微地址。如果狀態(tài)信息位有n位就可以實(shí)現(xiàn)微程序2n路轉(zhuǎn)移。多路轉(zhuǎn)移方式的特點(diǎn)是:能以較短的順序控制字段配合,實(shí)現(xiàn)多路并行轉(zhuǎn)移,靈活性好,速度較快。計(jì)數(shù)器法方式:這種方法同用程序計(jì)數(shù)器來產(chǎn)生機(jī)器指令地址的方法相類似。微地址寄存器通常作為計(jì)數(shù)器,在順序執(zhí)行微指令的時(shí)候,后續(xù)微指令地址由現(xiàn)行微地址加一產(chǎn)生。為此順序執(zhí)行的微指令必須安排在控制存儲(chǔ)器的連續(xù)單元中。-微指令格式水平型微指令:一次能定義并執(zhí)行多個(gè)微操作命令的微指令??刂谱侄闻袆e測(cè)試字段下地址字段
水平型微指令中控制字段某位為“1”時(shí),表示發(fā)出微命令,為“0”時(shí),表示不發(fā)出微命令,它的特點(diǎn)是:1)可以使多個(gè)微操作并發(fā)執(zhí)行,效率高。2)由于水平型微命令并行執(zhí)行的效率高,可以用較少的微指令來完成一條機(jī)器指令的執(zhí)行。3)水平型微指令一般直接控制對(duì)象,速度快。4)水平型微指令的微指令字較長(zhǎng)。5)水平型微指令用戶難以掌握,不宜理解。垂直型微指令:微指令中設(shè)置微操作碼字段,對(duì)微操作碼進(jìn)行譯碼來產(chǎn)生相應(yīng)的微命令。一條微指令譯碼只能產(chǎn)生一個(gè)或者幾個(gè)微命令,這種微指令稱為垂直型微指令。垂直型微指令的結(jié)構(gòu)類似于機(jī)器指令的結(jié)構(gòu)。000源寄存器目的寄存器…果微操作碼000表示寄存器-寄存器型微指令,源寄存器0010表示DR,目的寄存器1001表示IR,則微指令00000101001***表示一個(gè)微操作:DR->IR
001X端輸入Y端輸入ALU操果微操作碼001表示運(yùn)算控制微指令,X端輸入0001表示R1,Y輸入端0010表示R2,ALU操作的010表示加運(yùn)算,則微指令00100010010010表示三個(gè)微操作:R1->X
R2->Y運(yùn)算器+操作
垂直型微指令一般只能完成一個(gè)微操作,并行能力操作差,并且垂直型微指令不直接控制對(duì)象,要經(jīng)過譯碼,速度慢。但是垂直型微指令具有指令字比較短的特點(diǎn),并且對(duì)用戶來說容易掌握。5.6硬布線控制器基本思想硬布線控制器是早期設(shè)計(jì)控制器的一種方法。這種方法是把控制部件看作為產(chǎn)生時(shí)序控制信號(hào)的邏輯電路,這種邏輯電路是一種由門電路和觸發(fā)器構(gòu)成的復(fù)雜樹形邏輯網(wǎng)絡(luò),故稱之為硬布線控制器。由于硬布線控制器采用完全的邏輯電路來實(shí)現(xiàn),一旦控制部件構(gòu)成后,除非重新設(shè)計(jì)和物理上對(duì)它重新布線,否則要想增加新的控制功能是不可能的。因此在現(xiàn)代的控制器的設(shè)計(jì)中已經(jīng)很少使用。與微程序控制相比,硬布線控制的速度較快。其原因是微程序控制中每條微指令都要從控制存儲(chǔ)器中讀取一次,影響了速度,而硬布線控制主要取決于電路延遲。因此,近年來在某些超高速新型計(jì)算機(jī)結(jié)構(gòu)中,又選用了硬布線控制器。樹形邏輯網(wǎng)絡(luò)N微操作控制信號(hào)……C1CnB1Bj結(jié)果反饋信息指令譯碼器I1Im………指令寄存器啟動(dòng)停止時(shí)鐘復(fù)位節(jié)拍電位/脈沖發(fā)生器MiM1TkT1………邏輯網(wǎng)絡(luò)N的輸入信號(hào):邏輯網(wǎng)絡(luò)N的輸出信號(hào):C=f(Im,Mi,Tk,Bj)指令操碼譯碼器的輸出執(zhí)行部件的反饋信息時(shí)序產(chǎn)生器的時(shí)序信號(hào)對(duì)執(zhí)行部件進(jìn)行控制的各種操作信號(hào)硬布線控制器基本結(jié)構(gòu)硬布線控制器基本原理:指令執(zhí)行流程M1M3M2
節(jié)拍電平信號(hào)M1~Mi就是機(jī)器周期信號(hào),一條指令有多少個(gè)機(jī)器周期就有多少個(gè)節(jié)拍電平信號(hào)。節(jié)拍脈沖信號(hào)T1~Tk就是時(shí)鐘周期信號(hào),一個(gè)機(jī)器周期內(nèi)有多個(gè)操作,必須用節(jié)拍脈沖信號(hào)對(duì)操作的先后次序進(jìn)行控制。PC->ABUS(I)IBUS->IRPC+1->PCMOVLADADDSTOJMPR1+R2->R2R1->R0IR->PCIR->ARAR->ABUS(D)DBUS->DRDR->R1RD(D)RD(I)R3->ARWE(D)R3->DBUS微操作信號(hào)的產(chǎn)生在微程序控制器中,微操作控制信號(hào)由微指令產(chǎn)生,并且可以重復(fù)使用。在硬布線控制器中,某一微操作控制信號(hào)由布爾代數(shù)表達(dá)式描述的輸出函數(shù)產(chǎn)生。結(jié)合上5條指令邏輯網(wǎng)絡(luò)N的輸出讀信號(hào)RD(I)的邏輯表達(dá)式分析如下:任何指令的第一機(jī)器周期都是取指令,只要M1信號(hào)有效RD(I)就有效;RD(I)控制信號(hào)的邏輯表達(dá)式:RD(I)=M1WE(D)控制信號(hào)的邏輯表達(dá)式:WE(D)=M3·T3·STOLDIR控制信號(hào)的邏輯表達(dá)式:LDIR=M1·T4LDR2控制信號(hào)的邏輯表達(dá)式:LDR2=M2·T4·ADDLDDR控制信號(hào)的邏輯表達(dá)式:LDDR=M2·T3·(MOV+ADD)+M3·T3·LDA
設(shè)計(jì)微操作控制信號(hào)的方法和過程是,根據(jù)所有機(jī)器指令流程圖,尋找出產(chǎn)生同一個(gè)微操作信號(hào)的所有條件,并與適當(dāng)?shù)墓?jié)拍電位和節(jié)拍脈沖組合,從而寫出其布爾代數(shù)表達(dá)式并進(jìn)行簡(jiǎn)化,然后用門電路或可編程器件來實(shí)現(xiàn)。
5.6流水CPU并行處理技術(shù)并行和并發(fā)的含義:-并行性:兩個(gè)以上事件在同一時(shí)刻發(fā)生。例如在多CPU系統(tǒng)中,同一時(shí)刻多個(gè)進(jìn)程在運(yùn)行。-并發(fā)行:兩個(gè)以上事件在同一間隔內(nèi)發(fā)生。如某一時(shí)刻CPU中只有一個(gè)進(jìn)程運(yùn)行,而一個(gè)時(shí)間段內(nèi)多個(gè)進(jìn)程同時(shí)運(yùn)行。并行性的三種形式:-時(shí)間并行:讓多個(gè)處理過程在時(shí)間上相互錯(cuò)開,輪流地使用同一套硬件設(shè)備的各個(gè)部分,以加快硬件周轉(zhuǎn)而贏得速度。時(shí)間并行性概念的實(shí)現(xiàn)方式就是采用流水處理部件。
-空間并行:設(shè)置重復(fù)資源,同時(shí)工作??臻g并行技術(shù)主要體現(xiàn)在多處理器系統(tǒng)和多計(jì)算機(jī)系統(tǒng)。
-時(shí)間并行+空間并行:時(shí)間重疊和資源重復(fù)的綜合應(yīng)用。流水CPU的組成多體交叉存儲(chǔ)器Cache指令部件(指令I(lǐng)+K+1)指令隊(duì)列(指令I(lǐng)+K)……(指令I(lǐng)+1)執(zhí)行部件(指令I(lǐng))流水方式CPU-流水CPU的組成:指令部件,指令隊(duì)列,執(zhí)行部件。這三個(gè)功能部件可以組成一個(gè)3級(jí)流水線。-指令部件:指令部件由取指令、指令譯碼、計(jì)算操作數(shù)地址、取操作數(shù)構(gòu)成一個(gè)4級(jí)指令流水線地址形成部件指令譯碼部件取操作數(shù)部件取指令部件-執(zhí)行部件:由定點(diǎn)執(zhí)行部件和浮點(diǎn)運(yùn)算部件構(gòu)成,浮點(diǎn)運(yùn)算部件以流水方式構(gòu)成運(yùn)算流水線。對(duì)階部件尾數(shù)加部件規(guī)格化部件階碼比較流水CPU的時(shí)空?qǐng)D
空間S時(shí)間SWBEXIDIF123456789101112指令1指令2指令3設(shè)一條指令包含4個(gè)子過程:取指令(IF)、指令譯碼(ID)、執(zhí)行指令(EX)、結(jié)果回寫(WB)。下面表述了非流水時(shí)空?qǐng)D和流水時(shí)空?qǐng)D??臻gS時(shí)間SWBEXIDIF123456789101112I1I2I3超標(biāo)量技術(shù):具有兩條以上的指令流水線,當(dāng)流水線滿載時(shí)每一個(gè)時(shí)鐘周期可以執(zhí)行兩條以上的指令。
空間S時(shí)間SWBEXIDIF123456789101112假設(shè)每條指令需要4個(gè)時(shí)間單位執(zhí)行完畢,如果有N條指令:在非流水CPU中,N條指令執(zhí)行完畢需要時(shí)間t=N*4。在流水CPU中,N條指令執(zhí)行完畢需要時(shí)間t=4+(N-1)。如果有20條指令,非流水CPU需要80個(gè)時(shí)間單位,而流水CPU需要23個(gè)時(shí)間單位,計(jì)算機(jī)的速度有很大提高。流水線分類-指令流水線是指令執(zhí)行步驟的并行。將指令流的處理過程劃分為取指令、譯碼、執(zhí)行、寫回等幾個(gè)并行處理的過程段。目前,幾乎所有的高性能計(jì)算機(jī)都采用了指令流水線。完成一條指令分7段,每段需一個(gè)時(shí)鐘周期若流水線不出現(xiàn)斷流1
個(gè)時(shí)鐘周期出
1
結(jié)果不采用流水技術(shù)7
個(gè)時(shí)鐘周期出1結(jié)果地址形成部件指令譯碼部件取操作數(shù)部件取指令部件操作執(zhí)行部件回寫結(jié)果部件修改指令指針部件-算術(shù)流水線指運(yùn)算操作步驟的并行。如流水加法器、流水乘法器、流水除法器等?,F(xiàn)代計(jì)算機(jī)中已廣泛采用了流水的算術(shù)運(yùn)算器。完成浮點(diǎn)加運(yùn)算可分比較階碼、對(duì)階、尾數(shù)求和、規(guī)格化四段鎖存器對(duì)階功能部件第二段尾數(shù)加部件鎖存器第三段規(guī)格化部件鎖存器第四段鎖存器比較階碼部件第一段-處理機(jī)流水線又稱為宏流水線,是指程序步驟的并行。由一串級(jí)聯(lián)的處理機(jī)構(gòu)成流水線的各個(gè)過程段,每臺(tái)處理機(jī)負(fù)責(zé)某一特定的任務(wù)。流水線的主要問題-資源相關(guān):指多條指令進(jìn)入流水線后在同一機(jī)器時(shí)鐘周期內(nèi)爭(zhēng)用同一個(gè)功能部件所發(fā)生的沖突。設(shè)一條指令流水線包含5個(gè)子過程:取指令(IF)、指令譯碼(ID)、計(jì)算有效地址(EX)、取操作數(shù)(MEM)、結(jié)果回寫(WB)。由于都要訪問存儲(chǔ)器,發(fā)生資源相關(guān)-數(shù)據(jù)相關(guān):在一個(gè)程序中,如果必須等前一條指令執(zhí)行完畢后,才能執(zhí)行后一條指令,這兩條指令就是數(shù)據(jù)相關(guān)。有下面三條指令流水執(zhí)行:
ADDR1,R2,R3;R2+R3->R1SUBR4,R1,R5;R1-R5->R4ANDR6,R1,R7;R1∧R7->R6ADD在時(shí)鐘5寫入R1,SUB在時(shí)鐘3讀取寄存器R1,AND在時(shí)鐘4讀取寄存器R1,發(fā)生了數(shù)據(jù)相關(guān)。例4:流水線中有三類數(shù)據(jù)相關(guān)沖突:寫后讀相關(guān);讀后寫相關(guān);寫后寫相關(guān)。判斷以下三組指令各存在哪種類型的數(shù)據(jù)相關(guān)。(1)I1:
ADDR1,R2,R3;(R2)+(R3)->R1
I2:
SUBR4,R1,R5;(R1)-(R5)->R4(2)I3:
STOM(x),R3;(R3)->M(x),M(x)是存儲(chǔ)器單元
I4:
ADDR3,R4,R5;(R4)+(R5)->R3(3)I5:
MULR3
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版房地產(chǎn)反擔(dān)保抵押合同附件十3篇
- 二零二五年度綠色物流鋼材運(yùn)輸服務(wù)合同2篇
- 二零二五年度車輛租賃與車輛銷售服務(wù)合同2篇
- 二零二五年度高端商務(wù)汽車租賃服務(wù)合同協(xié)議2篇
- 二零二五版冷鏈物流訂餐服務(wù)合同范本與質(zhì)量保證2篇
- 二零二五年擔(dān)保合同范本修訂要點(diǎn)與執(zhí)行建議6篇
- 二零二五版房產(chǎn)抵押投資合作合同范本3篇
- 二零二五版物流運(yùn)輸企業(yè)勞動(dòng)合同范本與司機(jī)權(quán)益保障服務(wù)合同3篇
- 二零二五年度房地產(chǎn)經(jīng)紀(jì)服務(wù)合同補(bǔ)充協(xié)議2篇
- 二零二五版12333職業(yè)培訓(xùn)補(bǔ)貼政策合同3篇
- 上海紐約大學(xué)自主招生面試試題綜合素質(zhì)答案技巧
- 辦公家具項(xiàng)目實(shí)施方案、供貨方案
- 2022年物流服務(wù)師職業(yè)技能競(jìng)賽理論題庫(kù)(含答案)
- ?;钒踩僮饕?guī)程
- 連鎖遺傳和遺傳作圖
- DB63∕T 1885-2020 青海省城鎮(zhèn)老舊小區(qū)綜合改造技術(shù)規(guī)程
- 高邊坡施工危險(xiǎn)源辨識(shí)及分析
- 中海地產(chǎn)設(shè)計(jì)管理程序
- 簡(jiǎn)譜視唱15942
- 《城鎮(zhèn)燃?xì)庠O(shè)施運(yùn)行、維護(hù)和搶修安全技術(shù)規(guī)程》(CJJ51-2006)
- 項(xiàng)目付款審核流程(visio流程圖)
評(píng)論
0/150
提交評(píng)論