

# ECE 271, Final Project, Group 4

Michael Boly, Brenden Lowe, David Headrick

January 15, 2021

## Contents

|          |                                            |           |
|----------|--------------------------------------------|-----------|
| <b>1</b> | <b>Introduction</b>                        | <b>4</b>  |
| 1.1      | NES Controller . . . . .                   | 4         |
| 1.2      | PS/2 Keyboard . . . . .                    | 4         |
| <b>2</b> | <b>Top Level and Hardware Diagrams</b>     | <b>5</b>  |
| 2.1      | Project Top Level . . . . .                | 5         |
| 2.2      | NES Controller Top Level . . . . .         | 5         |
| 2.3      | NES Controller Hardware Diagram . . . . .  | 6         |
| 2.4      | PS/2 Keyboard Top Level . . . . .          | 7         |
| 2.5      | PS/2 Keyboard Hardware Diagram . . . . .   | 8         |
| 2.6      | VGA Driver Top Level . . . . .             | 8         |
| 2.7      | VGA Driver Hardware Diagram . . . . .      | 9         |
| 2.8      | Addressable RGB Driver Top Level . . . . . | 10        |
| 2.9      | Addressable RGB Hardware Diagram . . . . . | 11        |
| <b>3</b> | <b>FPGA Usage Levels</b>                   | <b>11</b> |
| 3.1      | NES Controller . . . . .                   | 11        |
| 3.2      | PS/2 Keyboard . . . . .                    | 12        |
| 3.3      | VGA Driver . . . . .                       | 12        |
| 3.4      | Seven Segemnt Driver . . . . .             | 13        |
| 3.5      | RGB Driver . . . . .                       | 14        |
| <b>4</b> | <b>HDL Modules</b>                         | <b>14</b> |
| 4.1      | NES Controller . . . . .                   | 14        |
| 4.1.1    | NES_Decoder . . . . .                      | 14        |
| 4.1.2    | counter (4-bit) . . . . .                  | 14        |
| 4.1.3    | latch_pulse . . . . .                      | 14        |
| 4.1.4    | clock_pulse . . . . .                      | 15        |
| 4.1.5    | get_controls . . . . .                     | 15        |
| 4.2      | PS/2 Keyboard . . . . .                    | 15        |
| 4.2.1    | ps2keyboard . . . . .                      | 15        |
| 4.2.2    | keyboard_input . . . . .                   | 15        |
| 4.2.3    | keybuffer . . . . .                        | 15        |
| 4.2.4    | ps2clock . . . . .                         | 15        |
| 4.2.5    | ps2controller . . . . .                    | 16        |
| 4.2.6    | flop . . . . .                             | 16        |
| 4.2.7    | shiftRegister . . . . .                    | 16        |
| 4.2.8    | idleCounter . . . . .                      | 16        |
| 4.2.9    | lessThan . . . . .                         | 16        |
| 4.3      | VGA Driver . . . . .                       | 17        |
| 4.3.1    | AddressConverter . . . . .                 | 17        |
| 4.3.2    | Comparator . . . . .                       | 17        |
| 4.3.3    | SpriteMux . . . . .                        | 17        |
| 4.3.4    | DisplayMux . . . . .                       | 17        |
| 4.3.5    | VGA_Display . . . . .                      | 17        |
| 4.3.6    | clockdiv . . . . .                         | 17        |

|          |                                      |           |
|----------|--------------------------------------|-----------|
| 4.3.7    | syncCounter . . . . .                | 18        |
| 4.4      | Seven Segment Driver . . . . .       | 18        |
| 4.4.1    | SevenSeg . . . . .                   | 18        |
| 4.5      | RGB Driver . . . . .                 | 18        |
| 4.5.1    | RGB_Driver . . . . .                 | 18        |
| 4.5.2    | counter . . . . .                    | 18        |
| 4.5.3    | comparator . . . . .                 | 18        |
| 4.5.4    | sync . . . . .                       | 18        |
| 4.5.5    | freq_div . . . . .                   | 19        |
| 4.5.6    | cont_to_color . . . . .              | 19        |
| 4.5.7    | trans_state . . . . .                | 19        |
| 4.5.8    | bit_state . . . . .                  | 19        |
| 4.5.9    | choose_bit . . . . .                 | 19        |
| 4.5.10   | transfer . . . . .                   | 19        |
| <b>5</b> | <b>ModelSim Testing</b>              | <b>19</b> |
| 5.1      | NES Controller . . . . .             | 20        |
| 5.1.1    | NES_Decoder . . . . .                | 20        |
| 5.1.2    | counter . . . . .                    | 20        |
| 5.1.3    | latch_pulse . . . . .                | 20        |
| 5.1.4    | clock_pulse . . . . .                | 21        |
| 5.1.5    | get_controls . . . . .               | 21        |
| 5.2      | PS/2 Keyboard . . . . .              | 21        |
| 5.2.1    | ps2keyboard Module . . . . .         | 21        |
| 5.2.2    | keyboard_input Module . . . . .      | 23        |
| 5.2.3    | ps2clock Module . . . . .            | 23        |
| 5.2.4    | ps2controller Module . . . . .       | 23        |
| 5.3      | VGA Driver . . . . .                 | 24        |
| 5.3.1    | VGA_Driver Module . . . . .          | 24        |
| 5.3.2    | VGA_Display Module . . . . .         | 24        |
| 5.3.3    | Clock Divider Module . . . . .       | 24        |
| 5.3.4    | Comparator Module . . . . .          | 25        |
| 5.3.5    | DisplayMux Module . . . . .          | 25        |
| 5.3.6    | SpriteMux Module . . . . .           | 25        |
| 5.3.7    | Address Converter Module . . . . .   | 25        |
| 5.3.8    | Synchronous Counter Module . . . . . | 26        |
| 5.4      | SevenSeg Module . . . . .            | 26        |
| 5.5      | RGB Driver . . . . .                 | 26        |
| 5.5.1    | RGB_Driver . . . . .                 | 26        |
| 5.5.2    | counter . . . . .                    | 27        |
| 5.5.3    | comparator . . . . .                 | 27        |
| 5.5.4    | sync . . . . .                       | 27        |
| 5.5.5    | freq_div . . . . .                   | 28        |
| 5.5.6    | cont_to_color . . . . .              | 28        |
| 5.5.7    | trans_state . . . . .                | 28        |
| 5.5.8    | bit_state . . . . .                  | 28        |
| 5.5.9    | choose_bit . . . . .                 | 29        |
| 5.5.10   | transfer . . . . .                   | 29        |
| <b>6</b> | <b>Hardware Testing</b>              | <b>30</b> |
| 6.0.1    | VGA_Driver Module . . . . .          | 30        |
| <b>A</b> | <b>SystemVerilog Files</b>           | <b>30</b> |
| A.1      | NES Decoder . . . . .                | 30        |
| A.1.1    | NES_Decoder . . . . .                | 30        |
| A.1.2    | counter . . . . .                    | 31        |
| A.1.3    | latch_pulse . . . . .                | 31        |
| A.1.4    | clock_pulse . . . . .                | 31        |
| A.1.5    | get_controls . . . . .               | 31        |

|            |                                               |           |
|------------|-----------------------------------------------|-----------|
| <b>A.2</b> | <b>PS/2 Driver . . . . .</b>                  | <b>32</b> |
| A.2.1      | ps2keyboard . . . . .                         | 32        |
| A.2.2      | ps2clock . . . . .                            | 33        |
| A.2.3      | ps2controller . . . . .                       | 33        |
| A.2.4      | keyboard_input . . . . .                      | 34        |
| A.2.5      | keybuffer . . . . .                           | 34        |
| A.2.6      | shiftRegister . . . . .                       | 35        |
| A.2.7      | lessThan . . . . .                            | 35        |
| A.2.8      | idleCounter . . . . .                         | 35        |
| A.2.9      | flop . . . . .                                | 36        |
| A.2.10     | sevenseg . . . . .                            | 36        |
| <b>A.3</b> | <b>VGA_Driver . . . . .</b>                   | <b>36</b> |
| A.3.1      | Comparator . . . . .                          | 36        |
| A.3.2      | SpriteMux . . . . .                           | 37        |
| A.3.3      | DisplayMux . . . . .                          | 37        |
| A.3.4      | AddressConverter . . . . .                    | 37        |
| A.3.5      | VGA_Display . . . . .                         | 38        |
| A.3.6      | syncCounter . . . . .                         | 38        |
| A.3.7      | clockdiv . . . . .                            | 39        |
| A.3.8      | VGA_Driver . . . . .                          | 39        |
| <b>A.4</b> | <b>Seven Segment Display Driver . . . . .</b> | <b>40</b> |
| A.4.1      | SevenSeg . . . . .                            | 40        |
| <b>A.5</b> | <b>RGB Driver . . . . .</b>                   | <b>41</b> |
| A.5.1      | RGB_Driver . . . . .                          | 41        |
| A.5.2      | counter . . . . .                             | 41        |
| A.5.3      | comparator . . . . .                          | 42        |
| A.5.4      | sync . . . . .                                | 42        |
| A.5.5      | freq_div . . . . .                            | 42        |
| A.5.6      | cont_to_color . . . . .                       | 43        |
| A.5.7      | trans_state . . . . .                         | 43        |
| A.5.8      | bit_state . . . . .                           | 44        |
| A.5.9      | choose_bit . . . . .                          | 44        |
| A.5.10     | transfer . . . . .                            | 45        |
| <b>B</b>   | <b>Simulation Files (Do scripts)</b>          | <b>45</b> |
| <b>B.1</b> | <b>NES Decoder . . . . .</b>                  | <b>45</b> |
| <b>B.2</b> | <b>PS/2 Keyboard . . . . .</b>                | <b>46</b> |
| <b>B.3</b> | <b>Seven Segment Driver . . . . .</b>         | <b>46</b> |
| <b>B.4</b> | <b>RGB Driver . . . . .</b>                   | <b>46</b> |

# 1 Introduction

For our final ECE 271 design project, we decided to use the NES controller and PS/2 Keyboard as inputs and the addressable RGB LEDs, VGA display, and DE10-Lite Seven Segment displays as output. More specifically, we will display different colors on the LEDs and sprites on the VGA that correspond to the buttons pressed on the NES controller. Similarly, we will display a letter or number on the DE10-Lite Seven Segment displays that correspond to the keys pressed on the PS/2 Keyboard. To complete this project, we used Quartus Prime for writing SystemVerilog and ModelSim for testing each module.

## 1.1 NES Controller

The NES controller was released along side the famous NES (Nintendo Entertainment System) in the year 1985 (US release). The primary purpose of the NES controller was to provide an interface for user inputs to the NES, allowing for users to interact with the video games they were playing. The NES features a directional pad, with buttons for up, down, left, and right, in addition to select, start, a, and b buttons. In this project, the NES controller was chosen as an input interface for both addressable RGBs and VGA outputs.



Figure 1: NES Controller.

## 1.2 PS/2 Keyboard

The PS/2 Keyboard was introduced in 1987 in order to enable user input to the PS/2 system. Although the PS/2 Keyboard is typically used with a mouse, we will only be using the keyboard key presses as input for our project. The PS/2 Keyboard can be used to interface with computers other than the PS2 System by way of an adapter.



Figure 2: PS/2 Keyboard.

