當(dāng)前位置:首頁 > 嵌入式 > 嵌入式硬件

  1 引 言

  隨著數(shù)字通信和工業(yè)控制領(lǐng)域的高速發(fā)展,要求專用集成電路(ASIC)的功能越來越強,功耗越來越低,生產(chǎn)周期越來越短,這些都對芯片設(shè)計提出了巨大的挑戰(zhàn),傳統(tǒng)的芯片設(shè)計方法已經(jīng)不能適應(yīng)復(fù)雜的應(yīng)用需求了。SoC(System on a Chip)以其高集成度,低功耗等優(yōu)點越來越受歡迎。開發(fā)人員不必從單個邏輯門開始去設(shè)計ASIC,而是應(yīng)用己有IC芯片的功能模塊,稱為核(core),或知識產(chǎn)權(quán)(IP)宏單元進行快速設(shè)計,效率大為提高。CPU 的IP核是SoC技術(shù)的核心,開發(fā)出具有自主知識產(chǎn)權(quán)的CPU IP核對我國在電子技術(shù)方面跟上世界先進的步伐,提高信息產(chǎn)業(yè)在世界上的核心竟?fàn)幜τ兄卮笠饬x。

  精簡指令集計算機RISC(Reduced Instruction Set Computer)是針對復(fù)雜指令集計算機CISC(Complex Instruction Set Computer)提出的,具備如下特征1)一個有限的簡單的指令集; 2)強調(diào)寄存器的使用或CPU配備大量的能用的寄存器;3)強調(diào)對指令流水線的使用。

  2 CPU IP核的組成

  盡管各種CPU的性能指標(biāo)和結(jié)構(gòu)細(xì)節(jié)不同,但所要完成的基本功能相同,從整體上可分為八個基本的部件:時鐘發(fā)生器、指令寄存器、累加器、RISC CPU算術(shù)邏輯運算單元、數(shù)據(jù)控制器、狀態(tài)控制器、程序控制器、程序計數(shù)器、地址多路器。狀態(tài)控制器負(fù)責(zé)控制每一個部件之間的相互操作關(guān)系,具體的結(jié)構(gòu)和邏輯關(guān)系如圖1所示。

  時鐘發(fā)生器利用外部時鐘信號,經(jīng)過分頻生成一系列時鐘信號給CPU中的各個部件使用。為了保證分頻后信號的跳變性能,在設(shè)計中采用了同步狀態(tài)機的方法。

  指令寄存器在觸發(fā)時鐘clk1的正跳變觸發(fā)下,將數(shù)據(jù)總線送來的指令存入寄存器中。數(shù)據(jù)總線分時復(fù)用傳遞數(shù)據(jù)和指令,由狀態(tài)控制器的load_ir信號負(fù)責(zé)判別。load_ir信號通過使能信號ena口線輸入到指令寄存器。復(fù)位后,指令寄存器被清為零。每條指令為兩個字節(jié)16位,高3位是操作碼,低13位是地址線。CPU的地址總線為是13位,位尋址空間為8K 字節(jié)。本設(shè)計的數(shù)據(jù)總線是8位,每條指令取兩次,每次由變量state控制。

  累加器用于存放當(dāng)前的運算結(jié)果,是雙目運算中的一個數(shù)據(jù)來源。復(fù)位后,累加器的值為零。當(dāng)累加器通過使能信號ena 口線收到來自CPU狀態(tài)控制器load_acc 信號后,在clk1時鐘正跳沿時就接收來自數(shù)據(jù)總線的數(shù)據(jù)。

  圖1 CPU結(jié)構(gòu)圖

  算術(shù)邏輯運算單元根據(jù)輸入的不同的操作碼分別實現(xiàn)相應(yīng)的加、與、異或、跳轉(zhuǎn)等基本運算。

  數(shù)據(jù)控制器其作用是控制累加器的數(shù)據(jù)輸出,由于數(shù)據(jù)總線是各種操作傳送數(shù)據(jù)的公共通道,分時復(fù)用,有時傳輸指令,有時要傳送數(shù)據(jù)。其余時候,數(shù)據(jù)總線應(yīng)呈高阻態(tài),以允許其他部件使用。所以,任何部件向總線上輸出數(shù)據(jù)時,都需要一個控制信號的,而此控制信號的啟、停則由CPU狀態(tài)控制器輸出的各信號控制決定。控制信號datactl_ena決定何時輸出累加器中的數(shù)據(jù)。

  地址多路器用于輸出的地址是PC(程序計數(shù)器)地址還是數(shù)據(jù)/端口地址。每個指令周期的前4個時鐘周期用于從ROM中讀取指令,輸出的應(yīng)是PC地址,后4個時鐘周期用于對RAM或端口的讀寫,該地址由指令給出,地址的選擇輸出信號由時鐘信號的8分頻信號fecth提供。

  程序計數(shù)器用于提供指令地址,以便讀取指令,指令按地址順序存放在存儲器中,有兩種途徑可形成指令地址,一是順序執(zhí)行程序的情況,二是執(zhí)行JMP指令后,獲得新的指令地址。

  狀態(tài)機控制器接受復(fù)位信號RST,當(dāng)RST有效時,能通過信號ena使其為0 ,輸入到狀態(tài)機中以停止?fàn)顟B(tài)機的工作。狀態(tài)機是CPU 的控制核心,用于產(chǎn)生一系列的控制信號,啟動或停止某些部件,CPU何時進行讀指令來讀寫I/O端口及RAM區(qū)等操作,都是由狀態(tài)機來控制的。狀態(tài)機的當(dāng)前狀態(tài),由變量state記錄,state的值就是當(dāng)前這個指令周期中已經(jīng)過的時鐘數(shù)。指令周期是由8 個時鐘組成,每個時鐘都要完成固定的操作。

  3 系統(tǒng)時序

  RISC CPU的復(fù)位和啟動操作是通過rst引腳的信號觸發(fā)執(zhí)行的,當(dāng)rst信號一進入高電平,RISC CPU就會結(jié)束現(xiàn)行操作,并且只要rst停留在高電平狀態(tài),CPU就維持在復(fù)位狀態(tài),CPU各狀態(tài)寄存器都設(shè)為無效狀態(tài)。當(dāng)信號rst回到低電平,接著到來的第一個fetch 上升沿將啟動RISC CPU開始工作,從ROM的000處的開始讀取指令并 執(zhí)行相應(yīng)的操作。

  讀指令時序,每個指令的前3個時鐘周期用于讀指令,4~6周期讀信號rd有效,第7 個周期讀信號無效,第8個周期地址總線輸出PC地址,為下一個指令作準(zhǔn)備。

  寫指令時序,每個指令的第3.5個時鐘周期建立寫地址,第四個周期輸出數(shù)據(jù),第5個時鐘周期輸出寫信號,第6個時鐘結(jié)束,第7.5個時鐘周期輸出為PC地址,為下個指令做準(zhǔn)備。

  如圖2 所示,這是ModelSim SE6.0進行波形仿真的結(jié)果。

  4 微處理器指令

  數(shù)據(jù)處理指令:數(shù)據(jù)處理指令完成寄存器中數(shù)據(jù)的算術(shù)和邏輯操作,其他指令只是傳送數(shù)據(jù)和控制程序執(zhí)行的順序.因此,數(shù)據(jù)處理指令是唯一可以修改數(shù)據(jù)值的指令,數(shù)據(jù)處理指令一般需兩個源操作數(shù),產(chǎn)生單個結(jié)果.所有的操作數(shù)都是8位寬,或者來自寄存器,或者來自指令中定義的立即數(shù).每一個源操作數(shù)寄存器和結(jié)果寄存器都在指令中獨立的指定。

  圖2 讀寫指令時序

  數(shù)據(jù)傳送和控制轉(zhuǎn)移類指令:共有17條,不包括按布爾變量控制程序轉(zhuǎn)移的指令。其中有全存儲空間的長調(diào)用、長轉(zhuǎn)移和按2KB分塊的程序空間內(nèi)的絕對調(diào)用和絕對轉(zhuǎn)移;全空間的長度相對

