《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于RISC技術的8位微控制器設計
基于RISC技術的8位微控制器設計
摘要: 隨著微電子技術的不斷發展,超大規模集成電路的集成度和工藝水平不斷提高,將整個應用電子系統集成在一個芯片中(SoC),已成為現代電子系統設計的趨勢;以往高復雜度、高成本的嵌入式系統結構能夠通過低成本的單片芯片實現。
Abstract:
Key words :

       引 言


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

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

       1.1 RISC的結構特征和設計原則  
  精簡指令集計算機具有單周期單指令,存儲器到寄存器的操作,簡單的尋址方式和簡單的指令格式的結構特征,其設計原則為:


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

       ② 指令的結構簡單,所有指令長度相等;

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

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

       ⑤ 采用通用寄存器(GPR)結構;

       ⑥ 優化編譯,提高執行效率。

       1.2 性能因子CPI和執行時間

 

  性能因子是指微控制器每條指令的平均時鐘周期數CPI(Cycles Per Instruction),執行時間是微控制器性能的主要指標。在影響t的三個因素中,時鐘頻率取決于硬件技術;CPI與指令集和MCU的組成結構有關;而指令數由指令集和編譯技術決定。要使微控制器的性能得到提高,優化指令集、減少程序的總指令數和降低CPI值是設計主要考慮的問題。

       2 微控制器的系統結構

微控制器系統框圖


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

       ① PROM程序存儲器單元(Program ROM)。程序存儲器容量為2K×16位。系統復位后,程序計數器PC指向程序存儲器000H單元,程序從000H處開始執行。

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

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

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

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

       ⑥ CTRL控制單元(ControlUnit)。整個MCU的控制中心,主要控制流水線操作、數據總線的控制和程序計數器的轉移。另外,還包括中斷、計數器和堆棧控制。

       ⑦ 其它。定義了1組數據輸入端口、2組數據輸出端口,數據位寬均為8位;2個外部中斷輸入INT0和INT1;1個8位計數器TIMER;7級程序堆棧Stack,可實現7級子程序調用;1個8位的程序狀態控制寄存器PSW。


       3 流水線技術

       3.1 三級流水線結構

三級流水線示意圖


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

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

 

制信號;

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

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

       3.2 流水線競爭及解決

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

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

       4 指令集和指令格式 

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

       5 邏輯綜合、仿真和硬件實現

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