## 2 Top Level and Hardware Diagrams

### 2.1 Project Top Level



Figure 3: Top level overview of the project design.

### 2.2 NES Controller Top Level



Figure 4: NES Controller Decoder Top Level Diagram.



Figure 5: Synthesized NES Decoder Top Level Diagram in Quartus Prime.

The previous two figures illustrate the top level diagram for the NES Controller decoder, which takes in a clock signal from DE10-Lite board, a reset signal from user input, and a data signal from the NES controller itself. The NES decoder has ten outputs. It has eight outputs to represent the buttons being pressed, which will be fed into the VGA and RGB drivers, and two outputs, nes\_clk and nes\_latch, which connect to the NES controller and signal to assist in the serial data transfer from the controller to the decoder.

### 2.3 NES Controller Hardware Diagram



Figure 6: Hardware connections from NES Controller to DE10-Lite.

## 2.4 PS/2 Keyboard Top Level



Figure 7: PS/2 Top Level Diagram.



Figure 8: Synthesized PS/2 Top Level Diagram in Quartus Prime.

The figure above illustrates the top level diagram for the PS/2 Keyboard which takes letters A-F and numbers 0-9 as inputs and begins by creating a key code representation to be passed into the ps2clock module. Once received by the clock module, the key code is outputted in 11 bits that are passed into a shift register in the controller module and shifted out one by one. Lastly, the code is sent to the Seven Segment display to represent the key that was pressed.

## 2.5 PS/2 Keyboard Hardware Diagram



Figure 9: Hardware connections from PS/2 Keyboard to DE10-Lite.

## 2.6 VGA Driver Top Level



Figure 10: VGA Top Level Diagram.

Figure 10 illustrates the top level diagram for the VGA driver. The RGB generator takes an 3 bit bus to choose which of 3 sprites to display to the screen. The correct RGB outputs are then



Figure 11: Synthesized VGA Top Level Diagram in Quartus Prime.

output to the VGA display module that synchronizes the RGB values with the VGA display count. The VGA display also generates a hsync and vsync signal for the connected display. Both modules are synchronized using a 50MHz clock.

## 2.7 VGA Driver Hardware Diagram



Figure 12: Hardware connections from VGA Driver to DE10-Lite.

## 2.8 Addressable RGB Driver Top Level



Figure 13: RGB Driver Top Level Diagram.



Figure 14: Synthesized RGB Driver Top Level Diagram in Quartus Prime.

The previous two figures illustrate the top level design of the RGB Driver. The RGB driver takes in a 50 MHz clock signal as input, along with a reset signal, and a controller signal. Notice that the controller signal only contains seven bits, as select is reserved for another purpose. The RGB driver has a single output, being dout. The reason for this is due to the fact that the addressable RGBs use a special serial data transfer, being different periods of high and low signals to represent a 1 and 0.

## 2.9 Addressable RGB Hardware Diagram



Figure 15: Hardware connections from DE10-Lite to Addressable RGB.

## 3 FPGA Usage Levels

### 3.1 NES Controller

The figure below shows the memory being used by the NES\_Decoder module on the top level on the MAX10 FPGA after synthesis.



Figure 16: NES Decoder module usage level on FPGA after synthesis.

### 3.2 PS/2 Keyboard

The figure below represents the memory used by the PS/2 Keyboard top level on the MAX10 FPGA after synthesis. The blue rectangles are the memory used by this module, which is less than 1 percent of its capacity. In fact, the total logic elements used by this module is only 116 out of the 49,760 available.



Figure 17: PS/2 Keyboard module usage level on FPGA after synthesis.

### 3.3 VGA Driver

The VGA Driver module used less than 1% of the available logic units on the MAX 10 chip. In total, 150 logic elements were used to represent the module.



Figure 18: VGA Driver module usage level on FPGA after synthesis. 150 / 49,760 Logic Elements ( $< 1 \%$ )

### 3.4 Seven Segemnt Driver



Figure 19: Seven Segment module usage level on FPGA after synthesis. 16 / 49,760 Logic Elements ( $< 1 \%$ )

### 3.5 RGB Driver



Figure 20: RGB Driver module usage level of FPGA after synthesis.

## 4 HDL Modules

### 4.1 NES Controller

#### 4.1.1 NES\_Decoder

**Description:** The NES\_Decoder module is the top level for the NES Decoder circuit. The NES\_Decoder is able to read in input from an NES controller, and output the appropriate data mapping, as well as outputs to assist in the serial data transfer process from controller to circuit.

**Inputs:** The NES\_Decoder module takes in three inputs. One input is a data signal from the NES controller that represents controller data. The other two inputs are a clock signal, and a user reset signal.

**Outputs:** The NES\_Decoder module has ten outputs. Eight of these outputs represent the current state of the buttons on the NES controller. The other two outputs connect directly to the NES controller. One is the NES latch signal, which signals the NES controller to load in current controller state, and the other being the NES clock signal, which facilitates serial data transfer between the controller and the module.

#### 4.1.2 counter (4-bit)

**Description:** The counter module is a basic four-bit implementation of a traditional counter module. The counter module is a sequential design that increments its output every clock cycle, and resets the output back to 0 when its reset input is asserted.

**Inputs:** The counter module takes in two inputs, being a clock signal, and a reset signal.

**Outputs:** The counter module has a single output, being the current count at a given time. The count signal is 4-bits, and can thus represent any number within that range.

#### 4.1.3 latch\_pulse

**Description:** The latch\_pulse module is responsible for pulsing the latch output to the NES controller at the appropriate time. This signals the NES controller to load its inputs into its shift register, and prepare for serial data transfer.

**Inputs:** The latch\_pulse module has one input, being a four bit signal that represents a current controller state during data transmission.

**Outputs:** The latch\_pulse module has a single output, being the latch signal.

#### 4.1.4 `clock_pulse`

**Description:** The `clock_pulse` module is responsible for pulsing and emulating a clock signal to the NES controller. The goal of this signal is to assist in serial data transfer between the NES controller and the NES controller Decoder module.

**Inputs:** The `clock_pulse` module takes in a single output, being a four bit signal that represent a current controller state during data transmission.

**Outputs:** The `clock_pulse` module has one output, being the NES clock signal.

#### 4.1.5 `get_controls`

**Description:** The `get_controls` module is responsible for reading in the serial data line, and outputting the appropriate controller button mapping. For each transmission on the serial data line, the module is able to determine the corresponding button press, and outputs this result.

**Inputs:** The `get_controls` module takes in three inputs. One input is a four bit signal that represents a current controller state during transmission. One input is the data input from the NES controller, that inputs the current end-of-shift-register value. The other input is a user reset signal.

**Outputs:** The `get_controls` module has an eight bit output, with each bit representing whether a corresponding button was pressed or not pressed.

## 4.2 PS/2 Keyboard

### 4.2.1 `ps2keyboard`

**Description:** The `ps2keyboard` module is the top level for the PS/2 Keyboard that combines all the sub-modules to process a key-press from the keyboard and send it to the seven segment display. This module is in charge of combining the `keyboard_input` with the `ps2clock` and `ps2controller` to form the top level.

**Inputs:** The `ps2keyboard` module takes the letters A-F and numbers 0-9 as input from the keyboard. Additionally, a clock, reset (active low), and enable signals are taken as inputs.

**Outputs:** The `ps2keyboard` module outputs an 8-bit keycode that can be interpreted and displayed by the seven segment displays.

### 4.2.2 `keyboard_input`

**Description:** The `keyboard_input` module simply maps every key-press A-F and 0-9 to its corresponding 8-bit keycode. This module is essentially behaving as a virtual keyboard by passing on the 8-bit keycode for each key press.

**Inputs:** The `keyboard_input` module takes in a signal for each letter A-F and number 0-9.

**Outputs:** The `keyboard_input` module returns an 8-bit hexadecimal code that matches the key press.

### 4.2.3 `keybuffer`

**Description:** The `keybuffer` module serves as an input buffer of 30 characters so that we can process multiple keys being pressed one at a time. This module saves the project from possible malfunction when multiple keys are pressed simultaneously.

**Inputs:** The `keybuffer` module takes in the 8-bit keycode from the `keyboard_input` module, a reset signal, and a signal that determines when to pass on the output keycode.

**Outputs:** The `keybuffer` module outputs the 8-bit keycode for one key press at a time.

### 4.2.4 `ps2clock`

**Description:** The `ps2clock` module is an emulation of a real PS/2 keyboard that outputs a clock and data signal. On every other clock count, the data signal will represent the next bit in the 12 bit series that begins with a 0 and is followed by each state of the 8-bit keycode, a parity value, and a 1 that represents the end of the series transmission.

**Inputs:** The ps2clock module takes an active low reset, an enable signal, and the 8-bit keycode from the keyboard\_input.

**Outputs:** The ps2clock module returns a clock and data signal that function like a PS/2 keyboard.

#### 4.2.5 ps2controller

**Description:** The ps2controller module manages the data output from ps2clock by storing every new bit in a shift register on the negative edge of the ps2clock's clock output. This module outputs the 8-bit PS/2 code as well as a flag called ps2\_code\_new for every time a new code is processed.

**Inputs:** The ps2controller module receives the system clock, active-low reset, enable signal, as well as the clock and data from the ps2clock module.

**Outputs:** The ps2controller module outputs the original 8-bit keycode from the keyboard\_input and a flag indicating the complete processing of a single keycode.

#### 4.2.6 flop

**Description:** The flop module is a simple D flip flop that serves as an N-bit register for outputting the keycode from the shift register in ps2controller. Additionally, the flop is used to pass on the flag signal that a new code has been received by the ps2controller.

**Inputs:** The flop module takes in a data signal of size N, a active-low reset, enable signal, and the system clock.

**Outputs:** The flop module outputs a bus that is size N. In this project, we use the flop module to take in 8 bits and 1 bit for the register and flag signal respectively.

#### 4.2.7 shiftRegister

**Description:** The shiftRegister module is tasked with shifting the data from ps2data to the left on bit at a time and filling the least significant bit with the next bit from ps2data. This procedure takes place on the negative edge of the ps2clock.

**Inputs:** The shiftRegister module is passed the ps2clock, active-low reset, enable, and ps2data as inputs.

**Outputs:** The shiftRegister module outputs the contents of the shift register in an N-bit size bus (state) and the most significant bit (q).

#### 4.2.8 idleCounter

**Description:** The idleCounter module is a very simple counter using the positive edge of the clock.

**Inputs:** The idleCounter module takes an active low reset and the system clock as inputs.

**Outputs:** The idleCounter module outputs a 12-bit bus that contains the number of system clock cycles elapsed.

#### 4.2.9 lessThan

**Description:** The lessThan module is a simple comparator that will return true if the input (d) is less than the parameter (a) and false otherwise.

**Inputs:** The lessThan module takes a bus of size N as input. In this project, we pass the current number of system clock cycles as the input to see if we have reached 21 cycles.

**Outputs:** The lessThan module outputs a 1 if the input is less than the parameter value and a 0 otherwise.

## 4.3 VGA Driver

### 4.3.1 AddressConverter

**Description:** The AddressConverter module converts the row and column number into an address. This address defines a pixel within the ROMs loaded with a bitmap image of a 16x16 down, left, and right arrow.

**Inputs:** The AddressConverter takes in the currently displayed row and column number as a 10 bit bus.

