Extending a MIPS Simulator for FPGA Support by Sanderson, Pete
Extending a MIPS Simulator for 
FPGA Support
Pete Sanderson, Otterbein University
Ken Vollmar, Missouri State University
FPGA overview
• Field Programmable Gate Array (FPGA) is “programmable 
hardware.”
• Uses “hardware simulation” to execute a circuit design
• Design a circuit using components: 
– gates, 
– “mega-functions” (e.g., ALU), 
– Intellectual property (IP)
– VHDL or Verilog hardware design language
• Available in a range of capacity, cost, and environment
• Very attractive in an educational environment: flexible, 
re-usable, low cost. 
MARS Overview
• MIPS Assembler and Runtime Simulator
• An IDE for MIPS assembly language programming
• Designed for use with Computer Organization and 
Design by Patterson & Hennessy
• First release in 2005.  Two releases per year.
• Extended to support FPGA
– Configurable memory model
– Export memory contents to text file
• JAR download www.cs.missouristate.edu/MARS


MARS features for FPGA support
MIPS circuit design alternatives
• Single-cycle
• Multi-cycle
• Pipelined 
Two different circuits necessary
• MIPS circuit and the VGA display of the MIPS state
• Issue of “MIPS clock speed” vs. “VGA clock speed”
• MIPS memory not implemented in the FPGA itself, 
inefficient use of FPGA hardware simulation 
resources
• Instead, MIPS memory is contained in a separate 
RAM on the FPGA board
• This involves separate “memory load” steps for the 
MIPS memory and the MIPS circuit
Computer Organization and Design, 3rd Edition, Figure 5-28. 
PC
IR
Registers
Block of 
memory
(Data as desired)
VGA
Display
Logic
32 bits
32 bits
32 * 32 bits
Blocksize 
* 32 bits
VGA clock
VGA sync
VGA Red, 
Green, Blue
30 bits
Usage in an architecture class
• Reinforce the concept of MIPS execution on various 
platforms:
– A genuine MIPS processor
– The MARS simulator of MIPS execution (running in Java on 
some other processor)
– FPGA simulation of a MIPS processor (running with 
variable clock speed)
• Use spec sheets and manufacturer’s data to estimate 
run times of different FPGA and MIPS implementations
• Add instructions to the MIPS implementation on FPGA
Acknowledgements
The FPGA project was supported by a SIGCSE 
Special Projects Grant
Questions?
