一種高性能32位移位寄存器單元的設計
出處:maychang 發(fā)布于:2007-05-26 13:31:35
| 1引言
隨著CPU設計位數與性能的不斷提高,對CPU 執(zhí)行單元中專用硬件移位寄存器的要求也越來越高。CPU移位寄存器的性能直接影響到所設計CPU 對移位類指令的處理能力和執(zhí)行速度。傳統(tǒng)結構的CPU中,移位寄存器的設計一般采用矩陣結構和樹狀結構。當CPU的位數達到32位,速度達到100M以上時,要在一個指令周期內對32位的數據進行32 位內任意移位,以前的設計方法已經很難達到要求。曾經有過對32位桶形移位寄存器的行為級描述 [1],但其只適用于RISC指令集,并且作為CPU中的專用硬件為了達到功耗、速度和面積上的,通常硬件電路采用全定制設計[2]。 本文給出了一種可用于32位以上CPU執(zhí)行單元的移位寄存器電路,并針對CISC指令集INTEL X86進行了優(yōu)化(由于RISC指令集中移位類指令實現比較簡單,故沒有在文中討論);采用指令預處理的技術和通過冗余位,能很方便的實現帶進位標志 CF移位和設置CF位,并使得每條移位指令的平均執(zhí)行速度為兩個指令周期。它有效地提高了CPU對移位類指令的執(zhí)行性能,并且作為一個基本的內核單元能很方便地移植到不同指令集(RISC或 CISC)的CPU設計之中。 2 32位CPU中執(zhí)行單元總體結構 我們所設計的32位CPU的執(zhí)行部分采用雙總線結構,數據總線(Abus,Bbus)的寬度是32位。由于移位類指令如果用ALU進行實現的話,必然會耗費太多的CPU周期,為實現在一個指令周期內對32位數據進行任意位的移位操作,因此有必要在執(zhí)行單元中設計專用硬件移位寄存器,在執(zhí)行移位類指令時由它進行32位數據的移位。 圖1給出了32位CPU執(zhí)行單元總體結構數據流結構簡圖,并省略了所有控制信號。圖中Abus為雙向32數據總線,Bbus為單向32位數據總線。由于考慮到要實現INTEL X86系列所有的移位類指令(RCR,RCL,ROR,ROL等),所以移位寄存器在設計時采用雙輸入端,即實際該移位寄存器能實現64位移位。通過特殊的指令預設置方法,并通過增加冗余位實現標志位的設置。
3 移位寄存器單元的設計 3.1 矩陣移位器和樹狀移位器 3.1.1 矩陣結構(Matrix Style)移位器 它的結構為一傳輸門組成的陣列。行數等于操作數據寬度,列數等于多能移位數如圖2所示(以4位舉例)。
其中A3~A0是4位數據輸入線,sh3~sh0是 4根控制信號線。每次進行N位移位操作,對應的shN為高,其它控制信號為低。 這種結構的優(yōu)點是:(1)數據傳輸的速度快,每個信號到達輸出端只經過了傳輸,不受移位器位數限制;(2)版圖很規(guī)整。缺點是:(1)每根控制信號的負載太大,如32位移位器,每根信號線(sh0,sh1,……sh31)都要驅動32個開關管;(2)所需晶體管數目太多,如n位移位器所需晶體管數為2× n×n=2n2 (傳輸門部分采用CMOS實現),所帶來的功耗和芯片面積也會增加;(3)每一移位操作只需一根控制線為1,所以需輔以額外的譯碼單元。 3.1.2 樹狀結構(Tree Style)移位器 這種結構M位移位器所需的級數是log 2M每都由兩根信號線(shn和sh n#)控制數據的傳輸,數據在第i級要么移動2 i位或者不移動。 樹狀移位器如圖3所示。
這種結構的優(yōu)點是:(1)晶體管數目少, n位移器所需晶體管數目為2×n×log n(傳輸門部分采用CMOS實現),版圖面積小于矩陣移位器;(2)控制信號shN~sh0本身就是二進制表示,不需要額外的譯碼單元。缺點是:數據通路所需經過的開關管數目太多,M位移位器所需的級數是log 2M,因此導致延時太大。 3.2 矩陣-樹狀結構移位器
經過各方面綜合考慮,我們所設計的移位寄存器的前級為矩陣結構部分(輸入數據為64位,控制信號8位),由這一部分形成一36位的數據送入下樹狀結構(輸入數據為36位,控制信號2位)部分再完成剩余的4位移位,形成32位輸出數據。結構簡圖如圖4所示。
在這個結構中,后級的樹狀移位器實現3 位移位。輸入的2bit信號為2進制碼,這兩位由移位計數器sh4~sh0直接將兩位送入(在后一節(jié)將介紹)。前級的矩陣結構完成64位輸入36位輸出,我們設64位數據輸入由Abus,Bbus提供,如圖5所示。每一小格代表4位數據。這64位數據送入矩陣移位器后,根據計數器的高三位sh4~sh2 進行譯碼對其進行4,8,12,16,20,24,28,32中的一種移位(對應8bits中的一位為高)。形成36位的數據輸出送入下級樹狀移位器以完成剩余位數的移位。36位數據輸出格式如圖6所示。其中COUNT表示總共移位數。
4指令的預處理及移位類指令的實現 在我們設計的這片CPU中,需要對INTEL的 X86系列移位類指令進行兼容。因此移位寄存器單元需要在周圍譯碼和鎖存單元的配合下,要能在一個指令節(jié)拍內實現ROL,ROR,RCL,RCR, SHL,SHR,SAR,其中RCL,RCR實現了帶標志位C的移位(指令說明見文獻[4])。因此需由處理器的控制單元在每類移位指令移位之前進行指令的預處理。
4.2 指令的預處理
例:RCL AX , CL 指令 設AX=0001H , CL=3 , CF=1 Abus鎖存器輸出數據為操作數本0001H; Bbus鎖存器輸出的數據為操作數帶CF右移一位為1000H; 在輸出中,CF在輸出結果的左端為0。 5 驗證及結論 通過verilog的行為仿真及starsim的時序仿真顯示,性能完全符合要求。對比INTEL X86指令集中移位類指令標準執(zhí)行周期為4~7個機器周期 [3],本設計移位類指令平均執(zhí)行時間為2個指令周期,因此大大提高了移位類指令執(zhí)行效率。移位寄存器作為CPU中執(zhí)行單元的專用硬件,其性能的好壞直接影響到CPU處理移位類指令的速度和效率。本文采用的矩陣-樹狀結構移位寄存器,配合指令預處理技術,能有效實現32位數據的移位操作,并兼容INTEL X86系列的所有移位類指令還可作為通用硬件方便地移植到其他指令級別的CPU設計之中。 | ||||||||||
版權與免責聲明
凡本網注明“出處:維庫電子市場網”的所有作品,版權均屬于維庫電子市場網,轉載請必須注明維庫電子市場網,http://www.hbjingang.com,違反者本網將追究相關法律責任。
本網轉載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網贊同其觀點或證實其內容的真實性,不承擔此類作品侵權行為的直接責任及連帶責任。其他媒體、網站或個人從本網轉載時,必須保留本網注明的作品出處,并自負版權等法律責任。
如涉及作品內容、版權等問題,請在作品發(fā)表之日起一周內與本網聯系,否則視為放棄相關權利。
- 什么是氫氧燃料電池,氫氧燃料電池的知識介紹2025/8/29 16:58:56
- SQL核心知識點總結2025/8/11 16:51:36
- 等電位端子箱是什么_等電位端子箱的作用2025/8/1 11:36:41
- 基于PID控制和重復控制的復合控制策略2025/7/29 16:58:24
- 什么是樹莓派?一文快速了解樹莓派基礎知識2025/6/18 16:30:52


