**Outputs:** The output is an 8 bit bus that describes the location of a 12 bit word in system ROM.

### 4.3.2 Comparator

**Description:** The comparator module compares the input value with a parameter to see whether the input is less than the parameter value.

**Inputs:** The comparator inputs the displayed row or column as a 10 bit bus. It also uses a parameter for the comparison.

**Outputs:** The comparator outputs a 1 bit value with the true or false value of the comparison.

### 4.3.3 SpriteMux

**Description:** The SpriteMux determines which sprite is displayed to the screen. It uses hot bit encoding to determine which sprite is displayed. In the event that the switch value is not valid, a green color is output.

**Inputs:** The SpriteMux takes in three 12 bit RGB values for the current pixel on either the right, left, or down sprites.

**Outputs:** The SpriteMux outputs a 12 bit bus for the correct pixel currently being shown.

### 4.3.4 DisplayMux

**Description:** The DisplayMux chooses whether to display the sprite or a constant background color. This creates a solid color background with a sprite in the top left hand corner.

**Inputs:** The DisplayMux takes in a constant 12 bit constant background RGB color, a sprites 12 bit current pixel color, and a AND'd switch value from two comparators. The comparators determine if the current pixel is in the top 16x16 left hand corner of the screen.

**Outputs:** The output is a 12 bit bus with the current pixels RGB value.

### 4.3.5 VGA\_Display

**Description:** The VGA\_Display module is a Top Level module for synchronizing the h\_sync, v\_sync, and RGB output with the current pixel and line count.

**Inputs:** The VGA\_Display takes in a 50MHz clock, a reset value, and a 12 bit bus for the current pixel.

**Outputs:** The VGA\_Display outputs two 10 bit bus values with the current row and column being displayed. It also outputs a 12 bit bus with the current RGB values. Lastly it outputs two different one bit lines for the h\_sync and v\_sync values.

### 4.3.6 clockdiv

**Description:** The clockdiv divides the clock value from 50MHz to 25MHz using 2 as the parameter. The 25MHz clock is the pixel clock used by the syncCounter.

**Inputs:** The clockdiv takes in a 50MHz clock and a reset value.

**Outputs:** The clockdiv outputs a 25MHz clock.

### 4.3.7 syncCounter

**Description:** The syncCounter module synchronizes when to display the RGB values and when to enable the h\_sync and v\_sync signals.

**Inputs:** The syncCounter takes in a 25MHz clock and a reset signal.

**Outputs:** The syncCounter outputs h\_sync and a v\_sync signal. It also outputs two signals, hdisplay and vdisplay, which determine whether the row and column are currently being displayed. Lastly, it outputs the current row and column values as a 12 bit bus.

## 4.4 Seven Segment Driver

### 4.4.1 SevenSeg

**Description:** The SevenSeg module converts a hexadecimal 8 bit bus signal into a signal to a seven segment display. The signal to the display is used to display a 0 - f on the display corresponding to the hexadecimal value of the 8 bit bus.

**Inputs:** The Seven Segment Display takes in an 8 bit bus as the single input.

**Outputs:** The output is a 7 bit bus. The code in the bus is used to display a value on the seven segment display.

## 4.5 RGB Driver

### 4.5.1 RGB\_Driver

**Description:** The RGB\_Driver module is the top-level design of the RGB Driver. This module takes in a controller signal, and then outputs a color to an addressable RGB.

**Inputs:** The RGB\_Driver module takes in three inputs. One is a 50 MHz clock signal, and another is a user reset signal. Additionally, the module takes in a seven bit controller signal, representing which buttons were pushed on a NES controller.

**Outputs:** The RGB\_Driver module has a single output, being dout. This signal sends data to an addressable RGB, following the specified protocols to encode 1's and 0's.

### 4.5.2 counter

**Description:** The counter module is a traditional take on a standard counter module. This module takes in a parameter to represent how many bits the counter should be. The counter increments its output every clock cycle.

**Inputs:** The counter module takes in two inputs, being a clock and reset signal.

**Outputs:** The counter module has a single output, which represents the count at a given time.

### 4.5.3 comparator

**Description:** The comparator module is a traditional take on a standard comparator module, only exception being that it only has an equality output. The comparator module determines whether two given numbers are equal. It also takes in a parameter to determine how many bits the inputs will be.

**Inputs:** The comparator module has two inputs, being the two numbers to be compared.

**Outputs:** The comparator module has one output, being the equality output, which is TRUE if the given inputs are equal.

### 4.5.4 sync

**Description:** The sync module is a traditional take on a standard sync module. The sync module outputs an input in sync with a given clock signal.

**Inputs:** The sync module has two inputs, being the data to be transmitted, and a clock signal.

**Outputs:** The sync module has a single output, being the data that was given as input.

#### 4.5.5 freq\_div

**Description:** The freq\_div module takes in a 50 MHz clock signal, and uses it to output a 1 MHz clock signal.

**Inputs:** The freq\_div module takes in two inputs, being a 50 MHz clock signal, and a user reset signal.

**Outputs:** The freq\_div module has a single output, being a 1 MHz clock signal.

#### 4.5.6 cont\_to\_color

**Description:** The cont\_to\_color module takes in a seven bit controller signal, and then maps it to a 24 bit color signal to be transmitted to an addressable RGB.

**Inputs:** The cont\_to\_color module takes in a single input, being a seven-bit controller signal.

**Outputs:** The cont\_to\_color module has a single output, being a 24-bit RGB color signal.

#### 4.5.7 trans\_state

**Description:** The trans\_state module keeps track of the current transmission time, in intervals of  $12\ \mu s$ . This is to help keep track of signal encoding in the addressable RGBs.

**Inputs:** The trans\_state module takes in two inputs, being a 1 MHz clock signal, and a user reset signal.

**Outputs:** The trans\_state module has a single four bit output, which represents the current transmission state.

#### 4.5.8 bit\_state

**Description:** The bit\_state module keeps track of which bit is to be transferred out of the 24-bit color signal. It also determines when a reset encoding should be sent to the addressable RGBs.

**Inputs:** The bit\_state module takes in two inputs, one being a 4 bit signal representing the current transmission state. The other input is a user reset signal.

**Outputs:** The bit\_state module has two outputs. One is a 5 bit signal that represents the current bit to be transferred. The other signal is a bit-reset signal, which indicates when a reset signal should be encoded to the addressable RGB.

#### 4.5.9 choose\_bit

**Description:** The choose\_bit module outputs the desired bit of the color signal to be transferred to the addressable RGB, given a bit state.

**Inputs:** The choose\_bit module has two inputs, being a 24 bit color signal, and a 5 bit signal representing which bit to transfer.

**Outputs:** The choose\_bit module has one output, which is the current bit in the color signal to be transmitted.

#### 4.5.10 transfer

**Description:** The transfer module transmits a time-specific encoding to the addressable RGBs, based on whether it's trying to encode a 1, 0, or reset signal.

**Inputs:** The transfer module has 3 inputs. One input is the current bit from the color signal to be encoded. The other is a 4 bit input representing the current transfer state. The last bit is a reset bit that represents when a reset signal should be encoded.

**Outputs:** The transfer module has a single output, being a data wire connected to the addressable RGB.

## 5 ModelSim Testing

Following the design and implementation of the individual modules of our project in Quartus Prime, we turned to ModelSim to verify that each module was functioning properly. The waves generated from the following tests in this section were performed in ModelSim and serve to replicate the data that would be received by our design if connected to hardware (the NES Controller or PS/2 Keyboard).

## 5.1 NES Controller

### 5.1.1 NES\_Decoder

Since the lower level modules were tested and simulated separately, the NES\_Decoder module was only tested to see if it accepted inputs and mapped to appropriate outputs at a specific time. Below, you can see the mapping of the a and b buttons to their corresponding outputs from the serial data transfer.



Figure 21: NES Decoder loading in a and b button inputs.

### 5.1.2 counter

The counter was tested by first asserting reset, and then asserting the clock signal to observe the behavior of the output. The goal was to observe the output increment every clock cycle. This behavior can be seen below:



Figure 22: counter increment its output every clock cycle.

### 5.1.3 latch\_pulse

The latch\_pulse module was tested for each possible input state. The behavior that was expected was that the latch signal would only be pulsed when the input state was 0, and would

remain 0 if the input state was any other value. This behavior can be observed below:



Figure 23: Latch signal pulses only once during state increment.

#### 5.1.4 `clock_pulse`

The `clock_pulse` module was tested for each possible input state. The behavior that was expected is that the clock signal would be pulsed on every even input state signal. This behavior can be observed below:



Figure 24: Clock signal pulses on every even input state.

#### 5.1.5 `get_controls`

The `get_controls` module was tested for its given input state, data, and reset signals. The behavior that was expected is that when reset was asserted, then the 8-bit output would be all zeros. When reset was not asserted, it was expected that buttons would update an individual bit with the data signal when state is an odd number. This behavior can be observed below:



Figure 25: Button outputs updates on every odd state signal.

## 5.2 PS/2 Keyboard

### 5.2.1 ps2keyboard Module

We tested the `ps2keyboard` module first by setting the A key to be pressed and verifying the state code matches the key press.



Figure 26: Testing single A key press.

Then we ran the same test for a single key press, but this time we set the B key to be pressed, and all the other keys not pressed.



Figure 27: Testing single B key press.

Both state keycodes generated matched what they should be for a single A key press (00011100) and a single B key press (00110010) respectively. The hexadecimal that represents each of these keycodes can be seen in the following figure, thus we know the proper keycodes are generated from the ps2keyboard module.

| Key | Make Code (hex) |
|-----|-----------------|
| A   | 1C              |
| B   | 32              |

Figure 28: Hexadecimal key codes for A and B key presses.

We also tested that number key presses were producing the correct keycodes by setting the 0 key to be pressed, then the 1 key, then the 2 key.



Figure 29: Testing key presses for 0, 1, and 2.

All three key presses resulted in the proper keycode being produced. The following figure shows the corresponding hexadecimal values for the keys 0, 1, and 2 being pressed.

|   |    |
|---|----|
| 0 | 45 |
| 1 | 16 |
| 2 | 1E |

Figure 30: Expected keycode result in hexadecimal for key presses for 0, 1, and 2.

### 5.2.2 keyboard\_input Module

Next we tested the keyboard\_input module to check that the input would be buffered properly if there were multiple key presses simultaneously. The following figure shows how when none of the keys are pressed, the default is the keycode for 0, and when all keys are pressed, the first one enters the buffer begins by processing the first one.



Figure 31: Test buffering for simultaneous key presses.

### 5.2.3 ps2clock Module

The ps2clock module was tested to see that it is keeping time properly based on the system clock. We can also see that the count, lt, and parity are functioning.



Figure 32: Testing ps2clock for time keeping.

#### 5.2.4 ps2controller Module

The ps2controller module was tested to verify that the shift register was properly storing and pushing through each bit of data into complete 8-bit PS/2 codes. We can also see that the ps2\_code\_new flag is properly raised every time a new code is processed.



Figure 33: Testing the shift register and processing of new codes.

## 5.3 VGA Driver

### 5.3.1 VGA\_Driver Module

We tested the VGA driver by forcing the 12 RGB sprite output as  $111111111111_2$ , and the background color as  $111100000000_2$ . We wanted to see if the correct RGB values were displayed at the correct time. Synthesized\_Wire\_4 is the forced sprite pixel value.



