华科 - HUST - 微机原理 - 类MIPS单周期微处理器设计 - 实验报告

2019-02-16 12:32

微机原理实验报告

学号 姓名 专业

华中科技大学

通信1301 罗杰

指导教师 院(系、所)

电信学院

类MIPS单周期微处理器设计

一.实验目的

1. 了解微处理器的基本结构。

2. 掌握哈佛结构的计算机工作原理。 3. 学会设计简单的微处理器。

4. 了解软件控制硬件工作的基本原理。

二.实验任务

利用HDL语言,基于Xilinx FPGA nexys4实验平台,设计一个能够执行以下MIPS指令集的单周期类MIPS处理器,要求完成所有支持指令的功能仿真,验证指令执行的正确性,要求编写汇编程序将本人学号的ASCII码存入RAM的连续内存区域。

(1)支持基本的算术逻辑运算如add,sub,and,or,slt,andi指令 (2)支持基本的内存操作如lw,sw指令 (3)支持基本的程序控制如beq,j指令

三.各模块实现原理 1. 指令存储器设计

指令存储器为ROM类型的存储器,为单一输出指令的存储器。设置一个程序计数器指针PC指向指令存储器,当时钟上升沿到来时,取出PC所指的指令,当时钟的下降沿到来时,修改PC的值,使其指向下一条要执行的指令。因此其对外的接口为clk、存储器地址输入信号(指令指针)以及数据输出信号(指令)。在本实验中调用ISE提供的IP核进行设计,设定的指令存储器大小为128字。

指令存储器模块在顶层模块中被调用。输入为指令指针(PC)与时钟信号(clkin),输出为32位的机器指令,并将输出的机器指令送到后续的寄存器组模块、控制器模块、立即数符号扩展模块进行相应的处理。 2. 数据存储器设计

数据存储器为RAM类型的存储器,并且需要独立的读写信号控制。因此其对外的接口为clk、we、datain、addr;输出信号为dataout。当时钟上升沿到来时,如果写信号(we)为真,根据addr所表示的地址找到对应的存储单元,并将输入的数据(datain)写到对应的存储单元中;如果写信号为假,则根据addr所表示的地址,将对应存储单元的数据送到输出端(dataout)。在本实验中调用ISE提供的IP核进行设计,设定的数据存储器大小为64字。

数据存储器模块在顶层模块中被调用。输入的时钟信号来自于顶层模块的clkin,addr信号来自于ALU单元的输出端(对基地址与偏移量执行加操作),datain来自于寄存器组的第二个数据输出端(Rtdata),而控制信号we则来自于控制器对指令的译码。输出数据dataout通过一个选择器(MUX3)决定是否写入到相应的寄存器。 3. 寄存器组设计

寄存器组是指令操作的主要对象,MIPS中一共有32个32位寄存器。在指令的操作过程中需要区分Rs、Rt、Rd的地址和数据,并且Rd的数据只有在寄存器写信号有效时才能够写入,因此该模块的输入为clk、RegWriteData、RegWriteAddr、RegWriteEn、RsAddr、RtAddr和reset,输出信号为RsData和RtData。由于$0一直输出0,因此当RsAddr、RtAddr为0时,RsData以及RtData必须输出0,否则输出相应地址寄存器数据。另外,当RegWriteEn

信号有效时,数据应该写入RegWriteAddr寄存器,并且每次复位时所有寄存器都清零。

寄存器组模块在顶层模块中被调用。clk信号来自于顶层模块的clkin,reset信号来自于顶层模块的reset,RegWriteData来自于ALU单元的运算结果输出端或者是数据存储器的输出端(通过一个选择器MUX3进行选择),RegWriteAddr、RsAddr、RtAddr来自于指令的对应位,RegWriteEn来自于控制器对指令的译码。输出信号Rsdata与Rtdata则分别来自于Rsaddr与Rtaddr对应的寄存器。

代码如下:

module regFile( input clk, input reset,

input [31:0] regWriteData, input [4:0] regWriteAddr, input regWriteEn, output [31:0] RsData, output [31:0] RtData, input [4:0] RsAddr, input [4:0] RtAddr );

