版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
主要內容本章主要討論控制器。內容主要包括控制器的基本結構和功能、時序控制方式、微程序控制器、微程序控制器的設計等,最后介紹超標量流水技術以及典型的CPU器件。當前1頁,總共89頁。6.1中央處理器的基本組成CPU的功能:(1)指令控制:按指令要求控制取下一條指令。程序中大部分指令是順序執(zhí)行,小部分指令是轉移指令.如果計算機的指令中沒有無條件轉移指令、條件轉移指令、循環(huán)轉移指令、轉子指令和返回指令等,那么就編不出高質量的程序。(2)操作控制:完成指令所規(guī)定的各功能操作,包括算術邏輯運算等操作,也包括CPU和主存、I/O設備之間信息傳送及控制等,協(xié)調CPU和主存、I/O設備之間的操作。當前2頁,總共89頁。一、功能:(3)時間控制:計算機有很多操作,對某條指令來說,某個操作信號在T1時刻可能是需要的,但在T2時刻可能又不需要了。因此CPU需根據(jù)指令要求,在T1時刻,只對某些操作信號適時地發(fā)出規(guī)定的操作。在計算機系統(tǒng)中,不僅要提供各種基本操作(微操作),更重要的是控制計算機何時發(fā)出所需要的操作,才能使計算機有條不紊地工作,這是CPU具有的最重要功能。(4)數(shù)據(jù)加工:對數(shù)據(jù)進行算術運算和邏輯運算。完成數(shù)據(jù)的加工處理,這是CPU的根本任務。當前3頁,總共89頁。二、組成傳統(tǒng)的CPU由運算器和控制器兩大部分組成。但是隨著高密度集成電路技術的發(fā)展,早期放在CPU芯片外的一些邏輯功能部件,如浮點運算器、cache等紛紛移入CPU內部,因而使CPU的內部組成越來越復雜。這樣,CPU的基本部分變成了運算器、cache和控制器三大部分。當前4頁,總共89頁。1、控制器是計算機的控制中心,是發(fā)布命令的“決策機構”,即完成協(xié)調和指揮整個計算機系統(tǒng)的操作。主要由程序計數(shù)器、指令寄存器、指令譯碼器、時序產生器和操作控制器組成。功能:(1)從內存中取出一條指令,并指出下一條指令在內存中的位置。(2)對指令進行譯碼或測試,并產生相應的操作控制信號,以便啟動規(guī)定的動作。比如一次內存讀/寫操作,一個算術邏輯運算操作,或一個輸入輸出操作。(3)指揮并控制CPU,內存和輸入/輸出設備之間數(shù)據(jù)流動的方向。當前5頁,總共89頁。2、運算器是計算機對數(shù)據(jù)加工處理的中心,計算機指令功能的實現(xiàn),就是通過運算器完成的。它主要由多功能算術邏輯運算部件(ALU)、累加寄存器(AC)、數(shù)據(jù)緩沖寄存器(DR)和狀態(tài)條件寄存器(PSW)組成,ALU輸入端的多路選擇器、通用寄存器、移位器、總線等功能部件等構成。運算器的功能(1)執(zhí)行所有的算術運算(2)執(zhí)行所有的邏輯運算,并進行邏輯測試。通常,一個算術操作產生一個運算結果,而一個邏輯操作產生一個判決。當前6頁,總共89頁。當前7頁,總共89頁。3、CPU的寄存器數(shù)據(jù)緩沖寄存器(DR):用來暫時存放由內存儲器讀出的一條指令或一個數(shù)據(jù)字;反之,當向內存中存入一條指令或一個數(shù)據(jù)字時,也暫時將它們存放在數(shù)據(jù)緩沖寄存器中。指令寄存器(DR):用來保存當前正在執(zhí)行的一條指令。程序計數(shù)器(PC):為了保證程序能夠連續(xù)地執(zhí)行下去,CPU必須具有某些手段來確定下一條指令的地址。而程序計數(shù)器(PC)正是起到這種作用地址寄存器(AR):用來保證當前CPU所訪問的內存單元的地址。當前8頁,總共89頁。3、CPU的寄存器累加寄存器(AC):當運算器的算術邏輯單元(ALU)執(zhí)行算術或邏輯運算時,為ALU提供一個工作區(qū)。狀態(tài)條件寄存器(PSW):保存由算術和邏輯指令運行或測試的結果建立的各種條件碼內容。當前9頁,總共89頁。4、操作控制器 數(shù)據(jù)通路:許多寄存器之間傳送信息的通路。信息從什么地方開始,中間通過哪個寄存器或多路開關,最后傳送到哪個寄存器,都要加以控制。在各寄存器之間建立數(shù)據(jù)通路的任務,是由稱為操作控制器的部件來完成的。操作控制器的功能,就是根據(jù)指令操作碼和時序信號,產生各種操作控制信號,以便正確地建立數(shù)據(jù)通路,從而完成取指令和執(zhí)行指令的控制。根據(jù)設計方法的不同,操作控制器可分為時序邏輯型、存儲邏輯型、時序邏輯與存儲邏輯結合型三種,第一種稱為硬布線控制器,它采用時序邏輯技術實現(xiàn);第二種稱為微程序控制器,它是采用存儲邏輯來實現(xiàn)的。第三種是前兩種的組合。當前10頁,總共89頁。4、操作控制器 操作控制器產生的控制信號必須定時,還必須有時序產生器。因為計算機高速地進行工作,每一個動作的時間是非常有限的,不能有任何差錯。時序產生器的作用,就是對各種操作實施時間上的控制。CPU中除了上述組成部分以外,還有中斷系統(tǒng)、總線接口等其他功能部件。當前11頁,總共89頁。6.2指令周期6.2.1指令周期的基本概念:CPU每取出并執(zhí)行一條指令,都要完成一系列的操作,這一系列操作所需的時間通常叫做一個指令周期。即,指令周期是取出并執(zhí)行一條指令的時間。各種指令的指令周期是不盡相同的。指令周期通常用若干個CPU周期來表示,CPU周期也稱為機器周期。由于CPU內部的操作速度較快,而CPU訪問一次內存所花的時間較長,因此通常用內存中讀取一個指令字的最段短時間來規(guī)定CPU周期,即,一條指令的取出階段需要一個CPU周期。而一個CPU周期時間又包含若干個時鐘周期(節(jié)拍脈沖或T周期,它是處理操作的基本單位)。這些時鐘周期的總和則規(guī)定了一個CPU周期的時間寬度。(P157)當前12頁,總共89頁。當前13頁,總共89頁。6.2指令周期當前14頁,總共89頁。五條典型指令組成的一個程序八進制地址八進制內容指令助記符040250000CLA041030060ADD60042021061STAI61043000000NOP044140055JMP55………………055…………………………060000006
061000080
……
080存和數(shù)單元
當前15頁,總共89頁。6.2.1非訪內指令的指令周期
CLA是一條非訪內指令,它需要兩個CPU周期,其中取指令階段需要一個CPU周期,執(zhí)行指令階段需要一個CPU周期。取指令階段:1、從內存中取出指令;2、對程序計數(shù)器PC加1,以便為取下一條指令做好準備;3、對指令操作碼進行譯碼或測試,以便進行什么操作。執(zhí)行指令階段:CPU根據(jù)對指令操作碼的譯碼或測試,進行指令所要求的操作。對非訪內指令來說,執(zhí)行階段通常涉及到累加器的內容,如累加器內容清零、累加器內容求反等操作。其他一些零地址格式的指令,執(zhí)行階段一般也僅需要一個CPU周期。具體操作見教材P159圖5.5當前16頁,總共89頁。當前17頁,總共89頁。6.2.2直接訪內指令的指令周期
ADD指令是一條訪問內存取數(shù)并執(zhí)行加法的指令;其指令周期由三個CPU周期組成,其中,第一個周期為取值指令階段,其過程完全與CLA指令相同。執(zhí)行指令階段由兩個CPU周期組成:在第二個CPU周期中將操作數(shù)的地址送往地址寄存器并完成地址譯碼,在第三個CPU周期從內存中取出操作數(shù)并執(zhí)行相加的操作。當前18頁,總共89頁。當前19頁,總共89頁。6.2.3間接訪內指令的指令周期
程序的第三條指令是“STA40”指令,這是一條訪問內存的指令。STA指令的指令周期由三個CPU周期組成,如圖,其中第一個CPU周期仍然是取指令階段,其過程與CLA指令、ADD指令完全一樣,不同的是此階段中程序計數(shù)器加1后變?yōu)?3,因而為取第四條指令做好了準備。當前20頁,總共89頁。當前21頁,總共89頁。6.2.4空操作指令的指令周期
NOP是一條空操作指令,由2個CPU周期組成,第一個CPU周期中取指令,CPU把23號單元的“NOP”指令取出并放到指令寄存器,第二個CPU周期中執(zhí)行該指令。因譯碼器譯出是“NOP”指令,第二個CPU周期中操作控制器不發(fā)出任何控制信號。NOP指令可用來調機使用。當前22頁,總共89頁。6.2.5程序轉移指令的指令周期JMP指令指令周期僅由兩個CPU周期組成。第一個CPU周期把24單元的“JMP21”指令取出并放至占領寄存器,同時程序計數(shù)器內容加1,變?yōu)?5,從而為下一條指令做好準備。第二個CPU周期為執(zhí)行階段。此階段中,CPU把指令寄存器中的地址碼部分21送到程序計數(shù)器,從而用新內容21代替PC原先的內容25。這樣,下一條指令將不從25單元讀出,而是從內存21單元開始讀出并執(zhí)行,從而改變了程序原先的順序。當前23頁,總共89頁。當前24頁,總共89頁。5.2.6用方框圖表示指令周期進行計算機設計時,可以采用方框圖語言來表示一條指令的指令周期。一個方框圖代表一個CPU周期,方框中的內容表示數(shù)據(jù)通路的操作或某種控制操作。除了方框圖外,還需要一個菱形符號,它通常用來表示某種判別或測試,不過時間上它依附于緊接它的前面一個方框的CPU周期,而不單獨占用一個CPU周期。由方框圖可以看出,所有指令的取指令階段都是相同的,而且是一個CPU周期。但是指令的執(zhí)行階段,由于各條指令的功能不同,所用的CPU周期是各不相同的,其中CLA,NOP,JMP指令是一個CPU周期;ADD,STA指令是兩個CPU周期??驁D中DBUS代表數(shù)據(jù)總線,ABUS代表地址總線,RD代表內存讀命令,WE代表內存寫命令?!啊狈Q為公操作符號,表示一條指令執(zhí)行完畢,轉入公操作。所謂公操作,就是一條指令執(zhí)行完畢后,CPU所開始進行的一些操作,這些操作主要是CPU對外設請求的處理,如中斷處理,通道處理等。當前25頁,總共89頁。當前26頁,總共89頁。6.3時序控制方式6.3.1時序信號的作用和體制:
計算機的協(xié)調動作需要時間標志,而時間標志則是用時序信號來體現(xiàn)的,一般來說,操作控制器發(fā)出的各種控制信號都是時間因素(時序信號)和空間因素(部件位置)的函數(shù)。如果忽略了時間因素,那么我們學習計算機硬件時就回感到困難。組成計算機硬件的器件特性決定了時序信號最基本的體制是電位-脈沖制,這種體制最明顯的一個例子,就是當實現(xiàn)寄存器之間的數(shù)據(jù)傳送時,數(shù)據(jù)加在觸發(fā)器的電位輸入端,而打入數(shù)據(jù)的控制信號加在觸發(fā)器的時鐘輸入端。電位的高低,標號數(shù)據(jù)是1還是0,而且要求打入數(shù)據(jù)的控制信號到來之前,電位信號已經(jīng)穩(wěn)定。當前27頁,總共89頁。6.3時序控制方式硬布線控制器中(組合邏輯控制器),時序信號往往采用主狀態(tài)周期-節(jié)拍電位-節(jié)拍脈沖三級體制。一個節(jié)拍電位表示CPU周期的時間,它表示了一個較大的時間單位;在一個節(jié)拍電位中又包含若干個節(jié)拍脈沖,以表示較小的時間單位;而主狀態(tài)周期可包含若干個節(jié)拍電位,所以它是最大的時間單位。主狀態(tài)周期可以用一個觸發(fā)器的狀態(tài)持續(xù)時間來表示。微程序控制器中,時序信號比較簡單,一般采用節(jié)拍電位節(jié)拍脈沖二級體制。即:它只有一個節(jié)拍電位,在節(jié)拍電位中又包含若干個節(jié)拍脈沖(始終周期)。節(jié)拍電位表示一個CPU周期的時間,而節(jié)拍脈沖把一個CPU周期劃分成幾個較小的時間間隔。根據(jù)需要,這些時間間隔可以相等,也可以不相等。當前28頁,總共89頁。6.3.2時序信號產生器功能:用邏輯電路產生指令周期所需的時序。大、中形計算機的時序電路比較復雜,而小、微型機的時序電路比較簡單,因為前者涉及的動作較多,而后者涉及的操作動作較少。另一方面,從設計操作控制器的方法來講,硬布線控制器的時序電路比較復雜,而微程序控制器的時序電路比較簡單。不管哪一類,時序信號產生器的最基本的構成是一樣的。當前29頁,總共89頁。6.3.3多級時序系統(tǒng)
當前30頁,總共89頁。6.3.3多級時序系統(tǒng)多級時序
當前31頁,總共89頁。6.3.3控制器的控制方式
控制器控制一條指令運行的過程是依次執(zhí)行一個確定的微操作序列的過程,無論在微程序控制或硬布線控制計算機中都是這樣。由于不同指令所對應的微操作數(shù)及其繁簡程度很不一樣,因此每條指令和每個微操作所需的執(zhí)行時間也不相同,如何形成控制不同微操作序列的時序控制信號就有多種方法,稱為控制器的控制方式,常用的有同步控制方式、異步控制方式和聯(lián)合控制方式。當前32頁,總共89頁。1.同步控制方式
在任何情況下,已定的指令在執(zhí)行時所需的機器周期數(shù)和節(jié)拍數(shù)都是固定不變的,稱為同步控制方式。根據(jù)不同情況,同步控制方式可以選取如下方案:(1)采用完全統(tǒng)一的機器周期(或節(jié)拍)執(zhí)行各種不同的指令,即不管微操作的繁簡,以最繁的微操作為標準,采取統(tǒng)一的,具有相同時間間隔和相同數(shù)目的節(jié)拍作為機器周期。這對于那些比較簡單的微操作,將造成時間浪費。(2)采用不定長的機器周期,以解決微操作執(zhí)行所需時間不統(tǒng)一的問題。通常把大多數(shù)微操作安排在一個較短時間的機器周期內完成,而對某些較繁的微操作,則采取延長機器周期或增加節(jié)拍的辦法解決。(3)采用中央控制和局部控制相結合的方法。將機器的大部分指令安排在一個統(tǒng)一的較短的機器周期內完成,稱為中央控制。對少數(shù)復雜的指令(如乘法操作、除法操作或浮點運算等)則采用另外的時序進行定時,稱為局部控制。當前33頁,總共89頁。2.異步控制方式
異步控制方式的特點是:根據(jù)每條指令、每個微操作的具體需要決定其占用的時間。這意味著每條指令的指令周期可以由多少不等的機器周期組成;也可以是當控制器發(fā)出進行某一微操作控制信號后,等待執(zhí)行部件完成該操作后發(fā)回的“回答”信號或“結束”信號,再開始新的微操作。用這種控制方式形成的微操作序列沒有固定的周期節(jié)拍和嚴格的時鐘同步。
當前34頁,總共89頁。3.聯(lián)合控制方式
聯(lián)合控制方式將同步控制和異步控制方式相結合。對不同指令的各個微操作實行大部分統(tǒng)一、小部分區(qū)別對待的方式。即大部分微操作安排在一個固定機器周期中,并在同步時序信號控制下進行;而對某些時間難以確定的微操作則以執(zhí)行部件送回的“回答”信號作為本次微操作的結束。
當前35頁,總共89頁。6.4微程序控制器
微程序控制器同硬布線控制器相比較,具有規(guī)整性、靈活性、可維護性等一系列優(yōu)點,因而在計算機設計中逐漸取代了早期采用的硬布線控制器,并已被廣泛使用。在計算機系統(tǒng)中,微程序設計技術是利用軟件方法來設計硬件的一門技術。微程序控制的基本思想,就是仿照通常的解題程序的方法,把操作控制信號編成所謂的“微指令”,存放到一個只讀存儲器里。當機器運行時,一條又一條地讀出這些微指令,從而產生全機所需要的各種操作控制信號,使相應部件執(zhí)行所規(guī)定的操作。當前36頁,總共89頁。1.微程序概念的提出與發(fā)展
1951年,英國劍橋大學的MauriceVincentWilkes教授便提出了微程序(microprogram)的概念。
利用微程序設計技術,可以將計算機中的為操作控制信號按照一定的規(guī)則進行信息編碼,形成控制字(稱為微指令),在把這些微指令按時間先后順序排列起來,存放到一個只讀存儲器中。
當前37頁,總共89頁。Wilkes微程序控制器
當前38頁,總共89頁。2.基本概念和術語1、微命令和微操作控制部件(如控制器)與執(zhí)行部件(如運算器、存儲器、外圍設備等)的一種聯(lián)系,就是通過控制線??刂撇考ㄟ^控制線向執(zhí)行部件發(fā)出各種控制命令,通常把這種控制命令叫做微命令,而執(zhí)行部件接受微命令后所進行的操作,叫做微操作??刂撇考c執(zhí)行部件之間的另一種聯(lián)系是反饋信息。執(zhí)行部件通過反饋線向控制部件反映操作情況,以便使控制部件根據(jù)執(zhí)行部件的“狀態(tài)”來下達新的微命令,這也叫“狀態(tài)測試”當前39頁,總共89頁。2、微指令和微地址在微程序控制的計算機中,同時發(fā)出的控制信號所執(zhí)行的一組微操作稱為微指令,所以微指令就是把同時發(fā)出的控制信號的有關信息匯集起來而形成的。將一條指令分成若干條微指令,按次序執(zhí)行這些微指令,就可以實現(xiàn)指令的功能。組成微指令的微操作就是微命令。一條微指令通常至少包含兩個方面的信息:(1)操作控制字段,也稱為操作碼字段,用于產生某一步微操作所需的各種微操作控制信號;(2)順序控制字段,也稱為微地址碼字段,用于控制產生下一條要執(zhí)行的微指令地址。
當前40頁,總共89頁。2.基本概念和術語3).微指令周期從控制存儲器中讀出一條微指令并執(zhí)行相應的微命令所需的全部時間稱為微周期。4).微程序計算機的程序由指令序列構成,而計算機每條指令的功能均由微指令序列解釋完成,這些微指令序列的集合就叫微程序。一段微程序對應一條機器指令。
當前41頁,總共89頁。6.4.2微程序控制器
1.微程序控制器的基本組成
控制存儲器
微指令寄存器
地址轉移邏輯
當前42頁,總共89頁。2.微程序控制器的工作過程
微程序控制器計算機的結構簡圖
當前43頁,總共89頁。6.4.3微指令的編碼方式
微指令的編碼方式是決定微指令格式的主要因素。微指令格式設計是以機器系統(tǒng)要求、指令級功能部件與數(shù)據(jù)通路設計為依據(jù)的。不同機器具有不同的微指令格式。如大型機強調速度,要求譯碼過程盡量快;微型機和小型機則更重視經(jīng)濟性,要求最大限度地縮短指令字長;中型機則介于兩者之間,兼顧速度和價格,要求在保證一定速度情況下,盡量縮短字長。
1.直接控制編碼法(不譯碼法)
2.最短編碼法
3.分段編譯法
當前44頁,總共89頁。1.直接控制編碼法(不譯碼法)
直接控制編碼法是指操作控制字段中的每一位都代表一個微命令。各位分別可以直接控制計算機,設計微指令時,只要根據(jù)需要將該微命令的對應位設置為1或0即可,不需要進行譯碼。這種編碼的優(yōu)點是結構簡單、直觀,執(zhí)行速度快,操作并行性最好。其缺點是微指令字長過長。如果機器的微命令數(shù)為n個,就要求微指令字的操作控制字段為n位。但實際的機器中微命令都在幾百個以上,采用此方法單是微命令字段就達到幾百位。這會使控制存儲器單元的位數(shù)過多。當前45頁,總共89頁。2.最短編碼法
最短編碼法是不譯法的另一個極端情況。不譯法的微指令字過長,而最短編碼法獲得的微指令長度最短。在這種方法中,所有的微命令統(tǒng)一進行編碼,每條微指令只定義一個微命令。設微命令的總數(shù)為N個,操作控制字段的長度為L位,則最短編碼法滿足以下關系式:
最短編碼法的優(yōu)點是指令字可以達到最短。但這同時帶來了一個不利的問題:必須對微指令進行譯碼后才能得到真正的微命令。微命令數(shù)目越多,譯碼器越復雜。
當前46頁,總共89頁。3.分段編譯法
分段編碼法融合了前兩種方法,它既具有前兩種方法的優(yōu)點,如縮短指令字長度,利用硬件的并行性等,又盡量克服了前兩種方法的缺點,因此使用較多。
1).分段直接編碼法
當前47頁,總共89頁。2).分段間接編碼法
當前48頁,總共89頁。2).分段間接編碼法分段編碼方法的中微操作控制字段的分段必須遵循以下原則:①將互斥性的微命令分在同一段內,兼容性的微命令分在不同的段內。這樣不但有利于提高信息的利用率,縮短微指令字長,也有利于充分利用硬件具有的并行性,加快執(zhí)行的速度。②分段應用數(shù)據(jù)通路結構相適應。③每個小段內包含的信息位不能太多,否則會增加譯碼線路的復雜性,使譯碼時間變長。④一般要求每個小段要留出一個狀態(tài),表示本字段不發(fā)出任何微命令。因此,n位長的字段最多只能表示2n個互斥的微命令,一般用00…0來表示不操作。當前49頁,總共89頁。3).常數(shù)源字段E的設置
在微指令中,一般設有一個常數(shù)源字段E,就如同機器指令中的立即操作數(shù)一樣,用來提供微指令所使用的常數(shù)(由設計者填寫),如提供計數(shù)器初值、通用寄存器地址、轉移地址等。字段E也可用來參與其它控制字段的間接編碼,以減少微指令字長,增加微指令的靈活性,字段E在微指令中的形式為:
當前50頁,總共89頁。6.4.4微程序的順序控制
1.微程序入口地址的形成由于每條機器指令都需要取指操作,所以將取指操作編制成一段公用微程序,通常安排在控制存儲器的0號或1號單元開始的一段控制存儲器空間。當用公用的“取機器指令”微程序從內存中取出機器指令后,首先由“取機器指令”微程序取出一條機器指令到指令寄存器IR中,然后根據(jù)機器指令操作碼轉換成該指令對應的微程序入口地址。
當前51頁,總共89頁。2.后繼微地址的形成
微指令的執(zhí)行是一個連續(xù)的過程,一條微指令執(zhí)行完后即開始執(zhí)行下一條微指令,直到所有的微指令都執(zhí)行完畢為止。因此,要連續(xù)執(zhí)行微指令,必須在一條微指令執(zhí)行結束后就已知下一條要執(zhí)行的微指令的地址。一般是根據(jù)前一條微指令中的順序控制字段的要求形成后繼微指令地址。
1).增量方式(順序—轉移型微地址)2).斷定方式
當前52頁,總共89頁。6.4.5微指令格式
微指令的編碼方式是決定微指令格式的主要因素。微指令格式設計是以機器系統(tǒng)要求、指令級功能部件與數(shù)據(jù)通路設計為依據(jù)的。不同機器具有不同的微指令格式。水平型微指令垂直型微指令
當前53頁,總共89頁。1.水平型微指令
水平型微指令是指一次能定義并執(zhí)行多個并行操作微命令的微指令,一般來說它有如下特征:①微指令較長,通常為幾十位到上百位左右。如VAX一11/780的微指令字長96位。機器規(guī)模越大,速度越快,其微指令字越長。②微指令中的微操作具有高度并行性,這種并行操作能力是以數(shù)據(jù)通路中各部件間的并行操作結構為基礎的。例如,執(zhí)行一條水平型微指令就能控制信息從若干源部件同時傳送到若干目的部件。③微指令編碼簡單,一般采用直接控制編碼和分段直接編碼,以減少微命令的譯碼時間。
當前54頁,總共89頁。1.水平型微指令水平型微指令的優(yōu)點是并行操作能力強、執(zhí)行效率高、靈活性好,微程序條數(shù)少,因此廣泛應用于速度較快的機器中。但由于微指令字較長,增加了控制存儲器的橫向容量,同時微指令和機器指令的差別很大,設計者只有足夠熟悉數(shù)據(jù)通路,才能編制出理想的微程序。其復雜程度高,難以實現(xiàn)微程序設計自動化。當前55頁,總共89頁。2.垂直型微指令
垂直型微指令的特征是微指令較短,微指令的并行操作能力有限,一般一條微指令只能控制數(shù)據(jù)通路的一二種信息傳送操作。另外,執(zhí)行一條機器指令所需要的微指令數(shù)目較多,執(zhí)行時間長。這是它與水平型微指令相比不足的地方。但是,垂直型微指令與機器指令很相似,設計者只需注意微指令的功能,而對數(shù)據(jù)通路結構則不用過多考慮,因此便于編制微程序。編制的微程序規(guī)整、直觀,有利于設計的自動化。
當前56頁,總共89頁。3.水平型微指令與垂直型微指令的比較
水平型微指令垂直型微指令并行操作能力強弱效率高低靈活性強弱指令執(zhí)行時間短長復雜度高低與機器指令的差別大小當前57頁,總共89頁。6.4.6微指令的執(zhí)行方式
執(zhí)行微指令的過程與執(zhí)行機器指令有些類似。首先要從控制存儲器中取出微指令,如果是垂直型微指令,還需要包括微操作碼的譯碼過程;然后執(zhí)行微指令所規(guī)定的操作。具體說來,微指令分為串行執(zhí)行方式和并行執(zhí)行方式兩種。1.串行執(zhí)行在串行微程序控制器中,執(zhí)行現(xiàn)行微指令的操作與取下一條微指令的操作在時間上是串行的。只有在一條微指令取出并執(zhí)行完后,才能取下一條微指令。
當前58頁,總共89頁。1.串行執(zhí)行在串行執(zhí)行方式中,微指令周期等于取微指令的時間與執(zhí)行微操作時間的和。串行方式的微周期較長,但控制簡單,形成后繼微地址所用的硬件設備少。微指令的串行執(zhí)行與并行執(zhí)行
當前59頁,總共89頁。2.并行方式
并行執(zhí)行方式是將取微指令與執(zhí)行微指令的操作重疊起來執(zhí)行。即并行執(zhí)行方式下,在執(zhí)行當前微指令的同時,預取下一條微指令,從而節(jié)省了取微指令的時間。對于并行執(zhí)行方式,由于執(zhí)行本條微指令與預取下一條微指令是同時進行的,所以,如果遇到某些需要根據(jù)本條微指令的處理結果而進行條件轉移的微指令,先前預取的微指令就無用。此時可以通過延遲一個微周期再取微指令的方法解決。除了上述兩種方式外,還有串行和并行混合執(zhí)行方式。
當前60頁,總共89頁。6.4.7微程序舉例
當前61頁,總共89頁。6.4.7微程序舉例當前62頁,總共89頁。6.5流水線技術
加快機器指令執(zhí)行速度的其中一種重要方法。同時解釋執(zhí)行兩條、多條以至整段程序。流水(pipeline)線技術是目前廣泛應用于CPU中的一項關鍵技術。20世紀90年代以后出現(xiàn)的處理器,無論是RISC還是CISC,無一不采用“指令流水”技術。當前63頁,總共89頁。6.5.1流水線技術的基本原理1、流水線原理:計算機的流水處理過程同工廠中的流水裝配線類似。為了實現(xiàn)流水,首先必須把輸入的任務(或過程)分割為一系列子任務。使各子任務能在流水線的各個階段并發(fā)地執(zhí)行。將任務連續(xù)不斷地輸入流水線,從而實現(xiàn)了子任務級的并行。因此流水處理大幅度地改善了計算機的系統(tǒng)性能,是在計算機上實現(xiàn)時間并行性的一種非常經(jīng)濟的方法。在流水線中,原則上要求各個階段的處理時間相同。若某一階段處理時間較長,勢必造成其他階段的空轉等等。因此對子任務的劃分,是決定流水線性能的一個關鍵因素,它取決于操作部件的效率,所期望的處理速度,以及成本價格等等。當前64頁,總共89頁。2、并行處理技術并行性的含義:
一是同時性,指兩個以上事件在同一時刻發(fā)生;二是并發(fā)性,指兩個以上事件在同一時間間隔內發(fā)生。計算機的并行處理技術可貫穿于信息加工的各個步驟和階段,概括起來,有三種形式:(1)時間并行;(2)空間并行;(3)時間并行+空間并行。當前65頁,總共89頁。(1)時間并行時間并行:指時間重疊,在并行性概念中引入時間因素,讓多個處理過程在時間上相互錯開,輪流重疊地使用同一套硬件設備的各個部分,以加快硬件周轉而贏得速度。時間并行概念的實現(xiàn)方式就是采用流水處理部件。這是一種非常經(jīng)濟而實用的并行技術,能保證計算機系統(tǒng)具有高度的性能價格比。目前的高性能微型計算機幾乎無一例外地使用了流水技術。當前66頁,總共89頁。(2)空間并行指資源重復,在并行性概念中引入空間因素,以“數(shù)量取勝”為原則來大幅度提高計算機的處理速度。大規(guī)模和超大規(guī)模集成電路成為目前實現(xiàn)并行處理的一個重要途徑。空間并行技術主要體現(xiàn)在多處理器系統(tǒng)和多計算機系統(tǒng)。但是在但處理器系統(tǒng)中也得到了廣泛應用。當前67頁,總共89頁。(3)時間并行+空間并行時間并行+空間并行指時間重疊和資源重復的綜合應用,即采用時間并行性又采用空間并行性。例如,奔騰CPU采用了超標量流水技術,在一個機器周期中同時執(zhí)行兩條指令,因而既具有時間并行性,又具有空間并行性。顯然,第三種并行帶來的高速效益是最好的。當前68頁,總共89頁。3、流水CPU的時空圖假設流水CPU的一個指令周期包括四個字過程:取指令(IF)、指令譯碼(ID)、取操作數(shù)(OF)、進行運算(EX),每個子過程稱為過程段(Si),一個流水線由一系列串聯(lián)的過程段組成,各個過程段之間設有高速緩沖寄存器,以暫時保存上一過程段子任務處理的結果。在統(tǒng)一的時鐘信號控制下,數(shù)據(jù)從一個過程流向相鄰的過程段。當前69頁,總共89頁。4、流水CPU的時空圖當前70頁,總共89頁。非流水線時空圖對非流水計算機來說:上一條指令的四個子過程全部執(zhí)行完畢后才能開始下一條指令,因此,每隔四個時鐘周期才有一個輸出結果。當前71頁,總共89頁。超標量流水線時空圖所謂超標量流水,是指它具有兩條以上的指令流水線。當流水線滿載時,每一個時鐘周期可以執(zhí)行2條指令。顯然,超標量流水計算機是時間并行技術和空間并行技術的綜合利用。Pentium微型機就是一個超標量流水計算機。當前72頁,總共89頁。當前73頁,總共89頁。5、流水線分類指令流水線:實現(xiàn)指令步驟的并行。將指令流的處理過程劃分為取指、譯碼、取操作數(shù)、執(zhí)行等幾個并行處理的過程段。目前,所有高性能計算機都采用了指令流水線。算術流水線:實現(xiàn)運算操作步驟的并行。如流水加法器、流水乘法器等。處理機流水線(宏流水線):實現(xiàn)程序步驟的并行。由一串處理機構成流水線的各個過程段,每臺處理機負責某一特定的任務。數(shù)據(jù)流從第一臺處理機輸入,經(jīng)處理后被送到第二臺處理機相聯(lián)的緩沖存儲器中。第二臺處理機從該存儲器中取出數(shù)據(jù)進行處理,然后傳送至第三臺處理機,如此串聯(lián)下去,隨著高檔微處理芯片的出現(xiàn),構造處理機流水線變得容易,處理機流水線應用在多機系統(tǒng)中當前74頁,總共89頁。6.5.2流水線中的主要問題
1、資源相關2、數(shù)據(jù)相關3、控制相關當前75頁,總共89頁。1、資源相關當多條指令進入流水線后,在同一時間內對同一硬件發(fā)出請求時,硬件無法同時提供幾項服務,因而造成指令之間的資源沖突,稱為資源相關。當前76頁,總共89頁。資源相關的解決當前77頁,總共89頁。2、數(shù)據(jù)相關前一條指令和后一條指令可能需要同時存取相同的數(shù)據(jù)。例如在程序中,第一條指令寫入數(shù)據(jù),第二條指令讀取數(shù)據(jù)。為了避免數(shù)據(jù)沖突,必須等待第一條指令寫入內存后,才能執(zhí)行第二條指令。
當前78頁,總共89頁。2、數(shù)據(jù)相關根
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 電機驅動系統(tǒng)設計與優(yōu)化考核試卷
- 榫卯建筑課程設計
- 2024醫(yī)療期合規(guī)管理及醫(yī)療機構服務質量監(jiān)督與考核合同3篇
- 探索烏龜故事課程設計
- 相機實時取景與電子取景器考核試卷
- 電信服務在虛擬現(xiàn)實與增強現(xiàn)實中的應用考核試卷
- 符意德 硬件課程設計2
- 研學旅行課程設計恐龍
- 《填埋場污泥灰改性黏土襯墊開裂變形與三軸剪切試驗研究》
- 《液壓手腕關節(jié)伺服控制方法研究》
- 社會團體主要負責人登記表
- 難免壓力性損傷申報表
- 四線三格word模板
- 國家各部委專項資金申報種類
- 年會抽獎券可編輯模板
- 靜電場知識點例題結合
- 中醫(yī)醫(yī)案學三醫(yī)案的類型讀案方法
- 制造業(yè)信息化管理系統(tǒng)架構規(guī)劃
- 防雷裝置檢測質量管理手冊
- 化學錨栓計算
- 測井曲線及代碼
評論
0/150
提交評論