Gran Trak 10 Style Racing Game

This project was designed and implemented during the Digital Logic and Computer Design course offered Fall 2018. Over the first half of the semester, I implemented a MIPS architecture computer using SystemVerilog and an FPGA. The microarchitecture for the computer was designed by the course instructor, while the HDL code was written by each student individually.

For the second half of the semester, I worked in parallel with another student to build a two-player racing game modeled after the Gran Trak 10 arcade game. Our vision was to connect our MIPS computers with a custom communication protocol so that they could share necessary game state (e.g., position and orientation of the race car), while also leveraging the built-in accelerometer to use the FPGAs as steering wheels to control the race car. We designed the graphics and functionality together, but individually wrote MIPS assembly programs to encode our game. The finished code was executed on the MIPS architecture computers that we had implemented on our FPGAs during the first half of the semester.

The image on the right half of the screen shows one of the FPGAs used for the project after it had been modified with custom hardware for inter-board communication. This device was held and rotated to control its associated race car while receiving information from the other FPGA about the state of the competing race car.