# 32 bits MIPS RISC Processor

# Herless Alvarado

Computer Science 4th semester UTEC

Lima, Peru

herless.alvarado@utec.edu.pe

https://github.com/herlessjap/32-bits-MIPS-RISC-Processor

Abstract—The project for the course of Computer Architecture at UTEC is to develop a 32 bits MIPS RISC Processor with 24 instructions among R-type, I-type and J-type. All of these were develop and exceuted in three different testbenches and the results are shown in the paper.

Index Terms—Computer Architecture, mips, verilog, processor, 32bits

### I. INTRODUCTION

Early in the 1985 MIPS was introduced which stands for Microprocessor without Interlocked Pipelined Stages. MIPS is a reduced instruction set computer (RISC) instruction set architecture (ISA). The final project for the course CS2201 - Computer Architecture is to develop a 32 Bits Pathline RISC MIPS in verilog which supports r-type, i-type and j-type instructions. The instructions are the following:

| add | addi | lb  | beq  |
|-----|------|-----|------|
| sub | subi | lh  | bneq |
| and | andi | lw  | bgez |
| nor | ori  | sb  | j    |
| or  | slti | sh  | jr   |
| slt |      | sw  | jal  |
|     |      | lui |      |

The datapath for this project is image shown in Figure 1. To see the datapath in full image you can check the README.md in the github source code.



Fig. 1. MIPS Datapath

The size of the Instruction Memory and Data Memory are of 256 bytes, both memories are byte-addressable. Furthermore, the endianness of the datapath is big-endian.

# II. METHODOLOGY

This paper aims to explain the development, analysis and results of a 32 bits MIPS datapath though MIPS is a very well known instruction set architecture in which most of the gathered information was quantitative found on the internet. The base knowledge to build this project is being familiarized with MIPS assembly instructions and also know how a datapath works and its elements work together, all of this information is on the book "Computer Organization and Design by Patterson and Hennessy"

## III. EXPERIMENTAL SETUP

The base to begin the project was the knowledge from the Computer Organization and Design and some verilog tutorials from the web.

# R-TYPE

The R-type instructions were done first. The modules for this were created as follow, Program Counter, Instruction Memory, Register File and ALU. R-type instructions were not that complex and done in a very short time after of the first gathered of knowledge.

For the R instructions all have the same control Operation which is shown in Figure 2.

```
case (Opcode)
    6'b000000: begin //r-instructions and jr
    RegDst = 1'b0;
    Jump = 1'b0;

    Branch = 1'b0;
    MemRead = 3'b000;
    MemToReg = 2'b00;
    ALUOp = 2'b10;
    ALUOpImmmediate = 3'b000;
    MemWrite = 2'b00;
    ALUSrc = 1'b0;
    RegWrite = 2'b01;
end
```

Fig. 2. R-type-OpCode

The operation is calculated depending on the ALUOp and func which is shown in Figure 3.

```
always @(ALUOp & func)
begin
    if (ALUOp == 2'b10 & func == 6'b100000) //add
        ALUControl = 4'b0010;
    if (ALUOp == 2'b10 & func == 6'b100010) //sub
        ALUControl = 4'b0110;
    if (ALUOp == 2'b10 & func == 6'b100100) //and
        ALUControl = 4'b0000;
    if (ALUOp == 2'b10 & func == 6'b100111) //nor
        ALUControl = 4'b1100;
    if (ALUOp == 2'b10 & func == 6'b100101) //or
        ALUControl = 4'b0001;
    if (ALUOp == 2'b10 & func == 6'b101010) //slt
        ALUControl = 4'b0111;
end
```

Fig. 3. R-type-Operation

#### I-TYPE

The next instructions done were the first column of I-type shown in Introduction. As in the R-type instructions was missing the Control Unit it was a need for this instruction. The I-type instructions created the following modules, Sign Extend, Control, ALUControl, Multiplexer InsReg and Multiplexer RegALU. The I-type instruction were difficult and took some time to finish.

The main difference of Immediate instructions is that they use a sign\_extend to extend 16 bits to 32 bits shown in Figure 4.

```
module sign_extend(sign_in, sign_out);
input [0:15] sign_in;
output [0:31] sign_out;
assign sign_out[16:31] = sign_in[0:15];
assign sign_out[0:15] = 1'b0;
endmodule
```

Fig. 4. I-type-SignExtend

Also to decide which instruction to execute depends on the ALUOp and ALUOpImmediate shown in Figure 5.

# J-TYPE

Lastly the J-type instructions created the modules And, Multiplexer ControlPC, ImmediateShiftLeft,Multiplexer PC-ShiftAdd, PCAddShift, PCShiftLeft,Multiplexer Rad1PC and ShiftPlusPC.

This was the most complicated one because of the amount of modules created. The most important are the two shift lefts

