类MIPS单周期微处理器设计实验报告_钟远维_U201213500

类MIPS单周期微处理器设计实验报告_钟远维_U201213500

ID:37949270

大小:913.38 KB

页数:22页

时间:2019-06-03

类MIPS单周期微处理器设计实验报告_钟远维_U201213500_第1页
类MIPS单周期微处理器设计实验报告_钟远维_U201213500_第2页
类MIPS单周期微处理器设计实验报告_钟远维_U201213500_第3页
类MIPS单周期微处理器设计实验报告_钟远维_U201213500_第4页
类MIPS单周期微处理器设计实验报告_钟远维_U201213500_第5页
资源描述:

《类MIPS单周期微处理器设计实验报告_钟远维_U201213500》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、word格式文档类MIPS单周期微处理器设计实验报告专业:电子信息工程班级:卓越1201班学号:U201213500姓名:钟远维专业整理word格式文档一、实验目的1.了解微处理器的基本结构2.掌握哈佛结构的计算机工作原理3.学会设计简单的微处理器4.了解软件控制硬件工作的基本原理二、实验任务利用HDL语言,基于XilinxFPGAnexys4实验平台,设计一个能够执行以下MIPS指令集的单周期类MIPS处理器,要求完成所有支持指令的功能仿真,验证指令执行的正确性,要求编写汇编程序将本人学号的ASCII码存入RAM的连续内存区域——支持基本的内存操作如lw,sw指令——支持基本的算术逻

2、辑运算如add,sub,and,or,slt,andi指令——支持基本的程序控制如beq,j指令三、微处理器各模块设计专业整理word格式文档各模块的框图结构如上图所示。由图可知,该处理器包含指令存储器、数据存储器、寄存器组、ALU单元、符号数扩张、控制器、ALU控制译码以及多路复用器等。图中还忽略了一个单元:时钟信号产生器,而且以上各个部件必须在时钟信号的控制下协调工作。1.指令存储器的设计指令寄存器为ROM类型的存储器,为单一输出指令的存储器。因此其对外的接口为clk、存储器地址输入信号(指令指针)以及数据输出信号(指令)。(1)在IPwizard中配置ROM,分配128个字的存储

3、空间,字长为32位宽。(2)选择输入具有地址寄存功能,只有当时钟上升沿有效时,才进行数据的输出。(3)配置ROM内存空间的初始化COE文件。最后单击Generate按钮生成IROM模块。2.数据存储器的设计数据存储器为RAM类型的存储器,并且需要独立的读写控制信号。因此其对外的接口输入信号为clk、we、datain、addr;输出信号为dataout。数据存储器基本建立过程同ROM的建立。3.寄存器组设计寄存器组是指令操作的主要对象,MIPS中一共有32个32位寄存器。在指令的操作过程中需要区分Rs、Rt、Rd的地址和数据,并且Rd的数据只有在寄存器写信号有效时才能写入,因此该模块的

4、输入为clk、RegWriteAddr、RegWriteData、RegWriteEn、RsAddr、RtAddr、reset;专业整理word格式文档输出信号为RsData、RtData。由于$0一直输出0,因此当RsAddr、RtAddr为0时,RsData以及RtData必须输出0,否则输出相应地址寄存器的值。另外,当RegWriteEn有效时,数据应该写入RegWriteAddr寄存器。并且每次复位时所有寄存器都清零。代码如下:moduleregFile(inputclk,inputreset,input[31:0]regWriteData,input[4:0]regWrite

5、Addr,inputregWriteEn,output[31:0]RsData,output[31:0]RtData,input[4:0]RsAddr,input[4:0]RtAddr);reg[31:0]regs[0:31];assignRsData=(RsAddr==5'b0)?32'b0:regs[RsAddr];assignRtData=(RtAddr==5'b0)?32'b0:regs[RtAddr];integeri;always@(posedgeclk)beginif(!reset)beginif(regWriteEn==1)beginregs[regWriteAddr]

6、=regWriteData;endendelsebeginfor(i=0;i<31;i=i+1)regs[i]=0;regs[31]=32'hffffffff;endendendmodule1.ALU设计在这个简单的MIPS指令集中,微处理器支持add、sub、and、or、slt运算指令,需要利用ALU单元实现运算,同时数据存储指令sw、lw也专业整理word格式文档需要ALU单元计算存储器地址,条件跳转指令beq需要ALU来比较两个寄存器是否相等。所有这些指令包含的操作为加、减、与、或小于设置5种不同的操作。该模块根据输入控制信号对输入数据进行相应的操作,并获得输出结果以及零标示,

7、由于MIPS处理器ALU单元利用4根输入控制线的译码决定执行何种操作,因此该模块的接口为:输入:input1(32bit),input2(32bit),aluCtr(4bit)输出:zero(1bit),alluRes(32bit)代码如下:moduleALU(input[31:0]input1,input[31:0]input2,input[3:0]aluCtr,output[31:0]aluRes,outputzero);regzero;r

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。