當前位置:首頁 > EDA > 電子設(shè)計自動化
[導(dǎo)讀]介紹基于RISC技術(shù)的8位微控制器的設(shè)計與實現(xiàn)。

    摘要:介紹基于RISC技術(shù)的8位微控制器的設(shè)計與實現(xiàn)。主要包括RISC指令集的選??;取指單元、譯碼單元、執(zhí)行單元的設(shè)計;取指、譯碼、回寫三級流水線技術(shù)的實現(xiàn)。該微控制器包含8級硬件堆棧、1個8位計數(shù)器、1個計數(shù)器溢出中斷、2個外部中斷源、8位數(shù)據(jù)輸入和輸出端口、16個通用寄存器、2K×16位的程序存儲器、512字節(jié)的數(shù)據(jù)存儲器。設(shè)計使用可綜合的Verilog語言描述, QuartusⅡ軟件仿真,F(xiàn)PGA器件驗證實現(xiàn)。

    關(guān)鍵詞:RISC Verilog 8位微控制器 FPGA

引 言

??隨著微電子技術(shù)的不斷發(fā)展,超大規(guī)模集成電路的集成度和工藝水平不斷提高,將整個應(yīng)用電子系統(tǒng)集成在一個芯片中(SoC),已成為現(xiàn)代電子系統(tǒng)設(shè)計的趨勢;以往高復(fù)雜度、高成本的嵌入式系統(tǒng)結(jié)構(gòu)能夠通過低成本的單片芯片實現(xiàn)。另一方面,復(fù)雜可編程邏輯器件(CPLD)和現(xiàn)場可編程門陣列(FPGA)集成度和速度不斷提高,功能不斷增強,開發(fā)人員可以使用高性能的EDA綜合開發(fā)工具和硬件描述語言(HDL)在短時間內(nèi)設(shè)計出復(fù)雜的電子應(yīng)用系統(tǒng)。目前,嵌入式系統(tǒng)已經(jīng)在各行各業(yè)得到廣泛應(yīng)用。工控、通信、汽車、航空航天以及軍事等各個領(lǐng)域都能看到嵌入式系統(tǒng)的身影,而微控制器(MCU)則是嵌入式系統(tǒng)的核心。

1 精簡指令集計算機(RISC)

    1.1 RISC的結(jié)構(gòu)特征和設(shè)計原則

  精簡指令集計算機具有單周期單指令,存儲器到寄存器的操作,簡單的尋址方式和簡單的指令格式的結(jié)構(gòu)特征,其設(shè)計原則為:

① 選擇使用頻率高的指令,補充少量高效指令;

② 指令的結(jié)構(gòu)簡單,所有指令長度相等;

③ 采用流水線技術(shù),盡量使CPI = 1;

④ 使用Load/Store操作指令訪問存儲器;

⑤ 采用通用寄存器(GPR)結(jié)構(gòu);

⑥ 優(yōu)化編譯,提高執(zhí)行效率。

1.2 性能因子CPI和執(zhí)行時間

  性能因子是指微控制器每條指令的平均時鐘周期數(shù)CPI(Cycles Per Instruction):

  程序總的執(zhí)行時間t為:

  執(zhí)行時間是微控制器性能的主要指標。在影響t的三個因素中,時鐘頻率取決于硬件技術(shù);CPI與指令集和MCU的組成結(jié)構(gòu)有關(guān);而指令數(shù)由指令集和編譯技術(shù)決定。要使微控制器的性能得到提高,優(yōu)化指令集、減少程序的總指令數(shù)和降低CPI值是設(shè)計主要考慮的問題。

2 微控制器的系統(tǒng)結(jié)構(gòu)

  圖1所示的微控制器主要由以下幾個模塊組成:

 ?、?PROM程序存儲器單元(Program ROM)。程序存儲器容量為2K×16位。系統(tǒng)復(fù)位后,程序計數(shù)器PC指向程序存儲器000H單元,程序從000H處開始執(zhí)行。

 ?、?IDEC指令譯碼單元(Instruction Decoder)。指令譯碼器對輸入的16位寬指令進行譯碼,輸出寄存器、數(shù)據(jù)存儲器的地址和讀/寫控制信號。

 ?、?ALU算術(shù)邏輯運算單元(Arithmetic Logic Unit)。ALU單元是MCU數(shù)據(jù)處理的核心部分,數(shù)據(jù)寬度為8位,具有加、減、邏輯運算和移位功能。ALU單元有2個8位的數(shù)據(jù)輸入和1個8位數(shù)據(jù)輸出,1位進位輸入,1位進位標志輸出和零標志輸出。運算操作碼輸入為4位,由譯碼單元提供。

  ④ REGS寄存器單元(Register)。1組16個8位寄存器,用于數(shù)據(jù)的高速存取。寄存器組具有2個數(shù)據(jù)輸出端口和1個數(shù)據(jù)輸入端口,讀和寫地址分開,可同時進行讀/寫操作。

 ?、?DRAM數(shù)據(jù)存儲器單元(Data RAM)。包含4段共512字節(jié)(每段128字節(jié))的數(shù)據(jù)存儲器,直接尋址能力為128字節(jié),間接尋址能力為256字節(jié),由程序狀態(tài)控制寄存器PSW的高2位控制段選地址。

 ?、?CTRL控制單元(Control Unit)。整個MCU的控制中心,主要控制流水線操作、數(shù)據(jù)總線的控制和程序計數(shù)器的轉(zhuǎn)移。另外,還包括中斷、計數(shù)器和堆棧控制。

 ?、?其它。定義了1組數(shù)據(jù)輸入端口、2組數(shù)據(jù)輸出端口,數(shù)據(jù)位寬均為8位;2個外部中斷輸入INT0和INT1;1個8位計數(shù)器TIMER;7級程序堆棧Stack,可實現(xiàn)7級子程序調(diào)用;1個8位的程序狀態(tài)控制寄存器PSW。各位功能如表1。