```
always @(ALUOp & ALUOpImmmediate)
begin
    if (ALUOp == 2'b11 & ALUOpImmmediate == 3'b001) //addi
        ALUControl = 4'b0010;
    if (ALUOp == 2'b11 & ALUOpImmmediate == 3'b010) //subi
        ALUControl = 4'b0110;
    if (ALUOp == 2'b11 & ALUOpImmmediate == 3'b011) //andi
        ALUControl = 4'b0000;
    if (ALUOp == 2'b11 & ALUOpImmmediate == 3'b100) //ori
        ALUControl = 4'b0001;
    if (ALUOp == 2'b11 & ALUOpImmmediate == 3'b101) //slti
        ALUControl = 4'b0111;
end
```

Fig. 5. I-type-Operation

```
module immediate_shift_left(in,out);
input [0:31] in;
output [0:31] out;
assign out = {in[2:31], 1'b0, 1'b0};
endmodule
```

Fig. 6. Immediate ShiftLeft

used one for 26 bits code and another for immediate 16 bits numbers shown in Figure 6 and 7.

Another important module is the sum between pc+4 and Immediate shift left, this is shown in Figure 8.

Last but not least the is an and operator which compares branch signal with zero signal, this is shown in Figure 9.

This were most of the modules used for the j-type instructions, there are also some multiplexers but are not going to be shown.

#### IV. EVALUATION

There are 3 testbenches for this datapath. The first testbench contains the first and second columns of the instructions shown in the Introduction table. The second testbench contains the third column and lastly the third testbench contains the fourth column of instructions.

The first testbench modules are shown in Fig 10.

The first testbench is compiled with the following command *iverilog ri\_instructions\_tb.v alu\_control.v alu.v control.v data\_memory.v ins\_mem.v ins\_mux\_reg.v pc.v reg\_file.v reg\_mux\_alu.v sign\_extend.v data\_mux\_reg.v and the output is in Fig 11.* 

The second testbench modules are shown in Fig 12.

The second testbench is compiled with the following command *iverilog ls\_instructions\_tb.v alu\_control.v alu.v control.v data\_memory.v ins\_mem.v ins\_mux\_reg.v pc.v reg\_file.v reg\_mux\_alu.v sign\_extend.v data\_mux\_reg.v and the output is in Fig 13.* 

The third testbench modules are shown in Fig 14.

```
module pc_shift_left(in,out);
input [0:25] in;
output [0:27] out;
assign out = {in[0:25], 1'b0, 1'b0};
endmodule
```

Fig. 7. 26 bits ShiftLeft

```
module shift_plus_pc(shiftin,pcin,jaddress);
input [0:27] shiftin;
input [0:31] pcin;
output reg [0:31] jaddress;

always @(*)begin
    jaddress[0:3] <= pcin[0:3];
    jaddress[4:31] <= shiftin;
end
endmodule</pre>
```

Fig. 8. PC+4 add ImmediateShift

The third tesbench is compiled with the following command iverilog j\_instructions\_tb.v alu\_control.v alu.v and.v control mux pc.v control.v data memory.v data\_mux\_reg.v immediate\_shift\_left.v ins\_mem.v ins\_mux\_reg.v *pc\_add\_shift2.v* pc\_shift\_left.v pc.vpc4\_mux\_sl2add.v rad1\_mux\_pc.v reg\_file.v reg\_mux\_alu.v shift\_plus\_pc.v sign\_extend.v and the output is in Fig 15.

# V. Conclusions

MIPS is an understandable Instruction Set Architecture which can easily learned from the Computer Organization and Design by Patterson and Hennessy book. Furthermore, verilog is also an easy HDL to learn specially if you are familiarized with C-language. The datapath was mostly challenging in the immediate instructions in the way of getting to understand how the instructions divides and goes through the datapath.

The datapath itself is challenging because of the knowledge required to know what each module does. The jump instructions were a little difficult because of the big amount of multiplexers and modules to each one.

The final conclusions is that this project can be done in two weeks with the previous knowledge of MIPS and verilog.

# VI. COMMENTS

The first difficult I found is that most of the implementations of the datapath were little endian and it was given to make it big endian. Another difficult is that there is no much information about some instructions and how they go through

```
module andm(in1,in2,out);
input in1,in2;
output out;
assign out = in1&in2;
endmodule
```

Fig. 9. Module AND

```
pc pcl(clk,reset,out):
InstructionHemory inl(clk,out,instruction):
control coni(Opcode,RegDst,Jump,Branch,MemRead,MemToReg,ALUOp,ALUOpImmmediate,MemWrite,ALUSrc,RegWrite):
ins_mu_reg muxl(rad2,writeadd,RegDst,writereg);
slum_centrol sign(sign_in_sign_out):
alum_control alum(iALUOp,ALUOpImmmediate,func,ALUControl);
reg_file regIc(kx,rad1,rad2,writereg),writedata,RegWrite,readdata1,readdata2);
reg_mu_alumux2(readdata2,sign_out,ALUSrc,resmux);
alumulu(ikk,raddata1,resux,ALUControl,alures,Zerol);
data_muxreg_muxl(data_alux,res_readdata2,MemRead,MemWrite,data);
data_muxreg_muxl(data_alux,res_sign_out,paddress_MemRede,writedata);
```

