新聞中心

        EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 一種高性能32位移位寄存器單元的設(shè)計(jì)

        一種高性能32位移位寄存器單元的設(shè)計(jì)

        作者: 時(shí)間:2016-12-02 來(lái)源:網(wǎng)絡(luò) 收藏
        1 引言

        隨著CPU設(shè)計(jì)位數(shù)與性能的不斷提高,對(duì)CPU 執(zhí)行單元中專用硬件移位寄存器的要求也越來(lái)越高。CPU移位寄存器的性能直接影響到所設(shè)計(jì)CPU 對(duì)移位類指令的處理能力和執(zhí)行速度。傳統(tǒng)結(jié)構(gòu)的CPU中,移位寄存器的設(shè)計(jì)一般采用矩陣結(jié)構(gòu)和樹(shù)狀結(jié)構(gòu)。當(dāng)CPU的位數(shù)達(dá)到32位,速度達(dá)到100M以上時(shí),要在一個(gè)指令周期內(nèi)對(duì)32位的數(shù)據(jù)進(jìn)行32 位內(nèi)任意移位,以前的設(shè)計(jì)方法已經(jīng)很難達(dá)到要求。曾經(jīng)有過(guò)對(duì)32位桶形移位寄存器的行為級(jí)描述,但其只適用于RISC指令集,并且作為CPU中的專用硬件為了達(dá)到功耗、速度和面積上的最佳,通常硬件電路采用全定制設(shè)計(jì)。

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

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

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

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

        本文引用地址:http://www.104case.com/article/201612/324813.htm

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

        3.1 矩陣移位器和樹(shù)狀移位器

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

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

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


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

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

        上一頁(yè) 1 2 3 下一頁(yè)

        關(guān)鍵詞: 32位高性能移位寄存

        評(píng)論


        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 平阴县| 容城县| 安庆市| 博野县| 双牌县| 原平市| 江津市| 博乐市| 红原县| 湄潭县| 锡林浩特市| 图们市| 洛扎县| 日喀则市| 武功县| 五台县| 任丘市| 巴马| 保定市| 尖扎县| 大理市| 兰溪市| 互助| 清镇市| 平潭县| 临泽县| 长治县| 益阳市| 杭锦旗| 祁东县| 五峰| 旌德县| 驻马店市| 新疆| 西丰县| 江永县| 青川县| 绥阳县| 三台县| 兴义市| 绵阳市|