資料介紹
摘要:
隨著嵌入式領域和信息時代的蓬勃發展,微處理器設計開始被越來越多的人關注。目前國內很多高校和研究機構都開始設計微處理器。客觀的講,這些微處理器在硬件結構上比較簡單,缺乏匯編器、編譯器、操作系統以及各種I/O接口電路的支持,應用場合單一。另外,由于這些微處理器支持的指令集在格式上各有不同,因此造成了大量的設計資源浪費。我們旨在設計一套完備的高性能嵌入式SoC(System on Chip)系統,用以減少重復性設計工作,更好地普及高等院校的微處理器設計教育,吸引更多的人才專注于高性能微處理器研發;同時也提供給企業免費的SoC軟核,用于低成本的工業控制。
關鍵詞:RISC,微處理器,片上系統,minisys
1. 系統原理和技術特點
Minisys是東南大學計算機科學與工程學院系統結構實驗室開發的一款基于32位RISC架構的SoC系統。如圖1所示,Minisys包含一個以32位RISC型處理器為核心,附帶多個IO控制器的SoC芯片和相關的系統軟件。系統軟件包括以便于上層軟件編程而提供的系統功能調用接口為主體的BIOS、鍵盤驅動程序、以及Minisys匯編器(編譯器)。其中,Minisys SoC芯片功能結構如圖2所示。
![SoC系統設計與驗證](/uploads/allimg/171016/2362486-1G016104104253.png)
圖1 Minisys系統結構圖、
![SoC系統設計與驗證](/uploads/allimg/171016/2362486-1G016104112L6.png)
圖2 Minisys芯片功能結構圖
Minisys CPU有32個32位通用寄存器,32位數據線和16位地址線。IO部件包括一個4位7段LED數碼管控制器,一個4×4鍵盤控制器,一個16位定時/計數器,一個32位系統定時器,一個16位PWM控制器,一個看門狗電路和一個簡易UART串行通信控制器。
Minisys借鑒了MIPS指令集,指令定長32位,共有31條常用定點指令(不包括硬件乘除、硬件浮點指令)。32個32位寄存器除了5個寄存器被固定功能外,其余的都可以做通用寄存器。
Minisys采用哈佛存儲結構,片內包含4KB ROM和4KB RAM,都采用字節編制,但以32位為一個存儲單元,即他們和CPU之間的數據交換都以32位為單位進行。Minisys的I/O空間編址采用與存儲器統一編址方式,即將整個地址空間分為兩個部分,一部分作為訪問RAM的存儲空間,另一部分作為訪問IO的I/O空間。因此,對I/O部件的訪問采用與存儲器訪問相同的指令格式。
系統內部提供兩個中斷源的控制電路,兩個中斷源為INT0和INT1,其中INT0的優先級高于INT1,允許高優先級中斷嵌套。系統提供用于堆棧操作的SP寄存器,但沒有提供壓棧和退棧指令,因此對于堆棧的操作需要用軟件實現。堆棧操作的原子性由程序員負責。
2. 系統設計流程
Minisys SoC的設計包括了硬件設計和軟件設計。其中,硬件設計部分包括以下幾個部分:Minisys CPU的設計、接口部件的設計、BIOS的設計。軟件設計即為匯編器的設計。
在Minisys CPU設計中,主要考慮指令系統的確定、CPU結構的設計與實現、CPU寄存器組的組織與實現以及CPU的各個功能部件的設計與實現。下面主要介紹Minisys CPU的各個功能部件的設計和實現。
Minisysy CPU的內部功能部件被劃分為5歌基本單元:取指單元、譯碼單元、控制單元、執行單元和存儲單元。在設計CPU的時候,采用模塊化的設計方法,因此,以上這些單元是分別在相應的5歌模塊中進行設計,最后用一個頂層模塊將這5個模塊按照邏輯上的需要連接起來,成為一個完整的CPU。
取指單元
取指單元主要完成以下工作:到程序ROM中取指令;對PC值進行更新;完成各種跳轉指令的PC修改功能。本設計是在Altera公司的Quartus II環境下完成的,因此,在設計中使用了Altera公司已經設計好的rom宏模塊。
譯碼單元
譯碼單元的主要工作就是完成執行指令前的操作數準備工作,分析Minisys指令集得知,這些數據或者在寄存器中,或者是立即數,因此在譯碼單元中最重要的工作就是實現寄存器組和完成寄存器的讀寫并根據指令譯碼結果,決定向其他部件送一路還是兩路數據。
控制單元
控制單元是整個CPU的控制核心,各種控制信號都是從這里發出來的,而各種信號的值都是通過操作碼和功能碼的不同組合和一些約定來決定的。在設計中用SRCB來標志操作數的來源,具體操作如表1和表2所示。
表1 操作數A的來源標志
操作數零擴展的立即數ID階段取得的寄存器值
SRCA1’b01’b1
表2 操作數B的來源標志
操作數ID階段取得的寄存器值符號擴展的立即數零擴展的立即數
SRCB 2’b002’b012’b10||2’b11
執行單元
執行單元需要完成的工作歸納起來包括以下幾個方面:完成邏輯運算、完成算術運算、完成移位運算、完成比較轉移的PC值運算和完成比較后賦值操作。
存儲單元
存儲單元首先要實現數據RAM,并完成對數據RAM的讀寫操作。與指令ROM一樣,數據RAM也使用Altera公司提供的宏模塊來實現。Minisys擁有4KB的數據RAM,4個字節為一個讀寫單元,因此,它的RAM和ROM的初始化文件格式相同。
關于Minisys SoC的其他單元的設計將在系統中具體給出。
隨著嵌入式領域和信息時代的蓬勃發展,微處理器設計開始被越來越多的人關注。目前國內很多高校和研究機構都開始設計微處理器。客觀的講,這些微處理器在硬件結構上比較簡單,缺乏匯編器、編譯器、操作系統以及各種I/O接口電路的支持,應用場合單一。另外,由于這些微處理器支持的指令集在格式上各有不同,因此造成了大量的設計資源浪費。我們旨在設計一套完備的高性能嵌入式SoC(System on Chip)系統,用以減少重復性設計工作,更好地普及高等院校的微處理器設計教育,吸引更多的人才專注于高性能微處理器研發;同時也提供給企業免費的SoC軟核,用于低成本的工業控制。
關鍵詞:RISC,微處理器,片上系統,minisys
1. 系統原理和技術特點
Minisys是東南大學計算機科學與工程學院系統結構實驗室開發的一款基于32位RISC架構的SoC系統。如圖1所示,Minisys包含一個以32位RISC型處理器為核心,附帶多個IO控制器的SoC芯片和相關的系統軟件。系統軟件包括以便于上層軟件編程而提供的系統功能調用接口為主體的BIOS、鍵盤驅動程序、以及Minisys匯編器(編譯器)。其中,Minisys SoC芯片功能結構如圖2所示。
![SoC系統設計與驗證](/uploads/allimg/171016/2362486-1G016104104253.png)
圖1 Minisys系統結構圖、
![SoC系統設計與驗證](/uploads/allimg/171016/2362486-1G016104112L6.png)
圖2 Minisys芯片功能結構圖
Minisys CPU有32個32位通用寄存器,32位數據線和16位地址線。IO部件包括一個4位7段LED數碼管控制器,一個4×4鍵盤控制器,一個16位定時/計數器,一個32位系統定時器,一個16位PWM控制器,一個看門狗電路和一個簡易UART串行通信控制器。
Minisys借鑒了MIPS指令集,指令定長32位,共有31條常用定點指令(不包括硬件乘除、硬件浮點指令)。32個32位寄存器除了5個寄存器被固定功能外,其余的都可以做通用寄存器。
Minisys采用哈佛存儲結構,片內包含4KB ROM和4KB RAM,都采用字節編制,但以32位為一個存儲單元,即他們和CPU之間的數據交換都以32位為單位進行。Minisys的I/O空間編址采用與存儲器統一編址方式,即將整個地址空間分為兩個部分,一部分作為訪問RAM的存儲空間,另一部分作為訪問IO的I/O空間。因此,對I/O部件的訪問采用與存儲器訪問相同的指令格式。
系統內部提供兩個中斷源的控制電路,兩個中斷源為INT0和INT1,其中INT0的優先級高于INT1,允許高優先級中斷嵌套。系統提供用于堆棧操作的SP寄存器,但沒有提供壓棧和退棧指令,因此對于堆棧的操作需要用軟件實現。堆棧操作的原子性由程序員負責。
2. 系統設計流程
Minisys SoC的設計包括了硬件設計和軟件設計。其中,硬件設計部分包括以下幾個部分:Minisys CPU的設計、接口部件的設計、BIOS的設計。軟件設計即為匯編器的設計。
在Minisys CPU設計中,主要考慮指令系統的確定、CPU結構的設計與實現、CPU寄存器組的組織與實現以及CPU的各個功能部件的設計與實現。下面主要介紹Minisys CPU的各個功能部件的設計和實現。
Minisysy CPU的內部功能部件被劃分為5歌基本單元:取指單元、譯碼單元、控制單元、執行單元和存儲單元。在設計CPU的時候,采用模塊化的設計方法,因此,以上這些單元是分別在相應的5歌模塊中進行設計,最后用一個頂層模塊將這5個模塊按照邏輯上的需要連接起來,成為一個完整的CPU。
取指單元
取指單元主要完成以下工作:到程序ROM中取指令;對PC值進行更新;完成各種跳轉指令的PC修改功能。本設計是在Altera公司的Quartus II環境下完成的,因此,在設計中使用了Altera公司已經設計好的rom宏模塊。
譯碼單元
譯碼單元的主要工作就是完成執行指令前的操作數準備工作,分析Minisys指令集得知,這些數據或者在寄存器中,或者是立即數,因此在譯碼單元中最重要的工作就是實現寄存器組和完成寄存器的讀寫并根據指令譯碼結果,決定向其他部件送一路還是兩路數據。
控制單元
控制單元是整個CPU的控制核心,各種控制信號都是從這里發出來的,而各種信號的值都是通過操作碼和功能碼的不同組合和一些約定來決定的。在設計中用SRCB來標志操作數的來源,具體操作如表1和表2所示。
表1 操作數A的來源標志
操作數零擴展的立即數ID階段取得的寄存器值
SRCA1’b01’b1
表2 操作數B的來源標志
操作數ID階段取得的寄存器值符號擴展的立即數零擴展的立即數
SRCB 2’b002’b012’b10||2’b11
執行單元
執行單元需要完成的工作歸納起來包括以下幾個方面:完成邏輯運算、完成算術運算、完成移位運算、完成比較轉移的PC值運算和完成比較后賦值操作。
存儲單元
存儲單元首先要實現數據RAM,并完成對數據RAM的讀寫操作。與指令ROM一樣,數據RAM也使用Altera公司提供的宏模塊來實現。Minisys擁有4KB的數據RAM,4個字節為一個讀寫單元,因此,它的RAM和ROM的初始化文件格式相同。
關于Minisys SoC的其他單元的設計將在系統中具體給出。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 虹科ELLAB(易來博)溫度驗證系統目錄
- 利用Systemverilog+UVM搭建soc驗證環境 5次下載
- 基于雙接口NFC芯片的FPGA驗證系統 17次下載
- SoC設計中的驗證技術有哪些 12次下載
- 基于可重用激勵發生機制的虛擬SoC驗證平臺 0次下載
- SoC多語言協同驗證平臺技術研究 12次下載
- 基于ARM9的AFDX-ES SoC驗證平臺的構建與實現
- 使用Mentor產品進行SoC設計和驗證 0次下載
- 一種基于事務的SoC功能驗證方法
- Tensilica如何驗證處理器核心
- 基于SOC的USB主設備的軟硬件協同驗證
- SoC驗證環境搭建方法的研究
- 在SoC設計中采用ESL設計和驗證方法
- SoC芯片驗證技術的研究
- 用SystemC進行SoC的系統級設計與仿真
- SoC的數字簽名加解密過程 294次閱讀
- 什么是片上系統soc?片上系統soc主要包括什么? 1453次閱讀
- 什么是片上系統soc?soc如何工作的? 2523次閱讀
- 什么是片上系統SoC? 806次閱讀
- fpga驗證及其在soc驗證中的作用有哪些 1178次閱讀
- 移動SoC的時鐘驗證 796次閱讀
- 采用Altera Stratix II EP2S60器件實現SoC系統的FPGA實時驗證 2506次閱讀
- 基于VMM構建的驗證平臺在AXI總線協議SoC中的應用研究 1499次閱讀
- 一種能夠顯著提升客制化FPGA原型板驗證效率的創新方法淺析 673次閱讀
- 基于BFM測試和調試的Zynq SoC設計步驟及架構詳解 5343次閱讀
- SoC設計的可擴展驗證解決方案 956次閱讀
- 基于片上系統的SOC設計驗證方案 1546次閱讀
- 基于FPGA的Soc原型設計 2706次閱讀
- 如何利用軟件作為激勵來加速SoC系統級驗證? 1519次閱讀
- 基于OVM驗證平臺的IP芯片驗證 2844次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關電源基礎知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統的設計與實現
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發板設計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論