Figure 34: Testing the RGB value switching.

### 5.3.2 VGA\_Display Module

We tested the VGA\_Display module by seeing if the RGB outputs were the correct values at the correct times. We also saw if the Hdisplay, Vdisplay, H\_Sync and V\_Sync signals were correct.



Figure 35: Testing the RGB output and sync signals.

### 5.3.3 Clock Divider Module

We tested the Clock Divider module by simulating an input clock and observing the output clock. The output clock in the simulations checks out to be half as fast.



Figure 36: Testing the Clock Divider's timing

### 5.3.4 Comparator Module

We tested the Comparator by observing the altM wire's output depending on bus a's input. The Comparator tests to see if the input a's value is less than 16. The simulation checks out because altM is low when a is 16.



Figure 37: Testing the Comparator's output value

### 5.3.5 DisplayMux Module

We tested the DisplayMux in modelSim by forcing values for both d0 and d1. These are the RGB value inputs from either a sprite or a background color. The mux successfully switches the output RGB value upon toggling of the s value.



Figure 38: Testing the RGB output of the DisplayMux

### 5.3.6 SpriteMux Module

We tested the SpriteMux Module by forcing three different values for each sprite. Then we forced each possible hot-bit value, and a default value. The SpriteMux successfully toggles between each sprite input RGB value, and uses the background value when the hot bit input is invalid.



Figure 39: Testing the Sprite Mux module RGB output value.

### 5.3.7 Address Converter Module

We tested the Address Converter module by forcing values in the row and column input and observing the address output



Figure 40: Testing the Address Converter Module address value

### 5.3.8 Synchronous Counter Module

We tested the Synchronous Counter Module by observing the pixel count, line count, h\_sync, and v\_sync values to make sure they were within the correct values and timings needed to display to a VGA monitor.



Figure 41: Testing the SyncCounter timings.

### 5.4 SevenSeg Module

We tested the SevenSeg module by forcing every possible hexadecimal value 0-f. This was done using a modelsim DO script. The outputs for each hexadecimal value was observed.



Figure 42: Modelsim waves while testing output values for Seven Segment controller using do script.

### 5.5 RGB Driver

#### 5.5.1 RGB\_Driver

Because all of the lower level modules were separately tested and simulated. the top level was simulated to test whether correct encoding and timing were sent to the addressable RGB. The first figure below shows the correct encoding for sending a 0 bit, and the second figure shows the correct encoding for sending a 1 bit.



Figure 43: Correct timing and encoding for sending a 0 bit.



Figure 44: Correct timing and encoding for sending a 1 bit.

### 5.5.2 counter

The counter module was tested and simulated to observe whether the output incremented every clock cycle, and returns to 0 when reset is asserted. This behavior can be observed below:



Figure 45: Output increments every clock cycle.

### 5.5.3 comparator

The comparator module was tested and simulated to observe whether the output signal was pulsed if and only if the two inputs were equal. This behavior can be observed below:



Figure 46: Output only when both inputs are equal.

### 5.5.4 sync

The sync module was tested and simulated to observe that an input is synced to a given clock signal, and sent in sync with the clock cycle. This behavior can be observed below:



Figure 47: Input is passed to output in sync with clock.

### 5.5.5 freq\_div

The freq\_div module was tested and simulated to observe that if given an input clock cycle, whether it pulses its clock output when its internal counter reaches 50. This behavior can be observed below:



Figure 48: Output line is only pulsed when internal counter reaches 50.

### 5.5.6 cont\_to\_color

The cont\_to\_color module was tested for every possible controller input case. The expected behavior was that each controller input would have a unique corresponding color output. This behavior can be observed below:



Figure 49: Each controller input has a unique color output.

### 5.5.7 trans\_state

The trans\_state module was tested to assert that the state was incremented every clock cycle, and that it reset when it reached 12. This behavior can be seen below:



Figure 50: Output is continuously incremented every clock cycle until it reaches 12.

### 5.5.8 bit\_state

The bit\_state module was tested to assert that when the input state reaches 12, a inc signal is pulsed, which then increments the current bit state output. This behavior can be seen below:



Figure 51: Bit state increments every time the input state reaches 12 and pulses the inc signal.

### 5.5.9 choose\_bit

The choose\_bit module was tested and simulated to assert that the appropriate bit from a color signal is sent, given a bit state. The behavior can be seen below:



Figure 52: Appropriate bit from color signal is chosen based off of bit state signal to be sent to output.

### 5.5.10 transfer

The transfer module was tested and simulated to assert that given a data signal, it sent the correct signal encoding and timing to the output (which connects to the addressable RGB LEDs). The expected behavior for a data of 1 and a data of 0 can be seen below:



Figure 53: Expected signal encoding and timing given a data of 1.



Figure 54: Expected signal encoding and timing given a data of 0.

## 6 Hardware Testing

### 6.0.1 VGA\_Driver Module

