An undergraduate advanced computer design course using virtual-prototyping

This paper describes the Advanced Computer Design Course at the University of Virginia which teaches senior level Computer Engineering majors the art of computer system design using modem virtual prototyping techniques. The students develop an architecture to implement a small 8 bit microprocessor with 32 instructions and then actually implement it in real hardware using Field Programmable Gate Arrays (FPGAs).