表1 PSW各位功能

PSW.7 PSW.6 PSW.5 PSW.4 PSW.3 PSW.2 PSW.1 PSW.0
RAM段選 RAM段選 進位CIN 保留 INT1中斷允許 計數(shù)器溢出中斷 INT0中斷允許 啟/停計數(shù)器

3 流水線技術(shù)

    3.1 三級流水線結(jié)構(gòu)

  微控制器采用取指(IF)、執(zhí)行(EX)、回寫(WB)三級流水線結(jié)構(gòu),如圖2。各階段的主要功能為:

取指級——從程序存儲器中取出一條指令,同時進行指令譯碼,準備寄存器、存儲器的讀地址,讀/寫控制信號;

執(zhí)行級——數(shù)據(jù)輸入ALU單元運算,同時準備寄存器或存儲器的寫地址;

回寫級——將ALU輸出的運算結(jié)果寫入寄存器或存儲器中。

3.2 流水線競爭及解決

  控制競爭,由程序PC 指針值的改變引起。當執(zhí)行跳轉(zhuǎn)指令時,PC指針值要到執(zhí)行級才能改變,這將會使下一拍的取指操作出錯。這時必須由硬件插入一條空操作NOP指令,等待PC指針的值改變后再取下一條指令。

  數(shù)據(jù)競爭,由指令間數(shù)據(jù)相關(guān)引起。存儲器訪問存在先寫后讀相關(guān)(read after write),前一條指令的寫操作要到回寫級才能完成。若緊接的下一條指令需要讀取同一地址的內(nèi)容時,必須使用旁路(bypassing)技術(shù),從ALU的輸出結(jié)果直接反饋到ALU的輸入端供下一條指令的執(zhí)行級使用。

4 指令集和指令格式

  微控制器指令長度為16位定長,操作碼采用可變長結(jié)構(gòu)。操作碼長有4位(立即數(shù)運算)、5位(跳轉(zhuǎn),寄存器-存儲器運算)或8位(寄存器-寄存器運算)。支持的指令覆蓋了最基本的MOV、ADD、SUB、AND、OR、 XOR指令,以及移位、各種跳轉(zhuǎn)指令等。指令集中可不含清零、取反、自增和自減指令,因這些指令可由AND、 XOR、ADD、SUB指令代替。在51系列單片機中, 累加器的清零、取反、自增和自減運算(單周期)比累加器-立即數(shù)的邏輯運算(雙周期)快;而在實現(xiàn)了單周期單指令的RISC微控制器中,可用相應(yīng)的邏輯運算指令實現(xiàn)寄存器的清零、取反、自增和自減操作,對性能沒有影響。

圖3

5 邏輯綜合、仿真和硬件實現(xiàn)

  所有模塊均在Altera 公司的Quartus II 2.1上進行邏輯綜合、仿真測試通過,并在支持存儲器的 FLEX10KE系列FPGA器件上驗證實現(xiàn)。邏輯綜合結(jié)果為969個LE數(shù)(Logic Elements)。以下是一簡單程序,仿真波形如圖3。

000: ADD R1,#01H ;指令為1101H,R1對應(yīng)Pb輸出

001: MOV R2,Pa ;指令為FE62H,R2對于Pc輸出

002: JMP 000H ;指令為C000H,循環(huán)跳轉(zhuǎn)

  從仿真波形上可以清楚看到程序執(zhí)行時PC指針的改變、Pb口自增及Pa口的數(shù)據(jù)傳到Pc口的過程,也可大致看出程序的取指、執(zhí)行、回寫三級流水的執(zhí)行過程。同時還可看到在執(zhí)行跳轉(zhuǎn)指令JMP后自動插入一條空操作NOP指令(FFFFH)。

    注:源代碼見網(wǎng)站www.dpj.com.cn。

結(jié) 語

  從邏輯綜合與仿真測試的結(jié)果看,該微控制器完全達到了設(shè)計指標。設(shè)計的關(guān)鍵是三級流水線的實現(xiàn)和數(shù)據(jù)總線的控制。設(shè)計使用Verilog 語言描述,可讀性好,易于增減資源和修改功能,可方便地應(yīng)用于嵌入式系統(tǒng)中。由于時間倉促和水平有限,許多問題未能考慮,不足之處懇請讀者賜教。

本站聲明: 本文章由作者或相關(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)意到認證的所有需求的工具,可用于創(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)閉