The VGA Driver was tested on a VGA monitor. During this test, the input from the NES Controller module was emulated with three switches on the FPGA. A video demonstrating the VGA Driver working on hardware is available at: [https://youtu.be/LUShy7jyn\\_Q](https://youtu.be/LUShy7jyn_Q).



Figure 55: Right arrow sprite being shown during hardware testing.

## A SystemVerilog Files

### A.1 NES Decoder

#### A.1.1 NES\_Decoder

```
1 //////////////////////////////////////////////////////////////////
2 // Company:          Oregon State University
3 // Engineer:         Brenden Lowe
4 //
5 // Create Date:     06/01/20
6 // Design Name:    NES Decoder
7 // Module Name:    NES_Decoder
8 // Project Name:   ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description:   Top level module for NES Decoder. Identifies current controller
11 //                  state.
12 //
13 // Dependencies:
14 //
15 // Revision:
16 // Revision 0.01 - File Created
17 // additional Comments:
18 //
19 //////////////////////////////////////////////////////////////////
20
21 module NES_Decoder(input logic data, clk, reset,
22                      output logic nes_clk, nes_latch, a, b, select, start, up, down, left, right);
23   // Define a counter to assist in keeping track of current clock state
24   logic [3:0] count;
25
26   counter clk_state(clk, reset, count);
27   // Feed count into latch pulser
28   latch_pulser(count, nes_latch);
29   // Feed count into clock pulser
```

```

30     clock_pulse clk_pulser(count, nes_clk);
31     // Feed count into controller reader
32     get_controls control_read(count, data, reset, {a, b, select, start, up, down, left, right});
33
34 endmodule

```

### A.1.2 counter

```

1 //////////////////////////////////////////////////////////////////
2 // Company:          Oregon State University
3 // Engineer:         Brenden Lowe
4 //
5 // Create Date:    06/01/20
6 // Design Name:   NES Decoder
7 // Module Name:   counter
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description:  Increments output every clock cycle.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19
20 module counter(input logic clk, reset,
21                 output logic [3:0] q);
22
23     always_ff@(posedge clk)
24         if(reset) q <= 0;
25         else q <= q+1;
26
27 endmodule

```

### A.1.3 latch\_pulse

```

1 //////////////////////////////////////////////////////////////////
2 // Company:          Oregon State University
3 // Engineer:         Brenden Lowe
4 //
5 // Create Date:    06/01/20
6 // Design Name:   NES Decoder
7 // Module Name:   latch_pulse
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description:  Pulses the NES latch line to signal inputs to be loaded.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19
20 module latch_pulse(input logic [3:0] count,
21                     output logic latch);
22
23     always_comb
24         if(count == 0) latch = 1;
25         else latch = 0;
26
27 endmodule

```

### A.1.4 clock\_pulse

```

1 //////////////////////////////////////////////////////////////////
2 // Company:          Oregon State University
3 // Engineer:         Brenden Lowe
4 //
5 // Create Date:    06/01/20
6 // Design Name:   NES Decoder
7 // Module Name:   clock_pulse
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description:  Pulses the NES clock line to signal inputs to be transferred.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19
20 // Define module to pulse clock signals to NES controller
21 module clock_pulse(input logic [3:0] count,
22                     output logic nes_clk);
23
24     always_comb
25         case(count)
26             2: nes_clk = 1;
27             4: nes_clk = 1;
28             6: nes_clk = 1;
29             8: nes_clk = 1;
30             10: nes_clk = 1;
31             12: nes_clk = 1;
32             14: nes_clk = 1;
33             default: nes_clk = 0;
34
35 endmodule

```

### A.1.5 get\_controls

```

1 //////////////////////////////////////////////////////////////////
2 // Company: Oregon State University
3 // Engineer: Brenden Lowe
4 //
5 // Create Date: 06/01/20
6 // Design Name: NES Decoder
7 // Module Name: get_controls
8 // Project Name: ECE-271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description: Receives info from NES data line, and maps to corresponding
11 // output.
12 //
13 // Dependencies:
14 //
15 // Revision:
16 // Revision 0.01 - File Created
17 // additional Comments:
18 //
19 //////////////////////////////////////////////////////////////////
20
21 module get_controls(input logic [3:0] count,
22                      input logic data, reset,
23                      output logic [7:0] buttons);
24
25     always_ff@(posedge count[0])
26         if(reset) buttons <= 0;
27         else case(count)
28             1: buttons[7] <= data;
29             3: buttons[6] <= data;
30             5: buttons[5] <= data;
31             7: buttons[4] <= data;
32             9: buttons[3] <= data;
33             11: buttons[2] <= data;
34             13: buttons[1] <= data;
35             15: buttons[0] <= data;
36             default: buttons = buttons;
37         endcase
38
39 endmodule

```

## A.2 PS/2 Driver

### A.2.1 ps2keyboard

```

1 //////////////////////////////////////////////////////////////////
2 //Engineers : Michael Boly
3 //
4 //Create Date: 05/28/2020
5 //Design Name: PS2Keyboard
6 //Module Name: ps2keyboard
7 //Project Name: ECE 271 Final Project
8 //Target Devices : Max10 FPGA
9 //Description : This module simulates the function of an PS2 Keyboard.
10 //
11 //Dependencies :
12 //Revision : Revision 0.01 File Created
13 //additional Comments:
14 //
15 //////////////////////////////////////////////////////////////////
16 module ps2keyboard (input logic clk_10, reset_b, enable_switch,
17                      input logic A, B, C, D, E, F, zero, one, two, three,
18                      , four, five, six, seven, eight, nine,
19                      output logic [6:0] seg0);
20
21     logic [7:0] decode_bus;
22     logic [7:0] state;
23     logic ps2_new_wire;
24     logic ps2_data_wire;
25     logic ps2_clock_wire ;
26
27     /**************************************************************************
28     takes keyboard inputs A to Z, 0 to 9 and
29     outputs an 8 digit hexadecimal key
30     *****/
31     keyboard_input ps2_keyboardinput (
32         .A(A),
33         .B(B),
34         .C(C),
35         .D(D),
36         .E(E),
37         .F(F),
38         .zero(zero),
39         .one(one),
40         .two(two),
41         .three(three),
42         .four(four),
43         .five(five),
44         .six(six),
45         .seven(seven),
46         .eight(eight),
47         .nine(nine),
48         .q(state)
49     );
50
51     /**************************************************************************
52     takes outputs of keyboardClock and
53     determines the code that was
54     initially created by ps2_keyboardinput
55     *****/
56     ps2controller controller (
57         .clock(clk_10),
58         .reset_n(reset_b),
59         .enable(enable_switch),
60         .ps2_clock(ps2_clock_wire),
61         .ps2_data(ps2_data_wire),
62         .ps2_code_new(ps2_new_wire),
63         .ps2_code(decode_bus)
64     );
65
66     /**************************************************************************
67     takes the code outputted by
68     ps2_keyboardinput and sends the
69     coded message to a host

```

```

69 ****
70 ps2clock keyboardClock (
71     .clock (clk_10),
72     .state (state),
73     .enable (enable_switch),
74     .reset_n (reset_b),
75     .ps2_clock (ps2_clock_wire),
76     .ps2_data (ps2_data_wire)
77 );
78 ****
79 Displays the code created by
80 ps2_keyboardinput
81 ****
82 ****
83 sevenseg display0 (
84     .data (decode_bus [7:0]),
85     .segments (seg0)
86 );
87 ****
88 ****
89 endmodule

```

### A.2.2 ps2clock

```

1 //////////////////////////////////////////////////////////////////
2 //Engineers : Michael Boly
3 //
4 //Create Date: 05/28/2020
5 //Design Name: PS2Keyboard
6 //Module Name: ps2clock
7 //Project Name: ECE 271 Final Project
8 //Target Devices : Max10 FPGA
9 //Description : This module outputs the cooresponding keycode for a key press.
10 //
11 //Dependencies :
12 //Revision : Revision 0.01 File Created
13 //additional Comments:
14 //
15 //////////////////////////////////////////////////////////////////
16 module ps2clock ( input logic clock ,
17                     input logic [7:0] state ,
18                     input logic enable ,
19                     input logic reset_n ,
20                     output logic ps2_clock ,
21                     output logic ps2_data );
22
23     logic [4:0] count;
24     logic lt;
25     logic parity;
26
27     assign ps2_clock = count [0];
28     assign parity = !(( state [7] + state [6] + state [5] + state [4] + state [3] + state [2] +
29                         state [1] + state [0]) % 2);
30
31     always_ff@ (posedge clock , negedge reset_n)
32     begin
33         if (!reset_n) count <= 0;
34         else if (enable) count <= count;
35
36         case (count)
37             0: ps2_data = 0;
38             2: ps2_data = state [7];
39             4: ps2_data = state [6];
40             6: ps2_data = state [5];
41             8: ps2_data = state [4];
42             10: ps2_data = state [3];
43             12: ps2_data = state [2];
44             14: ps2_data = state [1];
45             16: ps2_data = state [0];
46             18: ps2_data = parity;
47             20: ps2_data = 1;
48             21: ps2_data = 1;
49             default ps2_data = ps2_data;
50
51         if (~count == 21) //Using ~ to prevent user heirarchy error
52             count <= 0;
53         else
54             count <= count + 5'b1;
55
56     end
57 endmodule

```

### A.2.3 ps2controller

```

1 //////////////////////////////////////////////////////////////////
2 //Engineers : Michael Boly
3 //
4 //Create Date: 05/28/2020
5 //Design Name: PS2Keyboard
6 //Module Name: ps2controller
7 //Project Name: ECE 271 Final Project
8 //Target Devices : Max10 FPGA
9 //Description : This module stores the outputs of ps2clock in a shift register.
10 //
11 //Dependencies :
12 //Revision : Revision 0.01 File Created
13 //additional Comments:
14 //
15 //////////////////////////////////////////////////////////////////
16 module ps2controller (input logic clock ,
17                         input logic reset_n ,
18                         input logic enable ,
19                         input logic ps2_clock ,
20                         input logic ps2_data ,
21                         output logic ps2_code_new ,
22                         output logic [7:0] ps2_code );
23
24     logic [10:0] ps2_register;
25     logic ps2_clock_int;
26     logic ps2_data_int;
27     logic [11:0] count_idle;

```

```

28     logic count_check;
29
30     shiftRegister #(N(11)) shiftReg(
31         .clk (ps2_clock),
32         .reset (reset_n),
33         .d (ps2_data),
34         .state (ps2_register) //shiftRegister "register" input not assigned but "state" output
35             is
36     );
37
38     flop ps2code(
39         .clk (clock),
40         .reset (reset_n),
41         .enable (count_check),
42         .d (ps2_register [8:1]),
43         .q (ps2_code)
44     );
45
46     flop #(N(1)) newps2Code(
47         .clk (clock),
48         .reset (reset_n),
49         .enable (0),
50         .d (!count_check),
51         .q (ps2_code_new)
52     );
53
54     idleCounter idleCount (
55         .clk (clock),
56         .rst (count_check),
57         .count (count_idle)
58     );
59
60     lessThan #(N(12), N(21)) count21(
61         .d (count_idle),
62         .q (count_check)
63     );
64 endmodule

```

#### A.2.4 keyboard\_input

```

1 //////////////////////////////////////////////////////////////////
2 //Engineers : Michael Boly
3 //
4 //Create Date: 05/28/2020
5 //Design Name: PS2Keyboard
6 //Module Name: keyboard_input
7 //Project Name: ECE 271-Final Project
8 //Target Devices : Max10 FPGA
9 //Description : This module defines the output 8-bit hex for any key press.
10 //
11 //Dependencies :
12 //Revision : Revision 0.01 File Created
13 //additional Comments:
14 //
15 //////////////////////////////////////////////////////////////////
16 module keyboard_input(input logic A, B, C, D, E, F, zero, one, two, three, four, five, six, seven, eight,
17   , nine,
18   , output logic [7:0] q);
19
20   always_comb
21   begin
22     if (A) q = 8'h1C;
23     else if (B) q = 8'h32;
24     else if (C) q = 8'h21;
25     else if (D) q = 8'h23;
26     else if (E) q = 8'h24;
27     else if (F) q = 8'h2B;
28     else if (zero) q = 8'h45;
29     else if (one) q = 8'h16;
30     else if (two) q = 8'h1E;
31     else if (three) q = 8'h26;
32     else if (four) q = 8'h25;
33     else if (five) q = 8'h2E;
34     else if (six) q = 8'h36;
35     else if (seven) q = 8'h3D;
36     else if (eight) q = 8'h3E;
37     else if (nine) q = 8'h46;
38   end
39 endmodule

```

#### A.2.5 keybuffer

```

1 //////////////////////////////////////////////////////////////////
2 //Engineers : Michael Boly
3 //
4 //Create Date: 05/28/2020
5 //Design Name: PS2Keyboard
6 //Module Name: keybuffer
7 //Project Name: ECE 271 Final Project
8 //Target Devices : Max10 FPGA
9 //Description : This module is an input buffer to handle simultaneous key presses.
10 //
11 //Dependencies :
12 //Revision : Revision 0.01 File Created
13 //additional Comments:
14 //
15 //////////////////////////////////////////////////////////////////
16 module keybuffer(input logic [7:0] input_keycode,
17   , input logic pass_input,
18   , input logic reset,
19   , output logic [7:0] output_keycode
20 );
21
22   //Register to store up to 30 characters in the buffer.
23   logic [239:0] keystore = 0;
24   //Count that counts how many characters are in the buffer
25   logic [4:0] charCounter = 0;
26
27   always_comb
28   begin

```

```

29          //Reset logic low
30          if( reset == 0)
31          begin
32              charCounter = 0;
33              keystore = 0;
34          end
35          else
36          //The buffer cannot get input and send input at the same time
37          if(input_keycode != 0 && charCounter < 5'd30)
38          begin
39              keystore[(5'd8 * charCounter) +: 5'd8] = input_keycode;
40              charCounter = charCounter + 5'b00001;
41          end
42
43
44          if(pass_input && charCounter != 0)
45          begin
46              output_keycode = keystore[7:0];
47              keystore[7:0] = 0;
48              keystore = keystore >>> 8;
49              charCounter = charCounter - 5'b00001;
50          end
51      end
52  end
53 endmodule

```

### A.2.6 shiftRegister

```

1 //////////////////////////////////////////////////////////////////
2 // Engineers : Michael Boly
3 //
4 // Create Date: 05/28/2020
5 // Design Name: PS2Keyboard
6 // Module Name: shiftRegister
7 // Project Name: ECE 271 Final Project
8 // Target Devices : Max10 FPGA
9 // Description : This module shifts the data coming from ps2clock module.
10 //
11 // Dependencies :
12 // Revision : Revision 0.01 File Created
13 // additional Comments:
14 //
15 //////////////////////////////////////////////////////////////////
16 module shiftRegister #(parameter N=7)(input logic clk, enable, input logic reset, input logic d, output
17   logic q, output logic [N-1:0] state);
18
19   logic [N-1:0] count;
20
21   always_ff@(posedge clk, posedge reset)
22   begin
23     if (!reset) count <= 0;
24     else count <= count << 1;
25     count [0] <= d;
26   end
27
28   assign q = count [N-1];
29   assign state = count;
endmodule

```

### A.2.7 lessThan

```

1 //////////////////////////////////////////////////////////////////
2 // Engineers : Michael Boly
3 //
4 // Create Date: 05/28/2020
5 // Design Name: PS2Keyboard
6 // Module Name: lessThan
7 // Project Name: ECE 271 Final Project
8 // Target Devices : Max10 FPGA
9 // Description : This module is a comparator that performs the less than comparison.
10 //
11 // Dependencies :
12 // Revision : Revision 0.01 File Created
13 // additional Comments:
14 //
15 //////////////////////////////////////////////////////////////////
16 module lessThan #(parameter a=10, parameter N=5) ( input logic [N-1:0] d,
17
18   always_comb
19   begin
20     if(d < a) q = 1;
21     else q = 0;
22   end
23
24 endmodule

```

### A.2.8 idleCounter

```

1 //////////////////////////////////////////////////////////////////
2 // Engineers : Michael Boly
3 //
4 // Create Date: 05/28/2020
5 // Design Name: PS2Keyboard
6 // Module Name: idleCounter
7 // Project Name: ECE 271 Final Project
8 // Target Devices : Max10 FPGA
9 // Description : This module is a simple counter with an active low reset.
10 //
11 // Dependencies :
12 // Revision : Revision 0.01 File Created

```

```

13 //additional Comments:
14 /**
15 ///////////////////////////////////////////////////////////////////
16 module idleCounter (input logic clk,
17                           input logic rst,
18                           output logic [11:0] count);
19
20     always_ff@(posedge clk)
21     begin
22         if (!rst) count <= 0;
23         else count <= count + 1;
24     end
25
26 endmodule

```

### A.2.9 flop

```

1 ///////////////////////////////////////////////////////////////////
2 //Engineers : Michael Boly
3 //
4 //Create Date: 05/28/2020
5 //Design Name: PS2Keyboard
6 //Module Name: flop
7 //Project Name: ECE 271 Final Project
8 //Target Devices : Max10 FPGA
9 //Description : This module is a register that stores N bits.
10 //
11 //Dependencies :
12 //Revision : Revision 0.01 File Created
13 //additional Comments:
14 //
15 ///////////////////////////////////////////////////////////////////
16 module flop #(parameter N=8)(input logic clk,
17                           input logic reset,
18                           input logic enable,
19                           input logic [N-1:0]d,
20                           output logic [N-1:0]q);
21
22 always_ff@(posedge clk, negedge reset)
23 begin
24     if (!reset) q <= 8'b0;
25     else if (enable) q <= d;
26     else q <= d;
27 end
28
29 endmodule

```

### A.2.10 sevenseg

```

1 ///////////////////////////////////////////////////////////////////
2 //Engineers : Michael Boly
3 //
4 //Create Date: 05/28/2020
5 //Design Name: PS2Keyboard
6 //Module Name: sevenseg
7 //Project Name: ECE 271 Final Project
8 //Target Devices : Max10 FPGA
9 //Description : This module will display the state on the FPGA display.
10 //
11 //Dependencies :
12 //Revision : Revision 0.01 File Created
13 //additional Comments:
14 //
15 ///////////////////////////////////////////////////////////////////
16 module sevenseg(input logic [7:0] data,
17                           output logic [6:0] segments);
18
19 always_comb
20     case(data)
21         8'b01000101: segments = 7'b100_0000; //0
22         8'b00010110: segments = 7'b111_1001; //1
23         8'b00011110: segments = 7'b010_0100; //2
24         8'b00100110: segments = 7'b011_0000; //3
25         8'b00100101: segments = 7'b001_1001; //4
26         8'b00101110: segments = 7'b001_0010; //5
27         8'b00111010: segments = 7'b000_0010; //6
28         8'b00111101: segments = 7'b111_1000; //7
29         8'b00111110: segments = 7'b000_0000; //8
30         8'b01000110: segments = 7'b001_1000; //9
31         8'b00011100: segments = 7'b000_1000; //A
32         8'b00110010: segments = 7'b110_0000; //B
33         8'b00100001: segments = 7'b011_0001; //C
34         8'b00100011: segments = 7'b100_0010; //D
35         8'b00100100: segments = 7'b011_0000; //E
36         8'b00101011: segments = 7'b011_1000; //F
37
38     default: segments = 7'b111_1111;
39 endcase
40
41 endmodule

```

## A.3 VGA\_Driver

### A.3.1 Comparator

```

1 ///////////////////////////////////////////////////////////////////
2 // Engineer:      David Headrick
3 //
4 // Create Date:   05/29/2020
5 // Design Name:   VGA_Driver
6 // Module Name:   Comparator
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Compares to see if the current pixel is less than the parameter
10 //
11 // Dependencies:
12 //
13 // Revision:
14 // Revision 0.01 - File Created

```

```

15 // additional Comments:
16 //
17 ///////////////////////////////////////////////////////////////////
18 module Comparator #(parameter M = 10)
19     (input logic [9:0] a,
20      output logic altM);
21
22
23     always_comb
24     altM = a < M;
25
26
27 endmodule

```

### A.3.2 SpriteMux

```

1 ///////////////////////////////////////////////////////////////////
2 // Engineer:        David Headrick
3 //
4 // Create Date:    05/29/2020
5 // Design Name:   VGA_Driver
6 // Module Name:   VGA_Display
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Chooses which sprite to display based off of the 3 bit switch value.
10 //                  Uses hot bit encoding.
11 //
12 // Dependencies: clockdiv.sv, syncCounter.sv
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 ///////////////////////////////////////////////////////////////////
19 module SpriteMux  (input logic [11:0] right,
20                     input logic [11:0] down,
21                     input logic [11:0] left,
22                     input logic [2:0] s,
23                     output logic [11:0] q);
24
25     always_comb
26     begin
27         case(s)
28             3'b100 : q = left;
29             3'b010 : q = right;
30             3'b001 : q = down;
31             default : q = 12'b000011110000;
32         endcase
33     end
34
35
36 endmodule

```

### A.3.3 DisplayMux

```

1 ///////////////////////////////////////////////////////////////////
2 // Engineer:        David Headrick
3 //
4 // Create Date:    05/29/2020
5 // Design Name:   VGA_Driver
6 // Module Name:   DisplayMux
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Chooses to display the background or the sprite
10 //
11 // Dependencies:
12 //
13 // Revision:
14 // Revision 0.01 - File Created
15 // additional Comments:
16 //
17 ///////////////////////////////////////////////////////////////////
18 module DisplayMux (input logic [11:0] d0,
19                     input logic [11:0] d1,
20                     input logic s,
21                     output logic [11:0] q);
22
23     assign q = s ? d0 : d1;
24
25 endmodule

```

### A.3.4 AddressConverter

```

1 ///////////////////////////////////////////////////////////////////
2 // Engineer:        David Headrick
3 //
4 // Create Date:    05/29/2020
5 // Design Name:   VGA_Driver
6 // Module Name:   AddressConverter
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Converts the current pixel location to a address for sprite in ROM
10 //
11 // Dependencies:
12 //
13 // Revision:
14 // Revision 0.01 - File Created
15 // additional Comments:
16 //
17 ///////////////////////////////////////////////////////////////////
18 module AddressConverter #(parameter ROWVALUE = 16)
19     (input logic [9:0] row,
20      input logic [9:0] column,
21      output logic [7:0] address);
22
23     assign address = row * ROWVALUE + column;
24
25 endmodule

```

### A.3.5 VGA\_Display

```

1 //////////////////////////////////////////////////////////////////
2 // Engineer:      David Headrick
3 //
4 // Create Date:   05/29/2020
5 // Design Name:   VGA_Driver
6 // Module Name:   VGA_Display
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Toplevel for synchronizing VGA output
10 //
11 // Dependencies: clockdiv.sv, syncCounter.sv
12 //
13 // Revision:
14 // Revision 0.01 - File Created
15 // additional Comments:
16 //
17 //////////////////////////////////////////////////////////////////
18 module VGA_Display    (input logic clock_50MHz,
19                         input logic reset_n,
20                         input logic [11:0] Pixel_Colors_RGB,
21                         output logic [9:0] displayed_row,
22                         output logic [9:0] displayed_column,
23                         output logic [11:0] RGB_Outputs,
24                         output logic h_sync,
25                         output logic v_sync);
26     wire clock_25MHz;
27     logic Hdisplay;
28     logic Vdisplay;
29     logic [11:0] RGB_Temp = 12'b111100000000;
30     wire hsyncwire;
31     wire vsyncwire;
32
33
34     clockdiv #(2) clockmod (clock_50MHz, reset_n, clock_25MHz);
35     syncCounter sc (clock_25MHz, reset_n, hsyncwire, vsyncwire, Hdisplay, Vdisplay, displayed_row,
36                     displayed_column);
37
38     assign h_sync = hsyncwire;
39     assign v_sync = vsyncwire;
40
41     assign RGB_Outputs = (Hdisplay == 1 && Vdisplay == 1) ? Pixel_Colors_RGB : 0;
42
43 endmodule

```

### A.3.6 syncCounter

```

1 //////////////////////////////////////////////////////////////////
2 // Engineer:      David Headrick
3 //
4 // Create Date:   05/29/2020
5 // Design Name:   VGA_Driver
6 // Module Name:   syncCounter
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Generates VGA signals from 25MHz clock
10 //
11 // Dependencies:
12 //
13 // Revision:
14 // Revision 0.01 - File Created
15 // additional Comments:
16 //
17 //////////////////////////////////////////////////////////////////
18 module syncCounter    (input wire clock_25MHz,
19                         input logic reset,
20                         output logic Hsync,
21                         output logic Vsync,
22                         output logic Hdisplay,
23                         output logic Vdisplay,
24                         output logic [9:0] displayed_row,
25                         output logic [9:0] displayed_column);
26
27 reg [9:0] pixel_count; //max count 800
28 reg [9:0] line_count; //max count 525
29
30 always_ff @(posedge clock_25MHz, posedge reset)
31 begin
32
33     if (reset)
34     begin
35         pixel_count <= 0;
36         line_count <= 0;
37     end
38     else if (pixel_count >= 799)
39     begin
40         pixel_count <= 0;
41         line_count <= line_count + 1;
42     end
43     else
44     begin
45         pixel_count <= pixel_count + 1;
46         if (line_count > 525)
47             line_count <= 0;
48     end
49
50 end
51
52 always_comb
53 begin
54
55     Hsync = ~((pixel_count >= 0) && (pixel_count <= 96));
56
57     Vsync = ~(line_count > 0 && line_count <= 2);
58
59     if ((pixel_count > 144) && (pixel_count <= 784))
60     begin
61         Hdisplay = 1;
62         displayed_row = pixel_count - 144;
63     end
64     else

```

```

65         begin
66             Hdisplay = 0;
67             displayed_row = 0;
68         end
69
70     if ((line_count > 35) && (line_count <= 515))
71     begin
72         Vdisplay = 1;
73         displayed_column = line_count - 35;
74     end
75     else
76     begin
77         Vdisplay = 0;
78         displayed_column = 0;
79     end
80
81 end
82
83 endmodule

```

### A.3.7 clockdiv

```

1 //////////////////////////////////////////////////////////////////
2 // Engineer:      David Headrick
3 //
4 // Create Date:   05/29/2020
5 // Design Name:   VGA_Driver
6 // Module Name:   clockdiv
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Divides the clock by the parameter value
10 //
11 // Dependencies:
12 //
13 // Revision:
14 // Revision 0.01 - File Created
15 // additional Comments:
16 //
17 //////////////////////////////////////////////////////////////////
18 module clockdiv #(parameter D = 2)
19     (input logic clk,
20      input logic reset,
21      output logic c_out);
22
23 reg [28:0] count;
24
25 always @(posedge clk, posedge reset)
26 begin
27     if (reset) count <= 1;
28     else if (count >= D) count <= 1;
29     else count <= count + 1;
30 end
31
32 assign c_out = (count > (D/2)) ?1:0;
33
endmodule

```

### A.3.8 VGA\_Driver

```

1 //////////////////////////////////////////////////////////////////
2 // Engineer:      David Headrick
3 //
4 // Create Date:   05/29/2020
5 // Design Name:   VGA_Display
6 // Module Name:   VGA_Display
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Toplevel for driving a VGA signal
10 //
11 // Dependencies: AddressConverter.sv, SpriteMux.sv, Comparator.sv, DisplayMux.sv, VGA_Display.sv
12 //
13 // Revision:
14 // Revision 0.01 - File Created
15 // additional Comments:
16 //
17 //////////////////////////////////////////////////////////////////
18 // Copyright (C) 2019 Intel Corporation. All rights reserved.
19 // Your use of Intel Corporation's design tools, logic functions
20 // and other software and tools, and any partner logic
21 // functions, and any output files from any of the foregoing
22 // (including device programming or simulation files), and any
23 // associated documentation or information are expressly subject
24 // to the terms and conditions of the Intel Program License
25 // Subscription Agreement, the Intel Quartus Prime License Agreement,
26 // the Intel FPGA IP License Agreement, or other applicable license
27 // agreement, including, without limitation, that your use is for
28 // the sole purpose of programming logic devices manufactured by
29 // Intel and sold by Intel or its authorized distributors. Please
30 // refer to the applicable agreement for further details, at
31 // https://fpgasoftware.intel.com/eula.
32
33 // PROGRAM           "Quartus Prime"
34 // VERSION          "Version 19.1.0 Build 670 09/22/2019 SJ Lite Edition"
35 // CREATED          "Sun May 31 18:25:23 2020"
36
37 module Final_Proj(
38     clock_50MHz,
39     reset,
40     s2,
41     s1,
42     s0,
43     hsync,
44     vsync,
45     RGB_OUT
46 );
47
48
49 input wire    clock_50MHz;
50 input wire    reset;
51 input wire    s2;
52 input wire    s1;
53 input wire    s0;
54 output wire   hsync;

```

```

55  output wire      vsync;
56  output wire      [11:0] RGB_OUT;
57
58  wire   [11:0] Background;
59  wire   [9:0] displayed_column;
60  wire   [9:0] displayed_row;
61  wire   [11:0] input_color;
62  wire   [7:0] SYNTHESIZED_WIRE_10;
63  wire   SYNTHESIZED_WIRE_2;
64  wire   SYNTHESIZED_WIRE_3;
65  wire   [11:0] SYNTHESIZED_WIRE_5;
66  wire   [11:0] SYNTHESIZED_WIRE_6;
67  wire   [11:0] SYNTHESIZED_WIRE_7;
68  wire   SYNTHESIZED_WIRE_8;
69  wire   [11:0] SYNTHESIZED_WIRE_9;
70
71  wire   [2:0] GDFX_TEMP_SIGNAL_0;
72
73
74  assign  GDFX_TEMP_SIGNAL_0 = {s2,s1,s0};
75
76
77 VGA_Display b2v_inst(
78   .clock_50MHz(clock_50MHz),
79   .reset_n(reset),
80   .Pixel_Colors_RGB(input_color),
81   .h_sync(hsync),
82   .v_sync(vsync),
83   .displayed_column(displayed_column),
84   .displayed_row(displayed_row),
85   .RGB_Outputs(RGB_OUT));
86
87
88 left   b2v_inst10(
89   .clock(clock_50MHz),
90   .address(SYNTHESIZED_WIRE_10),
91   .q(SYNTHESIZED_WIRE_6));
92
93
94 lpm_constant_0 b2v_inst11(
95   .result(Background));
96
97
98 RIGHT   b2v_inst12(
99   .clock(clock_50MHz),
100  .address(SYNTHESIZED_WIRE_10),
101  .q(SYNTHESIZED_WIRE_7));
102
103 assign  SYNTHESIZED_WIRE_8 = SYNTHESIZED_WIRE_2 & SYNTHESIZED_WIRE_3;
104
105
106 Comparator   b2v_inst4(
107   .a(displayed_row),
108   .altM(SYNTHESIZED_WIRE_2));
109 defparam     b2v_inst4.M = 16;
110
111
112 Comparator   b2v_inst5(
113   .a(displayed_column),
114   .altM(SYNTHESIZED_WIRE_3));
115 defparam     b2v_inst5.M = 16;
116
117
118 Down    b2v_inst6(
119   .clock(clock_50MHz),
120   .address(SYNTHESIZED_WIRE_10),
121   .q(SYNTHESIZED_WIRE_5));
122
123
124 AddressConverter b2v_inst7(
125   .column(displayed_column),
126   .row(displayed_row),
127   .address(SYNTHESIZED_WIRE_10));
128 defparam     b2v_inst7.ROWVALUE = 16;
129
130
131 SpriteMux   b2v_inst8(
132   .down(SYNTHESIZED_WIRE_5),
133   .left(SYNTHESIZED_WIRE_6),
134   .right(SYNTHESIZED_WIRE_7),
135   .s(GDFX_TEMP_SIGNAL_0),
136   .q(SYNTHESIZED_WIRE_9));
137
138
139 DisplayMux   b2v_inst9(
140   .s(SYNTHESIZED_WIRE_8),
141   .d0(SYNTHESIZED_WIRE_9),
142   .d1(Background),
143   .q(input_color));
144
145
146 endmodule
147
148 module lpm_constant_0(result);
149 /* synthesis black_box */
150
151 output [11:0] result;
152
153 endmodule

```

## A.4 Seven Segment Display Driver

### A.4.1 SevenSeg

```

1 //////////////////////////////////////////////////////////////////
2 // Engineer:      David Headrick
3 //
4 // Create Date:  05/29/2020
5 // Design Name:  SevenSeg
6 // Module Name:  SevenSeg
7 // Project Name:
8 // Target Devices: DE10-Lite
9 // Description:   Drives a seven segment display based off of an 8 bit bus input

```

```

10 // Dependencies:
11 // Revision:
12 // Revision 0.01 - File Created
13 // additional Comments: Derived from Matthew Shuman's seven segment driver design
14 //
15 module SevenSeg (input logic [7:0] data,
16                     output logic [0:6] segments);
17
18   always_comb
19   case(data)
20     8'b00000000: segments = 7'b000_0000; //0
21     8'b00000001: segments = 7'b100_1111; //1
22     8'b00000010: segments = 7'b001_0010; //2
23     8'b00000011: segments = 7'b000_0110; //3
24     8'b00000100: segments = 7'b100_1100; //4
25     8'b00000101: segments = 7'b010_0100; //5
26     8'b00000110: segments = 7'b010_0000; //6
27     8'b00000111: segments = 7'b000_1111; //7
28     8'b00001000: segments = 7'b000_0000; //8
29     8'b00001001: segments = 7'b000_1100; //9
30     8'b00001010: segments = 7'b000_1000; //a
31     8'b00001011: segments = 7'b110_0000; //b
32     8'b00001100: segments = 7'b011_0001; //c
33     8'b00001101: segments = 7'b100_0010; //d
34     8'b00001110: segments = 7'b011_0000; //e
35     8'b00001111: segments = 7'b011_1000; //f
36     default: segments = 7'b111_1111;
37   endcase
38 endmodule

```

## A.5 RGB Driver

### A.5.1 RGB\_Driver

```

1 //////////////////////////////////////////////////////////////////
2 // Company:          Oregon State University
3 // Engineer:         Brenden Lowe
4 //
5 // Create Date:      06/01/20
6 // Design Name:     RGB_Driver
7 // Module Name:    RGB_Driver
8 // Project Name:   ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description:    Top level of RGB Driver. Converts controller input to color
11 //                   output.
12 //
13 // Dependencies:
14 //
15 // Revision:
16 // Revision 0.01 - File Created
17 // additional Comments:
18 //
19 //////////////////////////////////////////////////////////////////
20
21 module RGB_Driver (input logic clk, user_res,
22                      input logic [6:0] controller,
23                      output logic dout);
24
25   // Define intermediate nodes
26   logic clk_1, bit_reset, bit_trans;
27   logic [3:0] tranfer_state;
28   logic [4:0] which_bit;
29   logic [23:0] colors;
30
31   // Feed clk into frequency divider
32   freq_div to_one (
33     .clk_50MHz (clk),
34     .user_res (user_res),
35     .clk_1MHz (clk_1)
36   );
37
38   // Feed controller input into colors
39   cont_to_color to_color (
40     .cont (controller),
41     .color (colors)
42   );
43
44   // Feed clk_1 into transfer state module
45   trans_state_to_trans (
46     .clk (clk_1),
47     .user_res (user_res),
48     .state (tranfer_state)
49   );
50
51   // Feed transfer state to get bit state
52   bit_state_to_bit (
53     .trans_state (tranfer_state),
54     .user_res (user_res),
55     .state (which_bit),
56     .res (bit_reset)
57   );
58
59   // Feed bit state to get appropriate bit to transfer
60   choose_bit to_bit_trans (
61     .color (colors),
62     .state (which_bit),
63     .send (bit_trans)
64   );
65
66   // Feed transfer bit into transfer module
67   transfer_to_transfer (
68     .data (bit_trans),
69     .reset (bit_reset),
70     .state (tranfer_state),
71     .dout (dout)
72   );
73 endmodule

```

### A.5.2 counter

```

1 //////////////////////////////////////////////////////////////////
2 // Company:      Oregon State University
3 // Engineer:     Brenden Lowe
4 //
5 // Create Date:  06/01/20
6 // Design Name: RGB Driver
7 // Module Name: counter
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description: Increments output every clock cycle.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19
20 module counter #(parameter N = 8) (input logic clk, reset,
21                                         output logic [
22                                         N-1:0] q)
23
24     always_ff@(posedge clk, posedge reset)
25         if (reset) q <= 0;
26         else q <= q + 1;
27
28 endmodule

```

### A.5.3 comparator

```

1 //////////////////////////////////////////////////////////////////
2 // Company:      Oregon State University
3 // Engineer:     Brenden Lowe
4 //
5 // Create Date:  06/01/20
6 // Design Name: RGB Driver
7 // Module Name: comparator
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description: Compares outputs and determines if they are equal.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19
20 module counter #(parameter N = 8) (input logic clk, reset,
21                                         output logic [
22                                         N-1:0] q)
23
24     always_ff@(posedge clk, posedge reset)
25         if (reset) q <= 0;
26         else q <= q + 1;
27
28 endmodule

```

### A.5.4 sync

```

1 //////////////////////////////////////////////////////////////////
2 // Company:      Oregon State University
3 // Engineer:     Brenden Lowe
4 //
5 // Create Date:  06/01/20
6 // Design Name: RGB Driver
7 // Module Name: sync
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description: Synchronizes signal with clock cycle.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19
20 module sync (input logic clk, d,
21               output logic q);
22
23     logic n1;
24
25     always_ff@(posedge clk)
26         begin
27             n1 <= d;
28             q <= n1;
29         end
30
31 endmodule

```

### A.5.5 freq\_div

```

1 //////////////////////////////////////////////////////////////////
2 // Company:      Oregon State University
3 // Engineer:     Brenden Lowe
4 //
5 // Create Date:  06/01/20
6 // Design Name: RGB Driver
7 // Module Name: freq_div
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description: Divides 50 MHz signal into 1 MHz signal.
11 //
12 // Dependencies:
13 //
14 // Revision:

```

```

15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 /////////////////////////////////
19
20 module freq_div (input logic clk_50Mhz, user_res,
21                   output logic clk_1Mhz);
22
23     logic [5:0] comp_50, count;
24     logic reset, full_res;
25
26     // Give comp_50 value
27     assign comp_50 = 50;
28
29     // Feed 50Mhz into counter
30     counter #(6) to_one(
31         .clk (clk_50Mhz),
32         .reset (full_res),
33         .q (count)
34     );
35
36     // Feed count into comparator
37     comparator #(6) is_50 (
38         .a (count),
39         .b (comp_50),
40         .eq (clk_1Mhz)
41     );
42
43     assign full_res = (clk_1Mhz | user_res);
44
45     // Feed clk_1Mhz into sync to reset counter
46     sync send_res (
47         .clk (clk_50Mhz),
48         .d (full_res),
49         .q (reset)
50     );
51 endmodule

```

### A.5.6 cont\_to\_color

```

1 //////////////////////////////////////////////////////////////////
2 // Company: Oregon State University
3 // Engineer: Brenden Lowe
4 //
5 // Create Date: 06/01/20
6 // Design Name: RGB Driver
7 // Module Name: cont_to_color
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description: Converts controller input into color-code output.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19 //
20 // module that converts controller input into color output
21 module cont_to_color (input logic [6:0] cont,
22                                     output logic [23:0] color);
23 //
24     always_comb
25         case(cont)
26             7'b100_0000: color = 24'hFF0000; // a maps to red
27             7'b010_0000: color = 24'h00FF00; // b maps to green
28             7'b001_0000: color = 24'h0000FF; // start maps to blue
29             7'b000_1000: color = 24'hFF9900; // up maps to orange
30             7'b000_0100: color = 24'hFF0066; // down maps to pink
31             7'b000_0010: color = 24'h660066; // left maps to purple
32             7'b000_0001: color = 24'h00FFFF; // right maps to cyan
33             default: color = 0;
34         endcase
35 endmodule

```

### A.5.7 trans state

```
1 //////////////////////////////////////////////////////////////////
2 // Company: Oregon State University
3 // Engineer: Brenden Lowe
4 //
5 // Create Date: 06/01/20
6 // Design Name: RGB Driver
7 // Module Name: trans_state
8 // Project Name: ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description: Keeps track of current transmission state.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19 //
20 module trans_state (input logic clk, user_res,
21                      output logic [3:0] state);
22
23     logic [3:0] comp_12;
24     logic reset, temp_eq, full_res;
25
26     // Give comp_12 value
27     assign comp_12 = 11; // 11, because we are counting zero as a 1 unit of time
28
29     // Feed clk into counter
30     counter #(4) cur_state(
31         .clk (clk),
32         .reset (reset),
33         .q (state)
```

```

34      );
35
36      // Feed count into comparator
37      comparator #(4) is_12 (
38          .a (state),
39          .b (comp_12),
40          .eq (temp_eq)
41      );
42
43      assign full_res = (temp_eq | user_res);
44
45      // Feed into sync to reset counter
46      sync res_send (
47          .clk (clk),
48          .d (full_res),
49          .q (reset)
50      );
51 endmodule

```

### A.5.8 bit\_state

```

1 //////////////////////////////////////////////////////////////////
2 // Company:          Oregon State University
3 // Engineer:         Brenden Lowe
4 //
5 // Create Date:     06/01/20
6 // Design Name:    RGB Driver
7 // Module Name:    bit_state
8 // Project Name:   ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description:    Keeps track of which bit to transmit.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19
20 module bit_state (input logic [3:0] trans_state,
21                     input logic user_res,
22                     output logic [4:0] state,
23                     output logic res);
24
25     // Define intermediate nodes
26     logic [4:0] comp_24, comp_30;
27     logic [3:0] comp_12;
28     logic inc, reset, temp_res, full_res;
29
30     // Give comp_12 a value
31     assign comp_12 = 11;
32
33     // Give comp_24 a value
34     assign comp_24 = 23;
35
36     // Give comp_30 a value
37     assign comp_30 = 30;
38
39     // Feed trans state into comparator
40     comparator #(4) is_inc (
41         .a (trans_state),
42         .b (comp_12),
43         .eq (inc)
44     );
45
46     // Feed inc into counter
47     counter #(5) count_bit (
48         .clk (inc),
49         .reset (reset),
50         .q (state)
51     );
52
53     // Feed state into a comparator
54     comparator #(5) is_24 (
55         .a (state),
56         .b (comp_30),
57         .eq (temp_res)
58     );
59
60     assign full_res = (temp_res | user_res);
61
62     // Feed into sync to reset counter
63     sync res_send (
64         .clk (inc),
65         .d (full_res),
66         .q (reset)
67     );
68
69     assign res = (state > comp_24);
70 endmodule

```

### A.5.9 choose\_bit

```

1 //////////////////////////////////////////////////////////////////
2 // Company:          Oregon State University
3 // Engineer:         Brenden Lowe
4 //
5 // Create Date:     06/01/20
6 // Design Name:    RGB Driver
7 // Module Name:    choose_bit
8 // Project Name:   ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description:    Outputs the current bit to be transmitted.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //

```

```

18 //////////////////////////////////////////////////////////////////
19
20 module choose_bit (input logic [23:0] color,
21                      input logic [4:0] state,
22                      output logic send);
23
24     always_comb
25         case(state)
26             0: send = color[23];
27             1: send = color[22];
28             2: send = color[21];
29             3: send = color[20];
30             4: send = color[19];
31             5: send = color[18];
32             6: send = color[17];
33             7: send = color[16];
34             8: send = color[15];
35             9: send = color[14];
36             10: send = color[13];
37             11: send = color[12];
38             12: send = color[11];
39             13: send = color[10];
40             14: send = color[9];
41             15: send = color[8];
42             16: send = color[7];
43             17: send = color[6];
44             18: send = color[5];
45             19: send = color[4];
46             20: send = color[3];
47             21: send = color[2];
48             22: send = color[1];
49             23: send = color[0];
50             default: send = 0;
51         endcase
52     endmodule

```

### A.5.10 transfer

```

1 //////////////////////////////////////////////////////////////////
2 // Company:          Oregon State University
3 // Engineer:         Brenden Lowe
4 //
5 // Create Date:      06/01/20
6 // Design Name:     RGB Driver
7 // Module Name:    transfer
8 // Project Name:   ECE 271 Design Project
9 // Target Devices: Max 10 FPGA
10 // Description:    Outputs the correct encoding based on given signal.
11 //
12 // Dependencies:
13 //
14 // Revision:
15 // Revision 0.01 - File Created
16 // additional Comments:
17 //
18 //////////////////////////////////////////////////////////////////
19
20 module transfer (input logic data, reset,
21                      input logic [3:0] state,
22                      output logic dout);
23
24     always_comb
25         if (reset)
26             begin
27                 dout = 0;
28             end
29         else
30             begin
31                 if (data)
32                     begin
33                         case(state)
34                             0: dout = 1;
35                             1: dout = 1;
36                             2: dout = 1;
37                             3: dout = 1;
38                             4: dout = 1;
39                             5: dout = 1;
40                             6: dout = 0;
41                             7: dout = 0;
42                             8: dout = 0;
43                             9: dout = 0;
44                             10: dout = 0;
45                             11: dout = 0;
46                             default: dout = 0;
47                     endcase
48                 end
49             else
50                 begin
51                     case(state)
52                         0: dout = 1;
53                         1: dout = 1;
54                         2: dout = 1;
55                         3: dout = 0;
56                         4: dout = 0;
57                         5: dout = 0;
58                         6: dout = 0;
59                         7: dout = 0;
60                         8: dout = 0;
61                         9: dout = 0;
62                         10: dout = 0;
63                         11: dout = 0;
64                         default: dout = 0;
65                 endcase
66             end
67         end
68     endmodule

```

## B Simulation Files (Do scripts)

### B.1 NES Decoder

```

1 vsim work.NES_Decoder
2
3 add wave *
4 force -freeze sim:/NES_Decoder/data 1'h0 0
5 force -freeze sim:/NES_Decoder/clk 1'h0 0
6 force -freeze sim:/NES_Decoder/reset 1'h1 0
7 force -freeze sim:/NES_Decoder/count 4'b0000 0
8 run 100 ns
9 force -freeze sim:/NES_Decoder/reset 1'h0 0
10 force -freeze sim:/NES_Decoder/count 4'b0001 0
11 force -freeze sim:/NES_Decoder/reset 1'h0 0
12 run 100 ns
13 force -freeze sim:/NES_Decoder/count 4'b0010 0
14 force -freeze sim:/NES_Decoder/data 1'h1 0
15 run 100 ns
16 force -freeze sim:/NES_Decoder/count 4'h3 0
17 run 100 ns

```

## B.2 PS/2 Keyboard

```

1 vsim ps2keyboard
2 add wave *
3 force -freeze clk_10 1 0, 0 {50 ps} -r 100
4 force reset_b 1
5 force enable_switch 1
6 force A 0
7 force B 0
8 force C 0
9 force D 0
10 force E 0
11 force F 0
12 force zero 0
13 force one 1
14 force two 0
15 force three 0
16 force four 0
17 force five 0
18 force six 0
19 force seven 0
20 force eight 0
21 force nine 0
22 run 200

```

## B.3 Seven Segment Driver

```

1 vsim work.SevenSeg
2
3 add wave data
4 add wave segments
5
6
7 force data 16#0 0
8 force data 16#1 10
9 force data 16#2 20
10 force data 16#3 30
11 force data 16#4 40
12 force data 16#5 50
13 force data 16#6 60
14 force data 16#7 70
15 force data 16#8 80
16 force data 16#9 90
17 force data 16#a 100
18 force data 16#b 110
19 force data 16#c 120
20 force data 16#d 130
21 force data 16#e 140
22 force data 16#f 150
23
24 run 160 ps

```

## B.4 RGB Driver

```

1 vsim work.RGB_Decoder
2
3 add wave *
4 force -freeze sim:/RGB_Driver/clk 1'h0 0
5 force -freeze sim:/RGB_Driver/user_res 1'h1 0
6 force -freeze sim:/RGB_Driver/controller 7'b100_0000 0
7 force -freeze sim:/RGB_Driver/clk_1 1'h0 0
8 force -freeze sim:/RGB_Driver/bit_reset 1'h0 0
9 run 50 ns
10 force -freeze sim:/RGB_Driver/user_res 1'h0 0
11 force -freeze sim:/RGB_Driver/transfer_state 4'h0 0
12 force -freeze sim:/RGB_Driver/which_bit 5'd24 0
13 run 50 ns
14 force -freeze sim:/RGB_Driver/transfer_state 4'h1 0
15 run 50 ns
16 force -freeze sim:/RGB_Driver/transfer_state 4'h2 0
17 run 50 ns
18 force -freeze sim:/RGB_Driver/transfer_state 4'h3 0
19 run 50 ns
20 force -freeze sim:/RGB_Driver/transfer_state 4'h4 0
21 run 50 ns
22 force -freeze sim:/RGB_Driver/transfer_state 4'h5 0
23 run 50 ns
24 force -freeze sim:/RGB_Driver/transfer_state 4'h6 0
25 run 50 ns
26 force -freeze sim:/RGB_Driver/transfer_state 4'h7 0
27 run 50 ns
28 force -freeze sim:/RGB_Driver/transfer_state 4'h8 0
29 run 50 ns
30 force -freeze sim:/RGB_Driver/transfer_state 4'h9 0
31 run 50 ns
32 force -freeze sim:/RGB_Driver/transfer_state 4'ha 0
33 run 50 ns
34 force -freeze sim:/RGB_Driver/transfer_state 4'hb 0
35 run 50 ns
36 force -freeze sim:/RGB_Driver/transfer_state 4'hc 0
37 force -freeze sim:/RGB_Driver/which_bit 5'h00 0

```

```
38 run 50 ns
39 force -freeze sim:/RGB_Driver/transfer_state 4'h1 0
40 run 50 ns
41 force -freeze sim:/RGB_Driver/transfer_state 4'h2 0
42 run 50 ns
43 force -freeze sim:/RGB_Driver/transfer_state 4'h3 0
44 run 50 ns
45 force -freeze sim:/RGB_Driver/transfer_state 4'h5 0
46 run 50 ns
47 force -freeze sim:/RGB_Driver/transfer_state 4'h6 0
48 run 50 ns
49 force -freeze sim:/RGB_Driver/transfer_state 4'h7 0
50 run 50 ns
51 force -freeze sim:/RGB_Driver/transfer_state 4'h8 0
52 run 50 ns
53 force -freeze sim:/RGB_Driver/transfer_state 4'h9 0
54 run 50 ns
55 force -freeze sim:/RGB_Driver/transfer_state 4'ha 0
56 run 50 ns
57 force -freeze sim:/RGB_Driver/transfer_state 4'hb 0
58 run 50 ns
```