轉(zhuǎn)移及一頁范圍內(nèi)的短相對轉(zhuǎn)移;還有條件轉(zhuǎn)移指令。這類指令用到的助記符有ACALL, AJMP, LCALL, LJMP, SJMP, M, JZ, JNZ, ONE,DJNZ。控制轉(zhuǎn)移類指令主要用來修改1x指針從而達到對程序流的控制,所用到的寄存器主要有sp, pc, ir等寄存器。

  指令由操作碼和操作數(shù)組成,取指令電路的目的就是把指令碼和操作數(shù)分開。組成電路由如圖3所示。取指令電路由程序指針,程序指針解析模塊、ROM, IR(指令寄存器),控制器狀態(tài)寄存器組成。取指令指令的過程如下:PC指針的值經(jīng)過pc_mux模塊賦值,把ROM中的指令取出來,送到指令寄存器的數(shù)據(jù)輸入口。指令寄存器受狀態(tài)寄存器的控制,當(dāng)取指令信號有效時,ROM中的指令碼被保存在指令寄存器中,然后經(jīng)控制器譯碼,產(chǎn)生控制信號,對PC指針的增量加以控制取出下一條指令。

  圖3 取指令電路

  5 匯編

  匯編程序是為了調(diào)試軟核而開發(fā)的,手工編寫機器碼很容易出錯并且工作量很大。在調(diào)試過程中修改指令集時,匯編程序也要作相應(yīng)的修改。所以要求編譯器的結(jié)構(gòu)簡單性能可靠,在程序中必要的地方可以用堆疊代碼方法實現(xiàn),不必考慮編程技巧和匯編器效率問題。匯編程序用于測試RISC CPU的基本指令集,如果CPU的各條指令執(zhí)行正確,停止在HLT指令處。如果程序在其它地址暫停運行,則有一個指令出錯。程序中,@符號后的十六進制表示存儲器的地址,每行的//后表示注釋。下面是一小段程序代碼,編譯好的匯編機器代碼裝入虛擬ROM,要參加運算的數(shù)據(jù)裝入虛擬RAM就可以開始進行仿真。

  機器碼 地址 匯編助記符 注釋

  @00 //地址聲明

  101_11000 //00 BEGIN: LDA DATA_2

  0000_0001

  011_11000 //02 AND DATA_3

  0000_0010

  100_11000 //04 XOR DATA_2

  0000_0001  001_00000 //06 SKZ

  0000_0000

  000_00000 //08 HLT //AND does't work

  6 調(diào)試

  最基本的調(diào)試手段

