《計算機組成原理》第5章:指令系統.ppt
《《計算機組成原理》第5章:指令系統.ppt》由會員分享,可在線閱讀,更多相關《《計算機組成原理》第5章:指令系統.ppt(89頁珍藏版)》請在裝配圖網上搜索。
1、第5章 指令系統,(時間:3次課,6學時),第5章 指令系統,本章講述計算機指令功能、指令中包含的信息、指令的一般格式、被指令處理的數據如何存儲在計算機中、指令如何尋找被處理的數據、指令分類、指令系統的兼容性等問題,并列舉幾種類型的計算機指令系統,由此可以較為深刻地理解計算機指令和指令系統的意義。,第5章 指令系統,5.1 計算機指令概念 5.2 指令格式 5.3 數據的表示和存儲 5.4 尋址方式 5.5 指令類型 5.6 指令系統舉例 5.7 機器語言、匯編語言和高級語言,5.1 計算機指令概念,軟件系統分為許多層次,最低的一層就是緊臨硬件的一層,它直接控制計算機的硬件運行,這一層就是指令
2、系統。指令系統是一種型號的計算機所具有的全體指令的集合。不同型號的計算機有不同的指令系統,一般不兼容。 計算機正在執(zhí)行的指令(二進制信息)是存放在控制器的指令寄存器中的。一條指令的功能就是告訴計算機要完成什么操作,至于具體如何完成,必須將指令寄存器中的指令經控制器的譯碼電路和微命令發(fā)生器,產生微命令;經控制器的地址形成電路給出操作數地址;由微命令和操作數地址決定實際的操作步驟。,5.1 計算機指令概念,一般說來,指令系統中的一條指令包括兩大類信息,即操作信息和地址信息。 計算機指令系統的設置與計算機硬件結構密切相關。指令系統直接影響到計算機系統的性能,也直接影響到操作系統和編譯程序的編寫難度,
3、可見指令系統的設計是計算機系統設計中的一個核心問題。 系列(Series)計算機。 指令系統的改進是圍繞著縮小機器語言、匯編語言與高級語言的語義差異以及有利于操作系統的實現和優(yōu)化而進行的,它有利于高級語言程序的編譯和提高機器運行速度。,5.1 計算機指令概念,指令系統太復雜也會帶來一些不利因素,為了解決這個問題,70年代末人們提出了便于VLSI實現的精簡指令系統計算機,簡稱RISC;與之相應的便是復雜指令系統計算機,簡稱CISC。,5.2 指 令 格 式,計算機的指令格式與機器字長、存儲器的容量以及指令的功能都有很大關系。為了便于程序設計、增加基本操作的并行性、增強指令功能,指令中包含的信息越
4、多越好。然而如果所有指令都取相同長度的話,那么在有些指令中,一部分信息將是沒有意義的,這就浪費了指令所占的存儲空間,從而增加了訪存次數,可能使整個指令執(zhí)行時間更長。因此,如何科學合理地設計指令格式,使指令既能給出足夠信息,其長度又盡可能與機器的字長相匹配,從而節(jié)省存儲空間,縮短取指周期,達到提高機器性能的目的,一直是指令格式設計中的一個重要問題。,5.2 指 令 格 式,5.2.1 指令的一般格式 5.2.2 指令操作碼的擴展技術 5.2.3 指令長度與字長的關系,5.2.1 指令的一般格式,計算機通過執(zhí)行指令來處理各種數據。為了指出數據的來源、操作結果的去向及所執(zhí)行的操作,一條指令必須包含下
5、列信息。 操作碼 操作數的地址。 下一條指令的地址 根據上述分析可知,一條指令實際上包括兩種信息,即操作碼和地址碼。 零地址指令,OP CODE,2. 一地址指令,3. 兩地址指令,4. 三地址指令,5.2.1 指令的一般格式,5. 多地址指令 在某些性能較好的大、中型機甚至高檔次小型機中,往往設置一些功能很強、用于處理成批數據的指令,如字符串處理指令,向量、矩陣運算指令。為了描述一批數據,指令中需要多個地址來指出數據存放的首地址、長度和下標等信息。 以上所述的幾種指令只是一般情況,并非所有計算機都具有。零地址、一地址和兩地址指令具有指令短、執(zhí)行速度快、硬件實現簡單等特點,多為結構較簡單、字長
6、較短的小型、微型機所采用;而兩地址、三地址和多地址指令具有功能強、便于編程等特點,多為字長較長的大、中型機所采用。但也不能一概而論。,5.2.1 指令的一般格式,,5.2.2 指令操作碼的擴展技術,,指令的操作碼長度決定了指令系統中完成不同操作的指令條數。若某機器的操作碼長度為K位,則它最多只能有2K條不同指令。指令操作碼通常有兩種編碼格式,一種是固定格式,即操作碼的長度固定,且集中放在指令字的一個字段中。這種格式對于簡化硬件設計、減少指令譯碼時間非常有利,在字長較長的大、中型機和超級小型機以及RISC上廣泛使用。另一種是可變格式,即操作碼的長度可變,且分散地放在指令字的不同字段中。這種格式能
7、夠有效地壓縮程序中操作碼的平均長度,在字長較短的微型機上廣泛采用。,5.2.2 指令操作碼的擴展技術,顯然,操作碼長度不固定將增加指令譯碼和分析的難度,使控制器的設計復雜化,因此對操作碼的編碼至關重要。通常是在指令字中用一個固定長度的字段來表示基本操作碼,而對于一部分不需要某個地址碼的指令,則把它們的操作碼擴展到該地址字段,這樣,既能充分地利用指令字的各個字段,又能在不增加指令長度的情況下擴展操作碼的長度,使它可以表示更多的指令。例如,設某機器的指令長度為16位,包括4位基本操作碼字段和3個4位地址字段,其格式如圖5-1所示。,圖5-1 指令格式,5.2.2 指令操作碼的擴展技術,(1)15條
8、三地址指令的操作碼由4位基本操作碼給出,范圍為00001110,剩下一個碼點1111用于把操作碼擴展到A1,即從4位擴展到8位。 (2)15條二地址指令的操作碼由擴展后的8位操作碼給出,范圍為1111000011111110,剩下一個碼點11111111用于把操作碼擴展到A2,即從8位擴展到12位。 (3)15條一地址指令的操作碼由12位操作碼給出,范圍為111111110000111111111110,剩下一個碼點111111111111用于把操作碼擴展到A3,即從12位擴展到16位。 (4)16條零地址指令的操作碼使用16位,范圍為11111111111100001111111111111
9、111。,5.2.2 指令操作碼的擴展技術,除了上述方法外,還有其他許多擴展方法,如可以形成15條三地址指令、14條兩地址指令、31條一地址指令和16條零地址指令,共76條指令。實際上,指令操作碼是有空余的。在可變長度的指令系統的設計中,到底使用何種擴展方法,所要遵循的一個重要原則是,使用頻度(即指令在程序中出現的概率)高的指令應分配較短的操作碼;使用頻度低的指令應分配較長的操作碼。這樣,不僅可以有效地縮短操作碼在程序中的平均長度,節(jié)省存儲器空間,而且縮短了經常使用的指令的譯碼時間,因而可以提高程序的運行速度。,5.2.2 指令操作碼的擴展技術,這里特別強調指出,計算機中的指令操作碼總是希望有
10、一定的規(guī)整性,否則會使硬件實現復雜化。此外,為了便于在計算機內存放,指令的長度一般是字節(jié)的整數倍,所以操作碼與地址碼兩部分長度之和就應該是字節(jié)的整數倍,因此在考慮操作碼長度時還應考慮地址碼的要求。 由此可見,操作碼擴展技術是一種重要的指令優(yōu)化技術,它可以縮短指令的平均長度,減少程序的總位數以及增加指令字所能表示的操作信息。擴展操作碼比固定操作碼譯碼復雜,使控制器的設計難度增大,也需要更多的硬件來支持。,5.2.3 指令長度與字長的關系,字長是指計算機能直接處理的二進制數據的位數,它與計算機的功能和用途有很大的關系,是計算機的一個重要技術指標。首先,字長決定了計算機的運算精度,字長越長,計算機
11、的運算精度越高,因此,高性能的計算機字長較長,而性能較差的計算機字長相對要短。其次,地址長度決定了指令直接尋址能力,若為n 位,則給出的n 位直接地址可以尋址2n字節(jié)。這對于字長較短(8位或16位)的微型機來說,遠遠滿足不了實際需要。擴大尋址能力的方法,一是通過增加機器字長來增加地址碼的長度;二是采用地址擴展技術,把存儲空間分成若干個段,用基地址加位移量的方法來增加地址碼的長度。,5.2.3 指令長度與字長的關系,為了便于處理字符數據和盡可能地充分利用存儲空間,一般機器字長都是字節(jié)長度(即8位)的1、2、4或8倍,也就是8、16、32、64位。20世紀80年代的微型機的字長多為8、16和32位
12、,大中型機的字長多為32位和64位,因此,一個字中可以存儲1、2、4或8個字符。隨著電路集成度的提高,機器字長也在增長,16位微機也趨于淘汰。 指令的長度主要取決于操作碼的長度、操作數地址的長度和操作數地址的個數。由于操作碼的長度、操作數地址的長度及所采用的格式不同,各指令的長度不是固定的,但也不是任意的。為了充分利用存儲空間,指令的長度通常為字節(jié)的整數倍。,5.2.3 指令長度與字長的關系,指令的長度與機器的字長沒有固定關系,它既可以小于或等于機器的字長,也可以大于機器字長。前者稱為短格式指令,后者稱為長格式指令,一條指令存放在地址連續(xù)的存儲單元中。在同一臺計算機中可能既有短格式指令,又有
13、長格式指令,但通常是把最常用的指令(如算術邏輯運算指令、數據傳送指令)設計成短格式指令,以便節(jié)省存儲空間和提高指令的執(zhí)行速度。,5.3 數據的表示和存儲,計算機中的基本數據有邏輯(布爾)數、定點數(整數)、浮點數(實數)、十進制、字符串、數組等。對這些數據的運算可以設置專門的指令,也可以僅設置最簡單的算術邏輯運算指令,再通過執(zhí)行程序來實現對其他類型數據的處理,但后者的速度下降許多。在機器中,若設置能直接對矩陣向量數據(數組)進行運算的指令(增加相應的硬件),可以大大提高對向量(數組)的處理速度,這一般只在巨型計算機中才采用。 目前計算機所用的數據字長一般為32位,而存儲器地址一般按字節(jié)表示,
14、即一個存儲單元只能存放一個字節(jié)的數據,因此一條指令通常要占用幾個存儲單元,使用幾個存儲器地址。,5.3 數據的表示和存儲,計算機指令系統可支持對字節(jié)、半字、字、雙字的運算,有些計算機有位處理指令。為便于硬件實現,一般要求多字節(jié)數據對準邊界,如圖5-2(a)所示。當所存數據不能滿足此要求時,則填充一個或多個空白字節(jié)。也有的計算機不要求對準邊界,但可能增加訪問存儲器次數。假如存儲器與運算部件間數據通路的寬度為32位(一個字),在不按邊界對準的計算機中,訪存指令所要求存取的數據(例如一個字)可能在兩個存儲單元中,因此需要訪問兩次存儲器,而且還要對高低字節(jié)的位置進行調整,圖5-2(b)中的陰影部分即屬
15、這種情況。,(a) 多字節(jié)數據對準邊界,圖5-2 存儲器中數據的存放舉例,(b) 數據不對準邊界,5.3 數據的表示和存儲,在數據對準邊界的計算機中,當以二進制來表示地址時,半字地址的最低位恒為零,字地址的最低兩位為零,雙字地址的最低三位為零。圖5-3為按字節(jié)編址的雙字數據的兩種字節(jié)次序:低字節(jié)為低地址,如圖5-3(a)所示;高字節(jié)為低地址,如圖5-3(b)所示。,(a) 低字節(jié)為低地址,(b) 高字節(jié)為低地址,圖5-3 兩種字節(jié)次序,5.4 尋 址 方 式,在執(zhí)行一條指令的時候,操作數可能在運算部件的某個寄存器中或存儲器中,也可能就在本指令中。正在運行的程序總是存放在存儲器(內存)中,正在執(zhí)
16、行的指令總是在CPU內控制器的指令寄存器中。所謂尋址方式(或編址方式)指的是確定本條指令的數據地址及下一條要執(zhí)行的指令地址的方法,它與計算機硬件結構緊密相關,而且對指令格式和功能影響很大。從程序員角度看,尋址方式與匯編程序設計的關系極為密切;與高級語言的編譯程序設計也同樣密切。不同的計算機有不同的尋址方式,但其基本原理是相同的。有的計算機尋址種類少,因此在指令的操作碼中表示出尋址方式;而有的計算,5.4 尋 址 方 式,機采用多種尋址方式,此時在指令中專設一個字段表示一個操作數的來源或去向。這里僅介紹幾種被廣泛采用的基本尋址方式。在一些計算機中,某些尋址方式可以組合使用,從而形成更復雜的尋址方
17、式。,5.4 尋 址 方 式,,1. 直接尋址 對直接尋址方式來說,指令的地址碼部分直接給出操作數在存儲器中的地址,圖5-4(a)僅給出一個操作數地址;當有多個地址時,情況類似。直接尋址方式可以由操作碼表示出來。圖5-4(b)在指令中增加了一個尋址方式字段M,假如M為3位二進制碼,則可表示8種尋址方式。,,圖5-4 直接尋址方式,5.4 尋 址 方 式,2. 寄存器尋址 計算機的中央處理器中一般設置有一定數量的通用寄存器,用以存放操作數、操作數的地址或中間結果。假如地址碼部分給出某一通用寄存器地址,而且所需的操作數就在這一寄存器中,則稱為寄存器尋址。通用寄存器的數量一般在幾個至幾十個之間,
18、比存儲單元少得多,因此地址碼短,而且對寄存器存取數據比對存儲器存取數據快得多,所以這種尋址方式可以縮短指令長度,節(jié)省存儲空間,提高指令的執(zhí)行速度,因而在計算機中得到廣泛應用。,5.4 尋 址 方 式,3. 基址尋址 基址尋址是指在計算機中設置一個專用的基址寄存器,或由指令指定一個通用寄存器作為基址寄存器。操作數的地址由基址寄存器的內容和指令的地址碼A相加得到,如圖5-5所示。在這種情況下,地址碼A通常被稱為位移量(Disp)。也可用其他方法獲得位移量。,圖5-5 基址尋址過程,5.4 尋 址 方 式,,4. 變址尋址 變址尋址的過程如圖5-6所示。指令地址碼部分給出的地址A和指定的變址寄存器R
19、的內容通過加法器相加,所得的和作為地址從存儲器中讀出所需的操作數。這是幾乎所有計算機都采用的一種尋址方式。如果計算機中還有基址寄存器,則在計算有效地址時還要加上基址寄存器內容。,,圖5-6 變址尋址過程,5.4 尋 址 方 式,,5. 間接尋址 在尋址時,若根據指令的地址碼所取出的內容是操作數的地址或指令地址,這種尋址方式就稱為間接尋址或間址。根據地址碼指的是寄存器地址還是存儲器地址,間接尋址又可分為寄存器間接尋址和存儲器間接尋址兩種方式。間接尋址有一次間址和多次間址兩種情況,大多數計算機只允許一次間址。對于存儲器一次間址來說,需要訪問兩次存儲器才能取得數據,第一次從存儲器讀出的是操作數的地址
20、,第二次才讀出操作數。,5.4 尋 址 方 式,,圖5-7(a)、(b)分別為寄存器間接尋址與存儲器間接尋址的操作數尋址過程。圖5-8以轉移指令JUMP為例,說明在直接尋址和間接尋址方式下,如何確定下一條要執(zhí)行的指令地址。,(a) 寄存器間接尋址,(b) 存儲器間接尋址,圖5-7 間接尋址過程,,(a) 直接尋址,(b) 間接尋址,圖5-8 確定JUMP指令的轉移地址,5.4 尋 址 方 式,,,6. 相對尋址 把程序計數器PC的內容(即當前正在執(zhí)行的指令地址)與地址碼部分給出的位移量(Disp)之和作為操作數的地址或轉移地址,稱為相對地址。主要用于轉移指令,執(zhí)行本條指令之后,將轉移到(PC)
21、+Disp,(PC)表示程序計數器的內容。相對尋址有兩個特點:第一,轉移地址不是固定的,它隨著PC值的變化而變化,并且總是相差一個固定值Disp,因此無論程序裝入存儲器的任何地方,均能正確運行,對浮動程序很適用。第二,位移量可正可負,通常用補碼表示。若位移量為n位,則這種方式的尋址范圍在到之間。,5.4 尋 址 方 式,,當前計算機的程序和數據一般是分開存放的,程序區(qū)在程序執(zhí)行過程中不允許修改。在程序與數據分區(qū)存放的情況下,不用相對尋址方式來確定操作數地址。 7. 立即數 所需的操作數由指令的地址碼部分直接給出,就稱為立即數(或直接數)尋址方式。這種方式的特點是,取指時操作碼和一個操作數同時被
22、取出,不必再次訪問存儲器,提高了指令的執(zhí)行速度。但是由于這一操作數是指令的一部分,不能修改,而一般情況下,指令所處理的數據都是在不斷變化的(如上條指令執(zhí)行的結果是下條指令的操作數),故這種方式只能適用于操作數固定的情況。通常用于給某一寄存器或存儲器單元賦初值或提供一個常數。,5.5 指 令 類 型,一臺計算機的指令系統通常有幾十條至幾百條指令,按其所完成的功能可分為算術邏輯運算指令、移位操作指令、浮點運算指令、十進制運算指令、字符串處理指令、向量運算指令、數據傳送指令、轉移類指令、堆棧操作指令、輸入/輸出指令、特權指令。本節(jié)分別說明各類指令的功能。,5.5 指 令 類 型,,1. 算術邏輯運算
23、指令 一般計算機都有算術邏輯運算指令。通常計算機具有對兩個數進行與、或、非(求反)、異或(按位加)等操作的邏輯運算指令。有些計算機還設置有位操作指令,如位測試(測試指定位的值)、位清除(把指定位清零)、位求反(取某位的反值)指令等。 2. 移位操作指令 移位操作指令分為算術移位、邏輯移位和循環(huán)移位3種,可以將操作數左移或右移若干位,如圖5-9所示。,圖5-9 各種移位的操作過程,5.5 指 令 類 型,3. 浮點運算指令 高級語言中的實數(Real)經常是先轉換成浮點數的形式再進行處理。某些機器沒有設置浮點運算指令而用子程序實現,其速度較低。因此主要用于科學計算的計算機應該設置浮點運算指
24、令,一般能對單精度(32位)、雙精度(64位)數據進行處理。 4. 十進制運算指令 在人機交互作用時,輸入/輸出的數據都是以十進制形式表示的。在某些數據處理系統中輸入/輸出的數據很多,但對數據本身的處理卻很簡單。在不具有十進制運算指令的計算機中,首先將十進制數轉換成二進制數,再在機器內運算;而后又轉換成十進制數據輸出。在輸入/輸出頻繁的計算機系統中,設置十進制運算指令能提高數據處理的速度。,5.5 指 令 類 型,5. 字符串處理指令 字符串處理指令是一種非數值數據的處理指令,一般包括字符串傳送、字符串比較、字符串查詢、字符串轉換等指令。其中,字符串傳送指令所完成的操作是將數據塊從主存儲器
25、的某區(qū)域傳送到另一區(qū)域;字符串比較指令所完成的操作是將一個字符串與另一個字符串逐個字符進行比較,以確定其是否相等;字符串查詢是查找在字符串中是否含有另一指定的子串或字符;字符串轉換是指將一種數據表達形式轉換成另一種表達形式,例如從ASCII碼轉換成EBCDIC碼(擴充的二-十進制交換碼)。這種指令在需對大量字符串進行各種處理的文字編輯和排版方面非常有用。,5.5 指 令 類 型,6. 數據傳送指令 數據傳遞指令用以實現寄存器與寄存器、寄存器與存儲器單元、存儲器單元與存儲器單元之間的數據傳送。對于存儲器來講,數據傳送包括了對數據的讀(相當于取數指令)或寫(相當于存數指令)操作。數據傳送時,數據
26、從源地址傳送到目的地址,而源地址中的數據保持不變,因此實際上是數據復制。 7. 轉移類指令 轉移類指令用以控制程序流的轉移。在大多數情況下,計算機是按順序方式執(zhí)行程序的,但是也經常會遇到離開原來的順序轉移到另一段程序或循環(huán)執(zhí)行某段程序的情況。,,5.5 指 令 類 型,按轉移的性質,轉移指令分為無條件轉移、條件轉移、過程調用與返回、陷阱(Trap)等幾種。 1)無條件轉移與條件轉移 2)調用指令與返回指令 3)陷阱與陷阱指令 8.堆棧及堆棧操作指令 堆棧(Stack)是由若干個連續(xù)存儲單元組成的先進后出(FILO)存儲區(qū),第一個送入堆棧中的數據存放在棧底,最近送入堆棧中的數據存放在棧頂。棧底
27、是固定不變的,而棧頂卻是隨著數據的入棧和出棧在不斷變化。為了表示棧頂的位置,有一個寄存器或存儲器單元用于指出棧頂的地址,這個寄存器或存儲器單元就稱為堆棧指針SP(Stack Pointer)。任何堆棧操作只能在棧頂進行。,,5.5 指 令 類 型,壓入指令 PUSH OPR 把OPR(長度為兩個字節(jié))壓入堆棧 操作是:(SP)-2SP,OPR(SP) 彈出指令 POP OPR 彈出一個數據(長度為兩個字節(jié))送OPR 操作是:((SP))OPR,(SP)+2SP 由于堆棧具有先進后出的性質,因而在中斷、子程序調用過程中廣泛用于保存返回地址、狀態(tài)標志及現場信息。 堆棧還有一個重要的作用,就是
28、用于子程序調用時參數的傳遞,特別是在不同語言程序之間相互調用過程中,使用堆棧來傳遞數據更加普遍。,,5.5 指 令 類 型,9. 輸入/輸出(I/O)指令 計算機所處理的一切原始數據和所執(zhí)行的程序(除了固化在ROM中的以外)均來自外部設備的輸入,處理結果需要外部設備輸出。輸入/輸出指令的一般格式是OP REG A。其中,OP是操作碼,表示I/O指令。REG是寄存器名,用于指定與外部設備交換數據的CPU中的某寄存器。A是外部設備接口中的寄存器地址或設備碼,其長度一般為8位或16位,可以表示25664K個設備寄存器(接口中有3類寄存器,即輸入數據寄存器、輸出數據寄存器和控制寄存器)。輸入指令用于從
29、A地址所指定的外部設備寄存器中讀入一個數據到REG寄存器中;輸出指令剛好相反,把REG寄存器中的數,5.5 指 令 類 型,,據送到A地址所指定的外部設備寄存器中。此外,I/O指令還可用來發(fā)送控制命令和接收回答信號,用以控制外部設備的工作。 10. 特權指令 某些指令使用不當會破壞系統或其他用戶信息,因此為了安全起見,這類指令只能用于操作系統或其他系統軟件,而不提供給用戶使用,稱為特權指令。 11. 其他指令 其他指令包括向量指令、多處理機指令和控制指令??刂浦噶畎ǖ却噶睿C指令,空操作指令,開中斷、關中斷、置條件碼指令。,,5.6 指令系統舉例,下面通過幾種類型計算機指令系統的介紹來
30、增加認識,這些計算機(或處理器)是Sun微系統公司的SPARC90(RISC)、IBM 360/370系列(CISC)、PDP 11/VAX 11(CISC)系列,Intel公司的Pentium系列(基于RISC的處理器內核)。,5.6 指令系統舉例,5.6.1 SPARC的指令系統 5.6.2 IBM大型機指令系統 5.6.3 PDP 11與VAX 11基本指令格式 5.6.4 Pentium 的指令系統,5.6.1 SPARC的指令系統,SPARC指令字長32位,有3種指令格式、6種指令類型。 1SPARC的指令類型 1)算術運算/邏輯運算/移位指令 加法指令4條:ADD、ADDCC、AD
31、DX、ADDXCC。 減法指令4條:SUB、SUBCC、SUBX、SUBXCC。 檢查標記的加法指令2條:TADDCC、TADDCCTV。 檢查標記的減法指令2條:TSUBCC、TSUBCCTV。 邏輯運算指令共12條:AND、ANDCC、ANDN、ANDNCC;OR、ORCC、ORN、ORNCC;XOR、XORCC、XORN、XORNCC。,,5.6.1 SPARC的指令系統,移位指令3條:SLL(邏輯左移)、SRL(邏輯右移)、SRA(算術右移)。 其他還有乘法步、SETHI、SAVE、RESTORE等。SAVE和RESTORE兩條指令分別將現行窗口指針減1和加1。 現在對4條加法指令進行
32、說明。以CC結尾的加法指令表示除了進行加法運算以外還要根據運算結果置狀態(tài)觸發(fā)器N、Z、V、C;X表示加進位信號;XCC表示加進位信號并置N、Z、V、C。 2)LOAD/STORE指令 取/存字節(jié)(LDSB/STB)、半字、字、雙字共20條指令,其中一半是特權指令。,5.6.1 SPARC的指令系統,SPARC結構將存儲器分成若干區(qū),其中有4個區(qū)分別為用戶程序區(qū)、用戶數據區(qū)、系統程序區(qū)和系統數據區(qū)。并規(guī)定在執(zhí)行用戶程序時,只能從用戶程序區(qū)取指令,在用戶數據區(qū)存取數據;而執(zhí)行系統程序時則可以使用特權指令訪問任一區(qū)。 另外還有兩條供多處理機系統使用的數據交換指令SWAP和讀后置字節(jié)指令LDSTUB。
33、 3)控制轉移類指令5條。 4)讀/寫專用寄存器指令8條。 以上指令共計66條。 5)浮點運算指令。 6)協處理器指令。,5.6.1 SPARC的指令系統,由于SPARC為整數運算部件(IU),所以當執(zhí)行浮點運算指令或協處理器指令時,將交給浮點運算器或協處理器處理,當機器沒有配置這種部件時,將通過子程序實現。 2SPARC的指令格式,,,格式1:CALL指令,格式2:SETHI指令和BRANCH指令,,5.6.1 SPARC的指令系統,,格式3:其他指令,,3. 各類指令的功能及尋址方式 下面簡單介紹第一類至第四類指令。 1)算術邏輯運算指令 功能:(rs1)OP(rs2) rd (當i=0
34、時) (rs1) OP Simm13 rd (當i=1時) RISC的特點之一是所有參與算術邏輯運算的數均在寄存器中。,5.6.1 SPARC的指令系統,2)LOAD/STORE指令(取數/存數指令) 功能:LOAD指令將存儲器中的數據送往rd中;STORE指令將rd的內容送往存儲器中。 存儲器地址的計算(寄存器間接尋址方式):當i=0時,存儲器地址=(rs1)+(rs2);當i=1時,存儲器地址=(rs1)+Simm13。在RISC中,只有LOAD/STORE指令訪問存儲器。 3)控制轉移類指令 控制轉移類指令用于改變PC值,SPARC有以下5種控制轉移指令。 (1)條件轉移(BRANCH
35、):根據指令中的Cond字段(條件碼)決定程序是否轉移。轉移地址由相對尋址方式形成。,,5.6.1 SPARC的指令系統,(2)轉移并連接(JMPL):采用寄存器間址方式形成轉移地址,并將本條指令的地址(即PC值)保存在以rd為地址的寄存器中,以備程序返回時用。 (3)調用(CALL):采用相對尋址方式形成轉移地址。為了擴大尋址范圍,本條指令的操作碼只取兩位,位移量有30位。 (4)陷阱(TRAP):采用寄存器間址方式形成轉移地址。 (5)從TRAP程序返回(RETT):采用寄存器間址方式形成返回地址。 4)讀/寫專用寄存器指令 SPARC有4個專用寄存器(PSR、Y、WIM、TBR),其中
36、PSR稱為程序狀態(tài)寄存器。,5.6.2 IBM大型機指令系統,現在簡單介紹IBM 360/370的結構及指令系統。IBM 360是32位機器,按字節(jié)尋址,支持的數據類型有字節(jié)、半字、字、雙字(雙精度實數)、裝配的十進制數(用4位二進制碼表示一個十進制數,一個字節(jié)放兩個十進制數字)和未經裝配(拆卸)的字符串(一個字節(jié)放一個字符)。機內有16個32位通用寄存器,4個雙精度(64位)浮點寄存器。 IBM 360/370有5種指令格式,如圖5-10所示。,圖5-10 IBM 360/370 指令格式,5.6.2 IBM大型機指令系統,(1)RR(寄存器-寄存器)格式:兩個源操作數都在寄存器中,結果放在
37、第一個源寄存器中。 (2)RX(寄存器-變址):第一個源操作數與結果放在同一寄存器中,第二個源操作數在存儲器中,其地址為(X2)+(B2)+D2,D2為12位位移量(無符號)。 (3)RS(寄存器-寄存器):R1是存放結果的目的寄存器,R3為源操作數寄存器,另一個操作數在存儲器中,其地址為(B2)+D2。RS與RX的區(qū)別在于RS是三地址格式,并取消了變址寄存器。 (4)SI(寄存器-立即數):將立即數imm(8位)送到存儲器,其地址為(B1)+D1。 (5)SS(存儲器-存儲器):兩個操作數都在存儲器,5.6.2 IBM大型機指令系統,中,其地址分別為(B1)+D1和(B2)+D2,(B1)+
38、 D1還是目的地址。SS格式用于十進制運算與字符串處理,數據長度(Length)字段可定義為1個長度(1256個字符)或兩個長度(每一個為116個十進制數)。,5.6.3 PDP 11與VAX 11基本指令格式,VAX 11/780是DEC公司于1977年推出的VAX系列的第一個產品,它將PDP 11結構從16位擴充到32位。VAX是一種通用寄存器機器,它有16個通用寄存器,但是R14是堆棧指針,R15為程序計數器PC,是專用的,因此只有其他14個才是真正的通用寄存器。 VAX的數據類型:整數有8、16、32、64、128位5種類型,浮點數有32、64、128位3種表示方式。另外有8n位字符串
39、、4n 位BCD碼,其中n為字符或數字的數量。VAX還支持固定或可變長度的位串(最長為32位)處理。,,5.6.3 PDP 11與VAX 11基本指令格式,PDP 11是16位小型機,它有兩組通用寄存器(R0R5),在任一時刻只有一組工作;3個硬件堆棧指示器(R6);一個程序計數器PC(R7)。根據兼容性質,VAX 11應包括PDP 11的全部指令與尋址方式,即PDP11上的程序不做任何修改即可在VAX 11上運行。現以PDP 11的單操作數指令與雙操作數指令為例,對它們的指令格式與尋址方式作簡單介紹。,5.6.3 PDP 11與VAX 11基本指令格式,1.單操作數指令,,指令格式:,第15
40、6位表示操作碼。第50位組成一個6位的字段,既是源地址字段也是目的地址字段。第20位說明本指令使用8個寄存器中的哪一個,第53位表示使用哪種尋址方式。其中第3位為0時表示直接尋址,第3位為1時表示間接尋址,第54位表示4種基本尋址方式。 單操作數指令有清除(CLR)、增1(INC)、減1(DEC)、求補(NEG)、測試(TST)等。,5.6.3 PDP 11與VAX 11基本指令格式,2.雙操作數指令,指令格式:,第1512位表示操作碼。第116位組成一個6位字段,為源地址字段(第一操作數);第50位組成另一個6位字段,既是源操作數字段(第二操作數),也是目的操作數字段。 雙操作數指令有傳送(
41、MOV)、加(ADD)、減(SUB)、比較(CMP)、按位加(XOR)、邏輯加(BIS)等。,5.6.3 PDP 11與VAX 11基本指令格式,3. 轉移指令,,指令格式:,轉移地址=PC+2位移量,4. 尋址方式 這里只講述單操作數指令與雙操作數指令的尋址方式。 1)直接尋址 表5-1列出了直接尋址的4種基本方式?,F以ADD指令為例,來說明尋址方式。,表5-1 直接尋址方式,5.6.3 PDP 11與VAX 11基本指令格式,(1)ADD R2,R4,操作:R2內容加到R4的內容上。 例: 操 作 前 操 作 后,,5.6.3 PDP 11與VAX 11基本指令格式,(2)ADD(R
42、2)+,R4 指令代碼062204 操作:R2內容為操作數地址,將此操作數加到R4的內容上,然后R2的內容加2。 例: 操作前 操作后,,5.6.3 PDP 11與VAX 11基本指令格式,(3)ADD-(R3),R0 指令代碼064300 操作:R3內容減2后作為操作數地址,將此操作數加到R0的內容上。 例: 操作前 操作后,,5.6.3 PDP 11與VAX 11基本指令格式,(4)ADD 30(R2),20(R5) 指令代碼066265 操作:R2內容加30(加和是001130)作為源操作數地址,R5內容加20(加和是002020)作為另一源操作數
43、和目的操作數地址,兩個操作數相加后,結果(加和是000002)存放在目的地址(002020)中。 例: 操作前 操作后,,5.6.3 PDP 11與VAX 11基本指令格式,2)間接尋址 表5-2列出了間接尋址的4種方式。間接尋址方式類似于相應的直接尋址方式,這里僅舉兩例說明。,表5-2 間接尋址方式,5.6.3 PDP 11與VAX 11基本指令格式,(1)ADD (R2),R1 指令代碼061201 ADD R2,R1 操作前 操作后,,5.6.3 PDP 11與VAX 11基本指令格式,(2)變址間接方式 ADD 1000(R2),R1 指令代碼
44、067201 當PC作為通用寄存器時,表5-1和表5-2中列出的尋址方式仍適用,特別是表5-3中所列出的幾種情況有特殊的效果。,表5-3 PC作為通用寄存器的特殊尋址方式,5.6.3 PDP 11與VAX 11基本指令格式,操作前 操作后,,5.6.4 Pentium 的指令系統,Pentium 是完全的32位機。由于它是Intel公司在IBM PC上使用的8088CPU的嫡系后代,所以雖然Pentium 的性能與8088相比已不可同日而語,但可以完全向下兼容到8088。Intel公司的x86系列CPU采用的是CISC指令系統的設計思想,指令系統規(guī)模很龐大,但Pentium 卻采
45、用了一個基于RISC的處理器內核,使用了RISC的大量特性,使Intel公司的x86系列微處理器的性能上升到一個嶄新的層次。 1Pentium 的指令格式 Pentium 的指令格式比較繁雜,最多可有6個變長域,其中5個是可選的,如圖5-11所示。,圖5-11 Pentium 的指令格式,5.6.4 Pentium 的指令系統,(1)前綴字節(jié):前綴字節(jié)是一個額外的操作碼,它附加在指令的最前面,用于改變指令的操作。 (2)操作碼字節(jié):操作碼的最低位用于指示操作數是字節(jié)還是字,次低位用于指示內存地址(若需要訪問內存的話)是源地址還是目的地址。 (3)模式字節(jié):模式字節(jié)包含了與操作數有關的信息。該
46、字節(jié)可分為2位的MOD字段及兩個3位的寄存器字段REG和R/M。在某些情況下,模式字節(jié)的前3位可用做操作碼擴展,這時操作碼的長度就是11位。,5.6.4 Pentium 的指令系統,Pentium 指令系統規(guī)定操作數中必須有一個是在寄存器中。模式字段MOD與R/M字段組合定義另一個操作數的尋址方式,REG字段規(guī)定了另一個操作數所在的寄存器。 從邏輯上來說,EAX、EBX、ECX、EDX、ESI、EDI、EBP和ESP中的任意一個都可以用于源操作數寄存器和目的操作數寄存器。但是編碼規(guī)則禁止了其中的某些組合,而把它們用于特殊的目的。,,5.6.4 Pentium 的指令系統,(4)額外模式字節(jié)SI
47、B:SIB字節(jié)定義了一個比例因子(Scale)和兩個寄存器。當出現SIB字節(jié)的時候,計算操作數地址的方法是:先用變址寄存器(Index)乘上1、2、4或者8(由比例因子決定),然后再加上基址寄存器(Base),最后再根據MOD字節(jié)來決定是否要加上一個8位或者32位的偏移量。 (5)偏移量:偏移量字節(jié)給出了1、2或者4個字節(jié)的內存地址。 (6)立即數:立即數字節(jié)給出了1、2或者4個字節(jié)的常量。,,5.6.4 Pentium 的指令系統,2Pentium 的尋址方式 Pentium 具有很大的地址空間,采用了段頁式存儲管理模式,即將內存分為16384個段,每個段的容量為4GB,按0232-1進行編
48、址,地址長度為32位,按照小端排序(低位地址存放在低位字節(jié))的方式存儲字。 Pentium配備了大量的寄存器,包括基本體系結構寄存器、系統級寄存器、調試和測試寄存器、浮點寄存器等,其中32位的通用寄存器不僅可用于處理32位的數據,還可用于處理16位和8位數據,以滿足用戶的不同要求。,,,,5.6.4 Pentium 的指令系統,為了滿足向下兼容的要求,Pentium的尋址方式非常沒有規(guī)律,它支持的尋址方式包括立即尋址、直接尋址、寄存器尋址、寄存器間接尋址、變址尋址、基址加變址尋址、相對尋址和用于數組元素的特殊尋址方式。當然,并不是所有的指令都具有所有的尋址方式,也不是所有的寄存器都能用于所有
49、的尋址方式。表5-4給出了32位模式下的尋址方式。,表5-4 Pentium 的32位尋址方式(Mx表示x處的內存字),5.6.4 Pentium 的指令系統,3Pentium 的指令類型 Pentium指令系統包括如下指令類型:數據傳送類指令,算術運算類指令,邏輯運算類及位處理指令,字符串操作類指令,程序控制類指令,系統寄存器、表控制類指令,系統和Cache控制類指令,MMX(Multi-Media Extension)指令集。 由于Pentium 的指令系統比較龐大,這里就不具體列出了,需要時可參看有關資料。 4Pentium 的指令前綴 Pentium 的指令前綴是可以放在大多數指令之
50、前的一個特殊字節(jié),用于控制指令的執(zhí)行過程。例如:,5.6.4 Pentium 的指令系統,REP 前綴表示重復執(zhí)行指令,直到ECX變成0。 REPZ 前綴表示重復執(zhí)行指令,直到條件碼Z 變?yōu)?。 REPNZ 前綴表示重復執(zhí)行指令,直到條件碼Z 變?yōu)?。 LOOK 前綴為整條指令保留總線,以允許多處理機同步。 還有一些指令前綴可以使指令運行于16位模式或者32位模式下。這些指令前綴不僅需要指令改變操作數的長度,而且需要徹底地重新定義操作數的尋址方式。,5.7 機器語言、匯編語言和高級語言,計算機能夠直接識別并執(zhí)行的語言只能是一種用二進制碼表示的、由一系列指令組成的機器語言。因此,對于任何一個要解
51、決的問題來說,不管使用哪一種計算機語言(匯編語言或高級語言)描述,都必須通過翻譯程序轉換成相應的機器語言才能執(zhí)行。 機器語言存在可讀性差、不容易編程和不容易維護等許多缺陷,這就給編寫程序造成了許多困難。我們可以用預先規(guī)定的符號來分別替代二進制碼表示的操作碼、操作數或地址,用便于記憶的符號而不是二進制碼來編寫程序要方便得多。,5.7 機器語言、匯編語言和高級語言,例:設有兩個8字節(jié)數已分別放在雙字變量FIRST和SECONT中。存放時,最低字節(jié)在地址最低處(例如,數據123456789ABCDEF0H在內存中存放的順序為0F0H、0DEH、0BCH、9AH、78H、56H、34H、12H),可用
52、下列80386匯編程序實現相加。,5.7 機器語言、匯編語言和高級語言,MOV EAX,FIRST ;取第一個數的低32位到EAX ADD EAX,SECOND;與第二個數的低32位內容相加 MOV THIRD,EAX;結果的低32位內容存放到THIRD的低32位中 MOV EXA,FIRST+4;取第一個數的高32位內容到EAX ADC EAX,SECOND+4;與第二個數高32位相加,再加上一步產生的進位 MOV THIRD+4,EAX;結果送變量THIRD的高32位中,5.7 機器語言、匯編語言和高級語言,這種用助記符來表示二進制碼指令序列的語言,稱為匯編語言(Assembly Lang
53、uage),它基本上是與機器語言一一對應的。顯然,用匯編語言編寫的程序,計算機不能直接識別,必須將它翻譯成機器語言后才能執(zhí)行。翻譯過程是把用助記符表示的操作碼、操作數或地址用相應的二進制碼來替代,這個工作通常是由計算機執(zhí)行匯編程序(Assembler)來完成的。 用匯編語言編寫程序,對程序員來說雖然比用機器語言方便得多,編寫的程序可讀性較好,出錯也便于檢查和修改,但它同計算機的硬件結構、指令系統的設置關系非常密切。,5.7 機器語言、匯編語言和高級語言,因此,匯編語言仍然是一種面向計算機硬件本身的語言,程序員用它編寫程序必須十分熟悉計算機硬件結構的配置、指令系統和尋址方式,這對程序員來說要求是
54、很高的。同時,匯編指令的基本操作簡單(主要是簡單的算術/邏輯運算和數據傳送),描述問題的能力差,用它編寫程序工作量大,源程序較長,可讀性仍然不好。匯編語言依賴于計算機的硬件結構和指令系統,而不同的機器有不同的結構和指令,因而用它編寫的程序不能在其他類型的機器上運行。 高級語言(High Level Language)FORTRAN、C、PASCAL、COBOL等就是為了克服匯編語言的這些缺點而發(fā)展起來的。高級語言與計算機的硬件結構,5.7 機器語言、匯編語言和高級語言,及指令系統無關,因此用高級語言編寫程序,無須考慮機器字長、寄存器、狀態(tài)、尋址方式和內存單元地址等,因而比使用匯編語言容易得多。
55、高級語言的表達方式比較接近于自然語言,描述問題的能力強,通用性、可讀性和可維護性都很好。 顯然,就編寫程序來說,高級語言比匯編語言優(yōu)越得多,但它并非完美無缺,它存在的顯著缺點是:用高級語言編寫的程序,必須翻譯成機器語言才能執(zhí)行,這一工作通常是由計算機執(zhí)行編譯程序來完成的。由于編譯過程既復雜又死板,翻譯出來的機器語言程序非常冗長,如果讓有經驗的程序員用匯編語言來編寫同樣功能的程序,至少可以節(jié)省2/3的內存空間,速度則要快一倍以上。由于高級語言,5.7 機器語言、匯編語言和高級語言,程序看不見機器的硬件結構,因而不能用它來編寫需要訪問機器硬件資源的系統軟件或設備控制軟件。 為了克服高級語言不能直接
56、訪問機器硬件資源(如某個寄存器或存儲單元)的缺陷,一些高級語言(如C、PASCAL、FORTRAN等)提供了與匯編語言之間的調用接口。用匯編語言編寫的程序,可作為高級語言的一個外部過程或函數,利用堆棧來傳遞參數或參數的地址(如何傳遞參數與高級語言的版本有關)。兩者的源程序通過編譯或匯編生成目標(OBJ)文件后,再利用連接程序(LINKER)把它們連接成可執(zhí)行文件,便可在機器上運行。采用這種方法,用高級語言編寫程序時,若要使用機器的硬件資源,則可調用匯編程序來實現。,5.7 機器語言、匯編語言和高級語言,匯編語言和高級語言各有其特點和優(yōu)點。匯編語言與機器硬件關系密切,用它編寫的程序緊湊、占內存小、速度快,特別適合于編寫經常與硬件打交道的系統軟件;而高級語言不涉及機器的硬件結構,通用性強,編寫程序容易,特別適合于編寫與硬件沒有直接關系的應用軟件。,,
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
5. 裝配圖網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。