Skip to content

Full FPGA Implementation of 32-bit FSM-based Multi-State MIPS Processor

License

Notifications You must be signed in to change notification settings

Kishan-Ved/mips-processor-basys3

 
 

Repository files navigation

mips-processor-basys3

Team ALUminati - ES215 Computer Organization and Architecture

The processor is implemented on the Basys3 FPGA board. The datapath has been modified carefully to expand the ISA - allowing recursive programs to run as well.

Check out the final report here and the final presentation here, it includes video demonstrations as well.

Some MIPS assembly codes are available in the codes directory. The utils directory contains a Python script to convert human-readable MIPS assembly code to machine code.

In the utils directory, write your human-readable MIPS assembly code in mips_instructions.txt run coe_generator.py:

python3 ./utils/coe_generator.py

data.coe will be ready to be used in the FPGA and even the 32-bit machine code will be available in mips_machine_code.txt.

Versions of the Processor

mips_v3.2 is the stable and FPGA-implementation ready version of the MIPS processor.

Modified Datapath

The FSM

The Complete ISA

BRAM

ALU

Factorial Waveform

About

Full FPGA Implementation of 32-bit FSM-based Multi-State MIPS Processor

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Verilog 74.5%
  • Python 17.7%
  • Tcl 7.8%