Fig. 10. First testbench modules

the datapath because when you dont know you have to manage to get to the correct result. Last difficult found is that some instructions needed more wires to get to the right answer and you have to create new wires and even extend the bits of some wire to get the right answer. I would really suggest to have some labs in class to teach how to begin with the datapath and the teacher going along with the students

## REFERENCES

- [1] D. Patterson and J. Hennessy, "Computer Organization and Design," 4th ed., San Mateo, CA:Morgan Kaufman, 2006.
- [2] MIPS, "MIPS32 Architecture," Accessed on: June. 15, 2019. [Online]. Available: https://www.mips.com/products/architectures/mips32-2/
- [3] University of Minnesota Duluth, "MIPS R-Type Instruction Coding," Accessed on: June. 16, 2019. [Online]. Available: https://www.d.umn.edu/gshute/mips/rtype.xhtml
- [4] University of Minnesota Duluth, "MIPS I-Type Instruction Coding," Accessed on: June. 20, 2019. [Online]. Available: https://www.d.umn.edu/gshute/mips/itype.xhtml
- [5] University of California, "MIPS Reference Sheet," Accessed on: June. 20, 2019. [Online]. Available: https://www.d.umn.edu/ gshute/mips/itype.xhtml
- [6] University of Idaho, "MIPS Instruction Reference," Accessed on: June. 20, 2019. [Online]. Available: http://www.mrc.uidaho.edu/mrc/people/jff/digital/MIPSir.html
- [7] University of Cambridge, "MIPS-Datapath," Accessed on: June. 24, 2019. [Online]. Available: http://mi.eng.cam.ac.uk/ ahg/MIPS-Datapath/

```
5-type Section(1992) and the section of the section
```

Fig. 11. First testbench output

```
pc pc1(clk, reset,out);
InstructionMemory inI(clk,out,instruction);
control conl (Opcode, RegOst,Jump, Branch, MemRoad, MemToReg, ALUOp, ALUOpImmediate, MemWrite, ALUSrc, RegWrite);
inn_gux_reg_susl(radz_writeado, RegOst,writereg);
slu_control slucl(ALUOp, ALUOpImmediate, func, ALUControl);
reg_llle regic(kk,radj,radj,writereg, writeadsa, RegWrite, readdata1, readdata2);
reg_gux_alu susz(readdata2, sign_out, ALUSrc, resmus);
slu_alu(kk,radj,radj,writereg, writeadsa, RegWrite, readdata1, readdata1, readdata1, readdata1, readdata2, writeadsa1, readdata1, readdata1, readdata1, readdata1, readdata1, readdata1, readdata1, alures, zerol);
data_memory dsta1(clk, alures, readdata2, MemRoad, MemWrite, data);
data_mux_reg_mux](data1, alures, sign_out, readdress, MemToReg, writedata);
```

Fig. 12. Second testbench modules

Fig. 13. Second testbench output

```
pc pt(clk,reset,out);
InstructionMemory in1c(th,out,instruction);
control con1(0pcode,RegDet,Jump,Branch,MemRead,MemToReg,ALUOp,ALUOpImmmediate,MemMrite,ALUSrc,RegWrite);
pc.shift_left shift(shiftiont,out,jaddress);
immediate_shift_left shift(shiftout);
pc.add_shift2_shifte(out,shiftout2);
pc.add_shift2_shifte(out,shiftout2,outpcshift);
andm and1(zero,Branch,outand);
pcf_mux_St2add mux6(out,outpcshift,outand,fandout);
control_mux_pc mux6(yaddress,fandout,Jump,ellminar2);
radl_mux_pc mux1(rad2,writeadd,RegDst,writereg);
sign_extend signlisign_in,sign_out);
ins_mux_reg mux1(rad2,writeadd,RegDst,writereg);
sign_extend signlisign_in,sign_out);
ins_mux_reg mux1(rad2,writeadd,RegDst,writereg);
sign_extend signlisign_in,sign_out);
ins_mux_reg mux1(rad2,writereg,writedata,RegMrite,readdata1,readdata2);
reg_file reglic(k,radd,rad2,writereg,writedata,RegMrite,readdata1,readdata2);
reg_mux_alu mux2(readdata2,sign_out,ALUSontrol,alures,zero);
data_mux_reg mux3(data,resmux,ALUControl,alures,zero);
data_mux_reg mux3(data,alures,sign_out,out;MemToReg,writedata);
data_mux_reg mux3(data,alures,sign_out,out;MemToReg,writedata);
```

Fig. 14. Third testbench modules

Fig. 15. Third testbench output