是基于FPGA 廠商提供的開發(fā)和仿真環(huán)境,用硬件描述語言編寫TESTBENCH,構(gòu)成一個最小運行環(huán)境。TESTBENCH產(chǎn)生對目標(biāo)軟核的激勵,同時記錄軟核的輸出,和預(yù)期值進行比對,可以確定核的設(shè)計錯誤。這種方法的好處是實現(xiàn)容易,結(jié)果準(zhǔn)確,但硬件描述語言編碼量較大。為了仿真結(jié)果的準(zhǔn)確性,無論功能仿真還是時序仿真,仿真的步長都不能太小,結(jié)果導(dǎo)致整個系統(tǒng)仿真時間太長。本設(shè)計中先對RISC CPU的各個子模塊進行了分別綜合,檢查正確性,如果發(fā)現(xiàn)錯誤可以在較小的范圍內(nèi)來檢查并驗證。子模塊綜合完畢后,把要綜合的RISC CPU的模塊與外圍器件以及測試模塊分離出來組成一個大模塊,綜合后的的RISC CPU模塊如圖4所示,這是Xilinx ISE7.1 所綜合生成的技術(shù)原理圖。

  綜合的結(jié)果只是通用的門級網(wǎng)表,只是一些與、或、非門的邏輯關(guān)系,和芯片實際的配置情況還有差距。此時應(yīng)該使用FPGA/CPLD廠商提供的實現(xiàn)與布局布線工具,根據(jù)所選芯片的型號,進行芯片內(nèi)部功能單元的實際連接與映射。這種實現(xiàn)與布局布線工具一般要選用所選器件的生產(chǎn)商開發(fā)的工具,因為只有生產(chǎn)者最了解器件內(nèi)部的結(jié)構(gòu),如在ISE的集成環(huán)境中完成實現(xiàn)與布局布線的工具是Flow Engine。

  圖4 CPU技術(shù)原理圖

  STA(Static Timing Analysis)靜態(tài)時序分析,完成FPGA設(shè)計時必須的一個步驟。在FPGA加約束、綜合、布局布線后,在ISE中可以運行Timing Analyzer生成詳細(xì)的時序報告,本設(shè)計中Minimum period: 12.032ns (Maximum Frequency: 83.112MHz),Minimum input arrival time before clock: 6.479ns,Maximum output required time after clock: 9.767ns。然后,設(shè)計人員檢查時序報告,根據(jù)工具的提示找出不滿足Setup/Hold time的路徑,以及不符合約束的路徑,進行修改保證數(shù)據(jù)能被正確的采樣。在后仿真中將布局布線的時延反標(biāo)到設(shè)計中去,使仿真既包含門延時,又包含線延時信息。這種后仿真是最準(zhǔn)確的仿真,能真實地反映芯片的實際工作情況。

  7 結(jié) 論

  復(fù)雜的RISC CPU設(shè)計是一個從抽象到具體的過程,本文根據(jù)FPGA的結(jié)構(gòu)特點,圍繞在FPGA上設(shè)計實現(xiàn)八位微處理器軟核設(shè)計方法進行探討,研究了片上系統(tǒng)的設(shè)計方法和設(shè)計復(fù)用技術(shù),并給出了指令集和其調(diào)試方法,提出了一種基于FPGA的微處理器的IP的設(shè)計方法。本文作者創(chuàng)新點是:根據(jù)Spartan II 的內(nèi)部結(jié)構(gòu),在編碼階段實現(xiàn)了地址和數(shù)據(jù)的優(yōu)化,實現(xiàn)階段對內(nèi)部布局布線進行重新配置,設(shè)計實現(xiàn)的微處理器僅占用78個slices,1個Block RAM,在10萬門的芯片實現(xiàn),占用6%的資源。

  參考文獻:

  [1] 夏宇聞.Verilog數(shù)字系統(tǒng)設(shè)計教程[M].北京: 北京航空航天大學(xué)出版社,2003. [2] 袁俊泉 孫敏琪 曹瑞 Verilog數(shù)字系統(tǒng)設(shè)計教程[M].西安: 西安電子科技大學(xué)出版社,2002.

  [3] J.Bhasjer 著 孫海平 等譯 Verilog HDL綜合實用教程[M].北京: 清華大學(xué)出版社,2004.

  [4] 楊厚俊 張公敬 張昆藏 編著 計算機系統(tǒng)結(jié)構(gòu)---奔騰PC[M].北京: 科學(xué)出版社,2004.

  [5] 馮海濤 王永綱 石江濤 顏天信 王硯方. 基于FPGA的32位整數(shù)微處理器的設(shè)計與實現(xiàn)[J]. 小型微型計算機系統(tǒng), 2005, 26(6): 1113-1117.

  [6] 王喆.八位CPU IP核的研究與設(shè)計[D].大連:大連理工大學(xué),2005

  [7] http:///

  [8] 袁本榮 劉萬春 賈云得 朱玉文 用Verilog HDL進行FPGA設(shè)計的一些基本方法[J].微計算機信息,2004,20(6):93-95

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