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

  1引言

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

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

  我們所設(shè)計(jì)的32位CPU的執(zhí)行部分采用雙總線結(jié)構(gòu),數(shù)據(jù)總線(Abus,Bbus)的寬度是32位。由于移位類(lèi)指令如果用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ì)專(zhuān)用硬件移位寄存器,在執(zhí)行移位類(lèi)指令時(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)INTELX86系列所有的移位類(lèi)指令(RCR,RCL,ROR,ROL等),所以移位寄存器在設(shè)計(jì)時(shí)采用雙輸入端,即實(shí)際該移位寄存器最大能實(shí)現(xiàn)64位移位。通過(guò)特殊的指令預(yù)設(shè)置方法,并通過(guò)增加冗余位實(shí)現(xiàn)標(biāo)志位的設(shè)置。

32位CPU執(zhí)行單元總體結(jié)構(gòu)數(shù)據(jù)流結(jié)構(gòu)簡(jiǎn)圖

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

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

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

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

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

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

  其中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(傳輸門(mén)部分采用CMOS實(shí)現(xiàn)),所帶來(lái)的功耗和芯片面積也會(huì)增加;(3)每一移位操作只需一根控制線為1,所以需輔以額外的譯碼單元。

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

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

樹(shù)狀移位器

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

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

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

不同級(jí)別比例的矩陣-樹(shù)狀結(jié)構(gòu)所需晶體管數(shù)目

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

結(jié)構(gòu)簡(jiǎn)圖

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

64位數(shù)據(jù)輸入格式

36位數(shù)據(jù)輸出格式

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

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

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

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

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

  4.2指令的預(yù)處理

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