仿真波形

 

       000: ADD R1,#01H ;指令為1101H,R1對應Pb輸出

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

       002: JMP 000H ;指令為C000H,循環跳轉

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

       結 語

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

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产午夜精品在线观看| 国产精品人人爽人人做我的可爱| 亚洲国产一区二区视频| 亚洲欧美日韩在线一区| 在线亚洲激情| 亚洲毛片av| 亚洲三级视频在线观看| 亚洲第一网站| 伊人久久久大香线蕉综合直播| 国产日韩欧美黄色| 国产精品男gay被猛男狂揉视频| 欧美午夜精品久久久| 欧美日韩国产综合久久| 欧美精选午夜久久久乱码6080| 欧美wwwwww| 欧美xart系列高清| 欧美成年人视频网站| 你懂的成人av| 欧美mv日韩mv国产网站| 女主播福利一区| 欧美大片网址| 欧美日本韩国一区| 欧美性大战久久久久| 国产精品高精视频免费| 国产精品视频精品视频| 国产农村妇女毛片精品久久麻豆 | 性欧美精品高清| 午夜宅男欧美| 久久精品国产99精品国产亚洲性色| 欧美一区视频| 久久免费99精品久久久久久| 另类春色校园亚洲| 欧美大香线蕉线伊人久久国产精品| 欧美成人中文字幕| 欧美日韩亚洲一区三区| 国产精品久久久久久亚洲调教 | 午夜电影亚洲| 亚洲视频狠狠| 午夜天堂精品久久久久| 久久成人av少妇免费| 亚洲国产精品久久久久婷婷老年| 亚洲激情婷婷| 99精品久久久| 午夜精品一区二区三区在线播放| 久久精品国产欧美亚洲人人爽| 久久一区二区三区四区| 欧美国产极速在线| 欧美午夜精品久久久久免费视 | 国产美女精品免费电影| 韩国福利一区| 亚洲美女区一区| 亚洲欧美日韩成人高清在线一区| 中国亚洲黄色| 日韩午夜在线观看视频| 久久国产精品久久久久久| 亚洲高清自拍| 亚洲图片你懂的| 久久国产精品一区二区三区| 裸体一区二区| 欧美午夜片欧美片在线观看| 国产一区二区三区高清| 亚洲三级电影全部在线观看高清| 亚洲淫片在线视频| 亚洲人成网在线播放| 亚洲一区二区免费| 久久免费观看视频| 欧美日韩在线一区二区三区| 欧美精品性视频| 午夜在线成人av| 亚洲欧洲精品一区二区三区不卡 | 亚洲精品一线二线三线无人区| 欧美精品一区二区三区视频| 一区二区三区四区五区精品| 欧美三区在线视频| 国产色视频一区| 亚洲黄一区二区三区| 亚洲欧美国产精品va在线观看| 亚洲女人小视频在线观看| 欧美电影免费观看大全| 欧美亚洲成人免费| 在线免费观看日本一区| 亚洲欧美一区二区三区极速播放 | 亚洲视频欧洲视频| 亚洲高清视频在线观看| 亚洲欧美日韩国产| 欧美粗暴jizz性欧美20| 国产一区999| 这里是久久伊人| 亚洲乱亚洲高清| 久久久久91| 国产精品家教| 亚洲美女福利视频网站| 久久精品免费电影| 欧美一级二区| 国产精品v日韩精品v欧美精品网站| 很黄很黄激情成人| 亚洲欧美日韩综合| 亚洲直播在线一区| 欧美日韩福利| 最新国产精品拍自在线播放| 欧美在线综合| 欧美一区中文字幕| 欧美午夜欧美| 久久久欧美精品| 久久久中精品2020中文| 国产精品久久午夜| 99re这里只有精品6| 亚洲日本国产| 久久综合久色欧美综合狠狠| 国产日韩在线播放| 亚洲一区三区视频在线观看| 一区二区三区四区国产| 欧美国产激情二区三区| 亚洲摸下面视频| 一区二区三区精品国产| 午夜精品福利一区二区蜜股av| 国产在线精品自拍| 国产一区二区三区免费在线观看| 狠狠做深爱婷婷久久综合一区 | 久久激情综合| 香蕉久久精品日日躁夜夜躁| 亚洲午夜羞羞片| 欧美人与性禽动交情品| 亚洲国产三级在线| 亚洲激情在线| 美女啪啪无遮挡免费久久网站| 国产网站欧美日韩免费精品在线观看 | 欧美伊久线香蕉线新在线| 午夜在线一区二区| 亚洲视频免费看| 精品88久久久久88久久久| 一区二区三区日韩欧美精品| 欧美成人免费视频| 蜜臀久久99精品久久久久久9| 久久综合九色九九| 性欧美大战久久久久久久久| 性伦欧美刺激片在线观看| 国产精品嫩草久久久久| 亚洲一区二区三区高清| 欧美一区二区三区视频在线| 国产日本欧美视频| 久久精品盗摄| 免费亚洲网站| 亚洲狼人精品一区二区三区| 亚洲社区在线观看| 国产精品theporn88| 亚洲在线第一页| 久久久久久免费| 一区二区视频免费在线观看 | 亚洲一区久久久| 国产精品免费看片| 欧美综合77777色婷婷| 久久一区二区三区av| 亚洲韩国青草视频| 亚洲午夜av| 国产女优一区| 国产欧美欧美| 欧美日韩在线一区二区三区| 欧美日韩国产高清| 欧美日韩精品三区| 一本色道久久88亚洲综合88 | 欧美一区午夜视频在线观看| 国产欧美另类| 久久精品99国产精品酒店日本| 免费亚洲电影在线观看| 99riav久久精品riav| 欧美一二区视频| 激情懂色av一区av二区av| 亚洲精品视频免费在线观看| 欧美无乱码久久久免费午夜一区| 亚洲欧美日韩国产中文 | 欧美区视频在线观看| 亚洲视频在线一区| 久久夜色精品| 亚洲精品人人| 欧美一区二区日韩| 亚洲第一偷拍| 亚洲欧美一区二区精品久久久| 国产欧美日韩免费| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美日韩一区二| 午夜在线成人av| 欧美激情视频一区二区三区在线播放| 中日韩高清电影网| 麻豆免费精品视频| 中文亚洲视频在线| 国产精品午夜久久| 亚洲东热激情| 亚洲手机视频| 国产在线精品成人一区二区三区| 亚洲高清久久网| 一本色道久久88综合日韩精品| 久久精品一区| 欧美国产亚洲另类动漫| 亚洲一级免费视频| 欧美成人免费小视频| 亚洲一区二区精品在线| 欧美成人一区二区三区| 亚洲欧美日韩一区二区| 久久久欧美精品sm网站|