日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 工業(yè)控制 > 電子設(shè)計自動化

  1引言

  本文給出了一種可用于32位以上CPU執(zhí)行單元的移位寄存器電路,并針對CISC指令集INTELX86進(jìn)行了優(yōu)化(由于RISC指令集中移位類指令實現(xiàn)比較簡單,故沒有在文中討論);采用指令預(yù)處理的技術(shù)和通過冗余位,能很方便的實現(xiàn)帶進(jìn)位標(biāo)志CF移位和設(shè)置CF位,并使得每條移位指令的平均執(zhí)行速度為兩個指令周期。它有效地提高了CPU對移位類指令的執(zhí)行性能,并且作為一個基本的內(nèi)核單元能很方便地移植到不同指令集(RISC或CISC)的CPU設(shè)計之中。

  232位CPU中執(zhí)行單元總體結(jié)構(gòu)

  我們所設(shè)計的32位CPU的執(zhí)行部分采用雙總線結(jié)構(gòu),數(shù)據(jù)總線(Abus,Bbus)的寬度是32位。由于移位類指令如果用ALU進(jìn)行實現(xiàn)的話,必然會耗費太多的CPU周期,為實現(xiàn)在一個指令周期內(nèi)對32位數(shù)據(jù)進(jìn)行任意位的移位操作,因此有必要在執(zhí)行單元中設(shè)計專用硬件移位寄存器,在執(zhí)行移位類指令時由它進(jìn)行32位數(shù)據(jù)的移位。

  圖1給出了32位CPU執(zhí)行單元總體結(jié)構(gòu)數(shù)據(jù)流結(jié)構(gòu)簡圖,并省略了所有控制信號。圖中Abus為雙向32數(shù)據(jù)總線,Bbus為單向32位數(shù)據(jù)總線。由于考慮到要實現(xiàn)INTELX86系列所有的移位類指令(RCR,RCL,ROR,ROL等),所以移位寄存器在設(shè)計時采用雙輸入端,即實際該移位寄存器最大能實現(xiàn)64位移位。通過特殊的指令預(yù)設(shè)置方法,并通過增加冗余位實現(xiàn)標(biāo)志位的設(shè)置。

  3移位寄存器單元的設(shè)計

  3.1矩陣移位器和樹狀移位器

  在CPU中移位寄存器單元的設(shè)計一般采用的是矩陣結(jié)構(gòu)和樹狀結(jié)構(gòu)的移位器。

  3.1.1矩陣結(jié)構(gòu)(MatrixStyle)移位器

  它的結(jié)構(gòu)為一傳輸門組成的陣列。行數(shù)等于操作數(shù)據(jù)寬度,列數(shù)等于最多能移位數(shù)如圖2所示(以4位舉例)。

  其中A3~A0是4位數(shù)據(jù)輸入線,sh3~sh0是4根控制信號線。每次進(jìn)行N位移位操作,對應(yīng)的shN為高,其它控制信號為低。

  這種結(jié)構(gòu)的優(yōu)點是:(1)數(shù)據(jù)傳輸?shù)乃俣瓤?,每個信號到達(dá)輸出端只經(jīng)過了一級傳輸,不受移位器位數(shù)限制;(2)版圖很規(guī)整。缺點是:(1)每根控制信號的負(fù)載太大,如32位移位器,每根信號線(sh0,sh1,……sh31)都要驅(qū)動32個開關(guān)管;(2)所需晶體管數(shù)目太多,如n位移位器所需晶體管數(shù)為2×n×n=2n2(傳輸門部分采用CMOS實現(xiàn)),所帶來的功耗和芯片面積也會增加;(3)每一移位操作只需一根控制線為1,所以需輔以額外的譯碼單元。

  3.1.2樹狀結(jié)構(gòu)(TreeStyle)移位器

  這種結(jié)構(gòu)M位移位器所需的級數(shù)是log2M每一級都由兩根信號線(shn和shn#)控制數(shù)據(jù)的傳輸,數(shù)據(jù)在第i級要么移動2i位或者不移動。樹狀移位器如圖3所示。

  這種結(jié)構(gòu)的優(yōu)點是:(1)晶體管數(shù)目少,n位移器所需晶體管數(shù)目為2×n×logn(傳輸門部分采用CMOS實現(xiàn)),版圖面積小于矩陣移位器;(2)控制信號shN~sh0本身就是二進(jìn)制表示,不需要額外的譯碼單元。缺點是:數(shù)據(jù)通路所需經(jīng)過的開關(guān)管數(shù)目太多,M位移位器所需的級數(shù)是log2M,因此導(dǎo)致延時太大。

  3.2矩陣-樹狀結(jié)構(gòu)移位器

  由上面的分析我們可以看出,如果所設(shè)計的處理器為16位以下CPU,那其移位器不管采用上述哪種方案都能達(dá)到要求,但當(dāng)數(shù)據(jù)寬度到32位以上,從功耗,速度及版圖面積考慮以上方案的固有缺點就會顯得非常突出。在本設(shè)計中,移位寄存器的實際輸入為64位,為結(jié)合矩陣結(jié)構(gòu)的優(yōu)點(速度快、版圖規(guī)整)和樹狀結(jié)構(gòu)的優(yōu)點(晶體管數(shù)目少、譯碼簡單),我們在設(shè)計中采用矩陣-樹狀結(jié)構(gòu)整個移位寄存器的是由雙總線輸入,即輸入64位,表1中列舉了不同級別比例的矩陣-樹狀結(jié)構(gòu)所需晶體管數(shù)目(n1為tree的級數(shù),n2為matrix的控制線,n3為matrix中用的晶體管數(shù)目)。經(jīng)過綜合考慮,我們采用第2行的矩陣-樹狀級別比例,即矩陣部分最大能實現(xiàn)8位移位,樹狀部分最大能實現(xiàn)4位移位。

  經(jīng)過各方面綜合考慮,我們所設(shè)計的移位寄存器的前級為矩陣結(jié)構(gòu)部分(輸入數(shù)據(jù)為64位,控制信號8位),由這一部分形成一36位的數(shù)據(jù)送入下一級樹狀結(jié)構(gòu)(輸入數(shù)據(jù)為36位,控制信號2位)部分再完成剩余的4位移位,形成32位輸出數(shù)據(jù)。結(jié)構(gòu)簡圖如圖4所示。

  在這個結(jié)構(gòu)中,后級的樹狀移位器最高實現(xiàn)3位移位。輸入的2bit信號為2進(jìn)制碼,這兩位由移位計數(shù)器sh4~sh0直接將最低兩位送入(在后一節(jié)將介紹)。前級的矩陣結(jié)構(gòu)完成64位輸入36位輸出,我們設(shè)64位數(shù)據(jù)輸入由Abus,Bbus提供,如圖5所示。每一小格代表4位數(shù)據(jù)。這64位數(shù)據(jù)送入矩陣移位器后,根據(jù)計數(shù)器的高三位sh4~sh2進(jìn)行譯碼對其進(jìn)行4,8,12,16,20,24,28,32中的一種移位(對應(yīng)8bits中的一位為高)。形成36位的數(shù)據(jù)輸出送入下級樹狀移位器以完成剩余位數(shù)的移位。36位數(shù)據(jù)輸出格式如圖6所示。其中COUNT表示總共移位數(shù)。

  4指令的預(yù)處理及移位類指令的實現(xiàn)

  在我們設(shè)計的這片CPU中,需要對INTEL的X86系列移位類指令進(jìn)行兼容。因此移位寄存器單元需要在周圍譯碼和鎖存單元的配合下,要能在一個指令節(jié)拍內(nèi)實現(xiàn)ROL,ROR,RCL,RCR,SHL,SHR,SAR,其中RCL,RCR實現(xiàn)了帶標(biāo)志位C的移位(指令說明見文獻(xiàn)[4])。因此需由處理器的控制單元在每類移位指令移位之前進(jìn)行指令的預(yù)處理。

  4.1移位寄存器單元總體結(jié)構(gòu)

  最終設(shè)計出的移位寄存器單元總體結(jié)構(gòu)如圖7所示,其中其核心部分的矩陣-樹狀結(jié)構(gòu)的移位寄存器就是使用上一節(jié)所描述的結(jié)構(gòu)。記數(shù)器中的數(shù)據(jù)(sh4~sh0)在移位上一拍由Bbus寫入,并進(jìn)行譯碼,其中低兩位(sh1,sh0)直接送樹狀結(jié)構(gòu)移位部分,高三位(sh4,sh3,sh2)經(jīng)過譯碼產(chǎn)生8位控制信號送入矩陣移位部分。Abus和Bbus輸入鎖存器能鎖存32位數(shù)據(jù)輸入,并根據(jù)不同指令的要求進(jìn)行操作,對指令進(jìn)行預(yù)處理。移位結(jié)果送ALU輸出鎖存器,并對CF寄存器進(jìn)行設(shè)置。

  4.2指令的預(yù)處理

  由于要對實現(xiàn)帶進(jìn)位CF的移位并在移位操作后對CF進(jìn)行設(shè)置,在一般情況下這需要CPU的控制單元提供多周期指令節(jié)拍來實現(xiàn)。在本設(shè)計中,將Abus和Bbus輸入鎖存器設(shè)計為能根據(jù)不同的指令實現(xiàn)清0和帶CF左移一位或右移一位的操作,以便為移位做好數(shù)據(jù)上的準(zhǔn)備,使輸入數(shù)據(jù)的0~32位移位能在一個指令周期內(nèi)完成。對不同的指令具體設(shè)置情況如圖8所示。圖中CF表示為進(jìn)位標(biāo)志位;len為操作數(shù)長度(如32位數(shù)據(jù));n為移位數(shù);DATA表示輸入鎖存輸出的數(shù)據(jù)為操作數(shù)據(jù)本身;0表示輸入鎖存輸出的數(shù)據(jù)為0;CF:DATA(-1)表示輸入鎖存輸出的數(shù)據(jù)為操作數(shù)帶CF右移一位;DATA(-1):CF表示輸入鎖存輸出的數(shù)據(jù)為操作數(shù)帶CF左移一位;SIGN_EXT表示輸入鎖存輸出的數(shù)據(jù)為操作數(shù)帶符號擴展。橫線下為移位前Abus和Bbus鎖存器中數(shù)據(jù)預(yù)處理完后的格式,橫線上方位移位完成后數(shù)據(jù)輸出及進(jìn)位CF所處位置。

  例:RCLAX,CL指令

  設(shè)AX=0001H,CL="3",CF=1

  Abus鎖存器輸出數(shù)據(jù)為操作數(shù)本0001H;

  Bbus鎖存器輸出的數(shù)據(jù)為操作數(shù)帶CF右移一位為1000H;

  在輸出中,CF在輸出結(jié)果的最左端為0。

  5驗證及結(jié)論

  通過Verilog的行為仿真及starsim的時序仿真顯示,性能完全符合要求。對比INTELX86指令集中移位類指令標(biāo)準(zhǔn)執(zhí)行周期為4~7個機器周期,本設(shè)計移位類指令平均執(zhí)行時間為2個指令周期,因此大大提高了移位類指令執(zhí)行效率。移位寄存器作為CPU中執(zhí)行單元的專用硬件,其性能的好壞直接影響到CPU處理移位類指令的速度和效率。本文采用的矩陣-樹狀結(jié)構(gòu)移位寄存器,配合指令預(yù)處理技術(shù),能有效實現(xiàn)32位數(shù)據(jù)的移位操作,并兼容INTELX86系列的所有移位類指令還可作為通用硬件方便地移植到其他指令級別的CPU設(shè)計之中。



本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

在本土存儲行業(yè),得瑞領(lǐng)新是當(dāng)中一個不得不提的重要玩家。得益于過去多年在企業(yè)級市場的堅持和持之以恒的投入,得瑞領(lǐng)新成功打造覆蓋高性能NVMe SSD的全產(chǎn)品線,為數(shù)據(jù)中心、云計算、人工智能等領(lǐng)域等客戶提供高可靠性的存儲方案...

關(guān)鍵字: PCIe 5 SSD D8000系列 云計算 人工智能 高性能

在快速發(fā)展的中國市場中,寬帶服務(wù)的需求日益增長,對高性能、高可靠性的CATV(有線電視)功率放大器提出了更高要求。作為全球領(lǐng)先的移動應(yīng)用、基礎(chǔ)設(shè)施與航空航天、國防應(yīng)用RF解決方案供應(yīng)商,Qorvo, Inc.(納斯達(dá)克代...

關(guān)鍵字: 寬帶服務(wù) 高性能 功率放大器

隨著現(xiàn)代電子技術(shù)的飛速發(fā)展,高性能信號鏈在通信、雷達(dá)、醫(yī)療等領(lǐng)域的應(yīng)用越來越廣泛。電源紋波作為影響信號鏈性能的重要因素之一,其分析和控制對于提升信號鏈的整體性能具有重要意義。本文將從電源紋波的產(chǎn)生機理、分析方法以及優(yōu)化措...

關(guān)鍵字: 電源紋波 信號鏈 高性能

今天,小編將在這篇文章中為大家?guī)砘谝莆患拇嫫鱐DM的實現(xiàn)方式的有關(guān)報道。

關(guān)鍵字: 寄存器 移位寄存器

移位寄存器,作為數(shù)字電路中的基本元件,是一種存儲數(shù)據(jù)并按特定方式改變數(shù)據(jù)順序的裝置。它在計算機硬件設(shè)計、通信協(xié)議處理、數(shù)據(jù)編碼解碼以及其他眾多數(shù)字信號處理場景中扮演著至關(guān)重要的角色。本文將深入探討移位寄存器的作用,其工作...

關(guān)鍵字: 移位寄存器 數(shù)字電路

在下述的內(nèi)容中,小編將會對移位寄存器的相關(guān)消息予以報道,如果移位寄存器是您想要了解的焦點之一,不妨和小編共同閱讀這篇文章哦。

關(guān)鍵字: 74ls194 移位寄存器

移位寄存器是一種特殊的數(shù)字邏輯電路,它可以在其內(nèi)部存儲數(shù)據(jù),并且能夠按照特定的方向逐位移動這些數(shù)據(jù)。8位移位寄存器,顧名思義,是一種能夠存儲8位二進(jìn)制數(shù)據(jù)的移位寄存器。這種寄存器在數(shù)字電路設(shè)計中有著廣泛的應(yīng)用,如數(shù)據(jù)串行...

關(guān)鍵字: 移位寄存器 數(shù)字邏輯電路 存儲數(shù)據(jù)

移位寄存器有不同的版本,可用于各種各樣的應(yīng)用程序。本文將向您介紹移位寄存器并說明它們的工作原理。此外,它還將解釋如何將它們用于將多條并行數(shù)據(jù)線轉(zhuǎn)換為單個串行連接。

關(guān)鍵字: 移位寄存器 串行 應(yīng)用程序

移位寄存器是計算機中一種重要的數(shù)字電路,它具有廣泛的應(yīng)用。下面我將為您詳細(xì)介紹移位寄存器的定義、功能和應(yīng)用。

關(guān)鍵字: 移位寄存器 計算機 數(shù)字電路

移位寄存器是一種常用的數(shù)字電路元件,廣泛應(yīng)用于計算機、通信、數(shù)據(jù)處理等領(lǐng)域。它可以實現(xiàn)數(shù)據(jù)的移位操作,具有較高的靈活性和可擴展性。本文將對移位寄存器的產(chǎn)品性能以及引腳圖進(jìn)行詳細(xì)分析。

關(guān)鍵字: 移位寄存器 計算機 數(shù)字電路
關(guān)閉