對(duì)不同的指令具體設(shè)置情況

  例:RCLAX,CL指令

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

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

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

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

  5驗(yàn)證及結(jié)論

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



 

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲一区二区av电影| 久久www免费人成看片高清 | 亚洲国产综合视频在线观看 | 好看的日韩av电影| 国产精品私房写真福利视频 | 午夜精品久久久久久久久久久久久| 亚洲精品在线观看免费| 亚洲国产欧美国产综合一区| 在线观看的日韩av| 在线观看成人一级片| 影音先锋亚洲精品| 影音先锋国产精品| 亚洲国产精品久久久久婷婷老年| 亚洲成人在线网站| 亚洲激情在线| 亚洲美女黄网| 一本到高清视频免费精品| 日韩小视频在线观看专区| 99精品热视频| 亚洲深爱激情| 亚洲自拍偷拍麻豆| 先锋影音久久久| 久久精品国产精品 | 欧美裸体一区二区三区| 欧美人成网站| 欧美日韩直播| 国产精品色午夜在线观看| 国产欧美视频在线观看| 国内免费精品永久在线视频| 激情综合自拍| 亚洲精选大片| 亚洲午夜在线观看视频在线| 午夜精品一区二区三区在线播放| 午夜精品国产更新| 亚洲国产精品福利| 99国产麻豆精品| 亚洲一级黄色片| 欧美在线二区| 免费亚洲视频| 欧美日韩一卡| 国产一区二区三区黄| 亚洲国产清纯| 一区二区三区成人| 欧美一激情一区二区三区| 亚洲国产91| 一个色综合导航| 欧美一级网站| 欧美成人午夜影院| 欧美午夜精品一区| 国产一区二区主播在线| 亚洲国产成人久久综合一区| 一级成人国产| 久久精品国产一区二区三| 亚洲美女网站| 欧美一区亚洲一区| 欧美高清一区| 国产精品美女久久久久aⅴ国产馆| 国产一区自拍视频| 亚洲卡通欧美制服中文| 亚洲欧美日韩国产综合精品二区| 91久久精品一区二区别| 亚洲综合色激情五月| 老司机午夜免费精品视频| 欧美美女喷水视频| 国产日韩一区二区| 亚洲精品在线观看免费| 久久电影一区| 亚洲在线视频网站| 欧美插天视频在线播放| 国产精品影视天天线| 亚洲激情小视频| 欧美伊人久久大香线蕉综合69| 99国内精品| 久久久久久久久久久一区| 欧美日韩国产精品成人| 激情国产一区二区| 宅男在线国产精品| 亚洲欧洲精品一区二区精品久久久| 亚洲欧美国产高清| 欧美黄色精品| 含羞草久久爱69一区| 亚洲一级在线观看| 亚洲免费久久| 久久天堂国产精品| 国产精品日日做人人爱| 亚洲片在线资源| 亚洲国产电影| 欧美一区二区成人6969| 欧美日韩一区二区三区四区五区 | 欧美一区二区网站| 亚洲在线观看免费| 欧美日韩国产精品一卡| 在线成人免费观看| 欧美在线视频免费| 欧美一区三区三区高中清蜜桃| 欧美日韩亚洲一区二区三区四区| 揄拍成人国产精品视频| 性欧美激情精品| 午夜欧美不卡精品aaaaa| 欧美日韩成人一区| 亚洲国产你懂的| 亚洲国产精品久久精品怡红院| 欧美一区二区高清| 国产精品av免费在线观看| 亚洲国产精品999| 亚洲福利视频网站| 久久亚洲春色中文字幕| 国产一区二区三区视频在线观看| 亚洲伊人伊色伊影伊综合网| 亚洲性线免费观看视频成熟| 欧美伦理91| 日韩五码在线| 制服诱惑一区二区| 欧美另类在线观看| 亚洲国产裸拍裸体视频在线观看乱了中文| 欧美一区二区高清在线观看| 欧美一区二区成人| 国产欧美精品一区二区三区介绍| 亚洲一区观看| 香蕉视频成人在线观看| 国产精品久久福利| 亚洲午夜女主播在线直播| 亚洲女ⅴideoshd黑人| 国产精品99免费看 | 欧美一区二区视频免费观看| 欧美一区二区三区在线免费观看| 国产精品视频九色porn| 亚洲淫性视频| 欧美在线观看天堂一区二区三区 | 国产私拍一区| 欧美一级淫片播放口| 久久久精品性| 在线电影一区| 日韩视频在线你懂得| 欧美日韩日本国产亚洲在线| 99xxxx成人网| 亚洲欧美成人一区二区三区| 国产精品免费小视频| 香蕉av777xxx色综合一区| 久久久久久久尹人综合网亚洲 | 一本色道久久综合狠狠躁篇怎么玩| 欧美激情视频一区二区三区在线播放| 亚洲国产日韩一区| 夜夜夜精品看看| 国产精品福利久久久| 亚洲欧美综合网| 老巨人导航500精品| 亚洲成在人线av| 宅男噜噜噜66一区二区66| 国产精品嫩草影院av蜜臀| 欧美在线视频二区| 欧美成人r级一区二区三区| 亚洲美女精品成人在线视频| 亚洲欧美日韩国产| 狠狠88综合久久久久综合网| 91久久国产自产拍夜夜嗨| 欧美日韩91| 亚洲欧美一区二区原创| 噜噜噜91成人网| 亚洲六月丁香色婷婷综合久久| 亚洲一区二区三区精品视频| 国产一区二区高清视频| 亚洲美女av在线播放| 国产精品99一区| 久久精品国产一区二区三区免费看| 欧美成人黑人xx视频免费观看| 一区二区成人精品| 久久久精品久久久久| 亚洲精品欧美日韩专区| 欧美一区二区三区四区高清 | 亚洲国产精品va| 欧美视频免费看| 性欧美1819sex性高清| 欧美成人伊人久久综合网| 这里只有精品视频| 美女在线一区二区| 一区二区三区四区精品| 久久久久综合网| 日韩一区二区久久| 久久九九久久九九| 欧美综合国产| 蜜乳av另类精品一区二区| 国产欧美成人| 亚洲精选成人| 国产精品永久免费视频| 亚洲精品国产精品久久清纯直播| 欧美午夜三级| 亚洲国产天堂久久综合| 亚洲大片一区二区三区| 一区二区精品在线| 国产一区二区剧情av在线| 国产精品你懂的| 亚洲日韩欧美一区二区在线| 国产精品免费观看视频| 亚洲精选久久| 国产一区二区主播在线| 亚洲在线黄色| 亚洲第一黄色| 久久精品夜色噜噜亚洲a∨| 日韩视频免费观看|