reg[31:0] regs[0:31];

assign RsData = (RsAddr == 5'b0)?32'b0:regs[RsAddr]; assign RtData = (RtAddr == 5'b0)?32'b0:regs[RtAddr];

integer i;

always @(posedge clk) begin

if(!reset) begin

if(regWriteEn==1) begin

regs[regWriteAddr]=regWriteData; end end else

begin

for(i=0;i<31;i=i+1) regs[i]=0;

regs[31]=32'hffffffff; end end endmodule 4. ALU设计

在这个简单的MIPS指令集中,微处理器支持的add、sub、and、or和slt运算指令,需要利用ALU单元实现运算,同时数据存储指令sw和lw也需要通过ALU单元计算存储器地

址,条件跳转指令beq需要ALU来比较两个寄存器是否相等。所有这些指令包含的操作为加、减、与、或和小于设置5钟不同的操作。

该模块根据输入控制信号对输入数据进行相应的操作,并获得输出结果以及零标识,由于MIPS处理器ALU单元利用4根输入控制信线的译码决定执行何种操作,于是该操作的输入接口为input1、input2和aluCtr,输出端口为zero和aluRes。

ALU模块在顶层模块被调用。input1来自于寄存器组模块输出信号Rsdata,input2来自于寄存器组模块输出信号Rtdata或者是立即数符号扩展模块的输出信号(通过一个选择器MUX2进行选择),aluCtr来自于aluctr模块的输出端。aluRes与zero为ALU单元的运算结果,其中zero主要用于beq指令。

代码如下: module ALU(

input [31:0] input1, input [31:0] input2, input [3:0] aluCtr, output [31:0] aluRes, output zero );

reg zero;

reg[31:0] aluRes;

always @(input1 or input2 or aluCtr) begin

case(aluCtr) 4'b0110: begin

aluRes=input1-input2; if(aluRes==0) zero=1; else

zero=0; end 4'b0010:

aluRes=input1+input2; 4'b0000:

aluRes=input1&input2; 4'b0001:

aluRes=input1|input2; 4'b1100:

aluRes=~(input1|input2); 4'b0111: begin

if(input1

end

default: aluRes = 0; endcase end

endmodule 5. ALU控制设计

ALU单元对应的5种操作的编码。

MIPS指令中具有6位操作码,如果为R型指令,进一步采用6位功能码来表示R型指令的具体操作。由于设计的微处理器支持的运算类指令全部为R型指令,因此可以通过对R型指令的6位功能码编码产生ALU的4为控制信号。但是lw、sw以及beq、j型指令没有功能码,因此需要区分指令的类型。由于只有三类指令需要ALU单元,因此可以采用两位二进制码对指令的ALU操作类型进行编码。指令的ALU操作类型编码由指令译码器产生。

通过2位操作类型码以及6位指令功能码就可以产生ALU单元的4位控制信号。 指令 LW SW BEQ R型指令 R型指令 R型指令 R型指令 R型指令 ADDI 因此该模块的主要功能就是根据译码控制单元产生的2位操作码以及6位功能码产生4位ALU控制信号,因此输入信号为aluop(2位)、funct(6位),输出信号为aluctr(4位)。ALU控制模块在顶层模块被调用。aluop来自于控制器对指令的6位opcode的译码,而funct来自于指令的后6位。

module aluctr(

input [1:0] ALUOp, input [5:0] funct, output [3:0] ALUCtr );

reg[3:0] ALUCtr;

always @(ALUOp or funct)

2位操作码 00 00 01 10 10 10 10 10 11 指令功能 取字 存字 相等跳转 加 减 与 或 小于设置 加立即数 6位功能码 XXXXXX XXXXXX XXXXXX 100000 100010 100100 100101 101010 XXXXXX ALU的运算 加 加 减 加 减 与 或 小于设置 加 ALU的控制信号 0010 0010 0110 0010 0110 0000 0001 0111 0010


华科 - HUST - 微机原理 - 类MIPS单周期微处理器设计 - 实验报告.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:酶促反应动力学实验

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: