



# Lab 2: FPFA-based Mental Binary Math Game

02.24.2023

—  
**Smithson Arrey**

Electrical Engineering, Computer and Embedded Systems

Dr. Yuhua Chen

ECE 5440, Advanced Digital Design, Spring 2023

## Introduction

This FPGA-based Mental Binary Math Game is a game that tests the two player's knowledge of binary. Each player is given a set of four switches that represent the bits of a hexadecimal number. By switching a switch to its active position, the players can indicate that a bit in their series of bits is active. For example, a player that has all but their 1st and 3rd switches in the inactive state will be representing the binary sequence, 1010, which is the hexadecimal number A. The goal of the game is for both players to add their numbers together to reach a total of 1111 or "F". Each player will be able to see the numbers that their inputs are creating on one of the 7 segment displays on either end of the board. In between the summation of their numbers will be shown. If the players are successful, they should see "F" appear on the summation screen and the leftmost red LED will turn on to confirm their victory. The rightmost LED, signaling an incorrect match, will turn off in that case. Otherwise, the summation screen will show another number and the rightmost LED will be active and the leftmost will be inactive. Note: Summation is limited to four bits. See the image below for visual details. Before the players begin playing, they must log in using a unique pin by the game's creator. After they are done playing, they may log out using the same password entry button. Their progress will not be erased unless the reset button is pressed.



Game User Interface



## System Architecture Design



## Lab 2 System Architecture

The figure above shows the system architecture for this game. There are three types of modules in this design:

1. Decoder\_4to7\_seg - This module decodes a 4-bit binary input, decoder\_in, representing a hexadecimal number to a 7-bit binary code, decoder\_out, that maps to the pins of a 7 segment display such that the display visualizes the alphanumeric representation of the hexadecimal. The 7 seg display has active low logic.
2. Adder\_NC\_4 - This module is a generic 2 input, 4-bit adder without a carry bit in its output. In this case, the two inputs are defined as the four bit binary input signal from either player's switches.
3. Game\_Checker - This module is a generic game win checker that can interpret a 4-bit game condition and output a 2-bit response indicating the game's state. Bit 0 of the response indicates a non-valid condition. Bit 1 of the response indicates a valid condition. Only one bit will be activated at a time. The use of this module in Lab 1 will be to use the 4-bit sum of both player's numbers as this module's input. The output will be wired to the verification LEDs.
4. ButtonShaper - This module is a generic button shaper. It transforms multi clock cycle input pulses into a single cycle pulse
5. LoadRegister - This module is a generic load register. It shifts the input to the output on command. Acts as a simple memory device.
6. AccessController - Prevents the user from accessing the game without first logging in. Uses sequential logic to input a predetermined password. Can be used to log in and out of the game.

## 7 Segment Decoder Simulation



Diagram of 7 Segment Decoder Module

The 7 Segment Decoder module necessary for Lab 1 takes 1 four bit input and outputs a 7 bit output. In this instance, the decoder will generate an output, decoder\_out,

that correlates to the visual representation of the hexadecimal equivalent of the four bit input, decoder\_in, rather than its direct representation in binary. The mapping is defined by the pin assignments driving the 7 Segment Display. The input signal will be driven by a player's slide switch used to indicate a 4 bit binary number or the summation of two player's binary numbers. The output signal will connect to the 7 segment display.



### 7 Segment Decoder Test Waveforms

For my test of the decoder, I ran a simulation of every input case. The source code for this test can be found in the appendix of this document. For example, on the fourth test run, indicated by the yellow line, the number four is inputted as a binary signal and the output is given as 7'b1100110. That output would correctly draw the hexadecimal number 4 on the display. See the appendix, for a visualization of which pins are connected to which LED on the display. Likewise, the binary signal of number three is decoded as 7'b1001111 and the binary signal of 5 is decoded as 7'b1101101. However, it should be noted that the bits of the output will be inverted in the production code because the 7 Segment Display has an active low logic configuration.

## Adder Simulation



Diagram of Adder Module

The Adder module necessary for Lab 1 takes 2 four bit inputs and outputs a four bit summation of the two inputs. No carry bit is necessary for this lab so it will be excluded from the design. The two inputs are generically defined as Number1 and Number2 can therefore be correlated to the corresponding player number in the lab. These inputs are generated from the player's use of the slide switches to indicate a 4 bit binary number. The 4 bit Summation output is the sum of Number1 and Number2. This output will then be used as an input signal for the 7 segment decoder linked to the summation display.



Adder Test Waveforms

For my test of the adder, I ran a simulation of a matching number, non-matching number, and two overflow cases. The source code for this test can be found in the appendix of this document. For example, a matching case should have an output of 4'b1111. The first test shown correctly displays this output. Likewise, a non matching case will be any number that is not equivalent to 4'b1111. That means that the second test correctly displays a non-matching case. Thirdly, the remaining cases show that a summation that overflows will not produce a correct matching case. However it would be hard to know that this was an overflow from looking at the output alone.

## Button Shaper Simulation



Diagram of Button Shaper Module

The Button Shaper module necessary for Lab 2 takes one single bit button press signal, B\_in, 1 clock signal, Clk, and 1 Reset signal, Rst, as inputs. The output is a single cycle pulse signal, B\_out. This module uses both combination and sequential logic to transform the multi-clock cycle input of B\_in into a single cycle pulse. This is accomplished using a two-procedure finite state machine implementation.



Button Shaper Test Waveforms

For my test of the Button Shaper, I ran a simulation of two multicycle button presses to ensure the system is functional. The image above shows the waveforms generated during my simulation. The period before the vertical yellow line indicates the "start-up" phase where  $Rst == 1'b0$ . The system is intentionally unresponsive during this stage. When  $Rst == 1'b1$ , the system we are interested in is active. For this system, we expect a single cycle pulse to appear in the output after a button is pressed and released no matter how long the button is pressed. The period after the vertical yellow line shows that this requirement has been met. Initially, the button isn't pressed so no output can be given. Then the button is pressed, held for a while, and then released. Resulting in a single cycle pulse shortly afterwards. The second occurrence of this scenario shows that this system is repeatable and doesn't get stuck in any state.



Finite State Machine for Button Shaper

## Access Control Simulation



Diagram of Access Control Module

The Access Control module necessary for Lab 2 takes a 4 bit PasswordDigit input, one Load signal input per player, 1 clock signal, Clk, and 1 Reset signal, Rst, as inputs. The outputs are the two replicated load signals, and the two signals indicating whether the players have logged in or not. Those signals will be connected directly to internal LEDs. This module uses both combination and sequential logic. This is accomplished using a one-procedure finite state machine implementation.



### Access Control Module Waveforms

For my test of the Access Control Module I checked the state machine by entering in the correct password, clearing that, and then entering an incorrect password. In the waveform above, it can be seen that the FPGA successfully travels the states of the state machine and logs in. Likewise, when entering any wrong input, the FPGA returns back to the original state to wait for a correct input.



Finite State Machine for Access Control Module

## FPGA Board Testing Results



Matching Case Demonstrated on FPGA

The demonstration above showcases a matching or “game-winning” case because the middle 7 segment display showcases the hexadecimal “F” and the matching LED is active while the non-matching LED is inactive. It can be seen that player two activated their most significant bit to represent the number 8. Likewise, player one activated every bit but their most significant bit to represent the number 7. And  $8 + 7 == "F"$  in hexadecimal so this confirms the validity of the demonstration.



#### Non-Matching Case Demonstrated on FPGA

The demonstration above showcases a non-matching or “game-losing” case because the middle 7 segment display showcases the hexadecimal “A” rather than “F”. Additionally, the matching LED is inactive while the non-matching LED is active. It can be seen that player two activated their most significant bit to represent the number 8. Likewise, player one only activated their second least significant bit to represent the number 2. And  $8 + 2 == "A"$  in hexadecimal so this confirms the validity of the demonstration.



User Interface Update 2-24-23

## Video Demo

Link to Game Demo:

<https://drive.google.com/file/d/1kf470GGztmG8lyOS5GGdO289C3EkZ-QW/view?usp=sharing>

Link to Access Control and Loading Update Demo:

[https://drive.google.com/file/d/1VgKYtuTyxryIWglkSf5pn5ktK65yZ\\_K/view?usp=sharing](https://drive.google.com/file/d/1VgKYtuTyxryIWglkSf5pn5ktK65yZ_K/view?usp=sharing)

## Conclusion

This week I was able to fully complete Lab 2 plus the bonus features. It was great to learn about how to build a fully functional system using FPGAs!

## Appendix



7 Segment Display Pin Assignments

```

1  module Adder_NC_4(Number1, Number2, Summation);
2    input [3:0] Number1, Number2;
3    output [3:0] Summation;
4    reg [3:0] Summation;
5
6    always@{Number1, Number2}
7      begin Summation = Number1 + Number2; end
8
9  endmodule

```

### Adder Module Source Code

```

1  `timescale 1 ns/100 ps
2  module Testbench_Adder_NC_4();
3
4    reg [3:0] Number1_s, Number2_s;
5    wire [3:0] Summation_s;
6
7    Adder_NC_4 DUT (Number1_s, Number2_s, Summation_s);
8
9    initial
10   begin
11     // matching numbers
12     Number1_s = 4'b0011; Number2_s = 4'b1100;
13     #10;
14     // non-matching numbers
15     Number1_s = 4'b1000; Number2_s = 4'b0011;
16     #10;
17     Number1_s = 4'd8; // Equivalent to 4'b1000
18     Number2_s = 4'd9; // Equivalent to 4'b1001
19     #10;
20     // Should overflow
21     Number1_s = 4'd10; Number2_s = 4'd10;
22   end
23 endmodule

```

### Adder Testbench Source Code

```

1 // Course Number: ECE 5440
2 // Author: Smithson Arrey, 0046
3 // Module Name: Decoder_4to7seg
4 // Description: This module decodes a 4-bit binary input representing a hexadecimal number to
5 // an 7-bit binary code that maps to the pins of a 7 segment display
6 // such that the display visualizes the alphanumeric
7 // representation of the hexadecimal
8 // The 7 seg display has active low logic
9 // Comments: N/A
10 module Decoder_4to7seg(decoder_in, decoder_out);
11   input [3:0] decoder_in;
12   output [6:0] decoder_out;
13   reg [6:0] decoder_out;
14
15   always@(decoder_in)
16     begin
17       case(decoder_in)
18         4'b0000://
19           begin decoder_out = 7'b1000000; end
20         4'b0001://
21           begin decoder_out = 7'b1111001; end
22         4'b0010://
23           begin decoder_out = 7'b0100100; end
24         4'b0011://
25           begin decoder_out = 7'b0110000; end
26         4'b0100://
27           begin decoder_out = 7'b0011001; end
28         4'b0101://
29           begin decoder_out = 7'b0010010; end
30         4'b0110://
31           begin decoder_out = 7'b0000010; end
32         4'b0111://
33           begin decoder_out = 7'b1111000; end
34         4'b1000://
35           begin decoder_out = 7'b0000000; end
36         4'b1001://
37           begin decoder_out = 7'b0001100; end
38         4'b1010://
39           begin decoder_out = 7'b0000100; end
40         4'b1011://
41           begin decoder_out = 7'b0000011; end
42         4'b1100://
43           begin decoder_out = 7'b0100111; end
44
45
46
47
48
49
50
51
52
53
54
55
56
57

```

## 7 Segment Decoder Source Code (Active Low Logic) Part 1

```

15   always@(decoder_in)
16     begin
17       case(decoder_in)
18         4'b0000://
19           begin decoder_out = 7'b1000000; end
20         4'b0001://
21           begin decoder_out = 7'b1111001; end
22         4'b0010://
23           begin decoder_out = 7'b0100100; end
24         4'b0011://
25           begin decoder_out = 7'b0110000; end
26         4'b0100://
27           begin decoder_out = 7'b0011001; end
28         4'b0101://
29           begin decoder_out = 7'b0010010; end
30         4'b0110://
31           begin decoder_out = 7'b0000010; end
32         4'b0111://
33           begin decoder_out = 7'b1111000; end
34         4'b1000://
35           begin decoder_out = 7'b0000000; end
36         4'b1001://
37           begin decoder_out = 7'b0001100; end
38         4'b1010://
39           begin decoder_out = 7'b0000100; end
40         4'b1011://
41           begin decoder_out = 7'b0000011; end
42         4'b1100://
43           begin decoder_out = 7'b0100111; end
44         4'b1101://
45           begin decoder_out = 7'b0100001; end
46         4'b1110://
47           begin decoder_out = 7'b0000010; end
48         4'b1111:
49           begin decoder_out = 7'b0000110; end
50         default:
51           begin decoder_out = 7'b0000000; end
52
53
54
55
56
57

```

## 7 Segment Decoder Source Code (Active Low Logic) Part 2

```

1   `timescale 1 ns/100 ps
2   module Testbench_Decoder_4to7seg();
3
4     reg [3:0] decoder_in_s;
5     wire [6:0] decoder_out_s;
6
7     Decoder_4to7seg DUT(decoder_in_s, decoder_out_s);
8
9     initial
10    begin
11      // Testing 0
12      decoder_in_s = 4'd0;
13      #10;
14      // Testing 1
15      decoder_in_s = 4'd1;
16      #10;
17      // Testing 2
18      decoder_in_s = 4'd2;
19      #10;
20      // Testing 3
21      decoder_in_s = 4'd3;
22      #10;
23      // Testing 4
24      decoder_in_s = 4'd4;
25      #10;
26      // Testing 5
27      decoder_in_s = 4'd5;
28      #10;
29      // Testing 6
30      decoder_in_s = 4'd6;
31      #10;
32      // Testing 7
33      decoder_in_s = 4'd7;
34      #10;
35      // Testing 8
36      decoder_in_s = 4'd8;
37      #10;
38      // Testing 9
39      decoder_in_s = 4'd9;

```

## 7 Segment Decoder Testbench Source Code Part 1

```

22      #10;
23      // Testing 4
24      decoder_in_s = 4'd4;
25      #10;
26      // Testing 5
27      decoder_in_s = 4'd5;
28      #10;
29      // Testing 6
30      decoder_in_s = 4'd6;
31      #10;
32      // Testing 7
33      decoder_in_s = 4'd7;
34      #10;
35      // Testing 8
36      decoder_in_s = 4'd8;
37      #10;
38      // Testing 9
39      decoder_in_s = 4'd9;
40      #10;
41      // Testing 10 (A)
42      decoder_in_s = 4'd10;
43      #10;
44      // Testing 11 (B)
45      decoder_in_s = 4'd11;
46      #10;
47      // Testing 12 (C)
48      decoder_in_s = 4'd12;
49      #10;
50      // Testing 13 (D)
51      decoder_in_s = 4'd13;
52      #10;
53      // Testing 14 (E)
54      decoder_in_s = 4'd14;
55      #10;
56      // Testing 15 (F)
57      decoder_in_s = 4'd15;
58
59    end
60  endmodule

```

## 7 Segment Decoder Testbench Source Code Part 2

```

1 // Course Number: ECE 5440
2 // Author: Smithson Arrey, 0046
3 // Module Name: Game_Checker
4 // Description: This module is a generic game checker that can interpret a 4-bit game condition,
5 // and output a 2-bit response indicating the game's state. Bit 0 of the response indicates a non-valid condition.
6 // Bit 1 of the response indicates a valid condition. Only one bit will be activated at a time.
7 // Comments: The use of this module in Lab 1 will be to use the 4-bit sum of both player's numbers
8 // as this module's input. The output will be wired to the verification LEDs
9
10 module Game_Checker(GameCondition, GameState);
11     input [3:0] GameCondition;
12     output [1:0] GameState;
13     reg [1:0] GameState;
14
15     always@(GameCondition)
16     begin
17         if(GameCondition == 4'b1111)
18             begin GameState = 2'b10; end
19         else
20             begin GameState = 2'b01; end
21     end
22 endmodule

```

### Game\_Checker Source Code

```

Lab2_ARREY_Smithson > src > LoadRegister.v
1 // Course Number: ECE 5440
2 // Author: Smithson Arrey, 0046
3 // Module Name: LoadRegister
4 // Description: This module is a generic load register.
5 // It shifts the input to the output on command. Acts as a simple memory device.
6 // Comments: N/A
7
8 module LoadRegister(D_in, D_out, Clk, Rst, Load);
9     input [3:0] D_in;
10    output [3:0] D_out;
11    input Clk, Rst;
12    input Load;
13    reg [3:0] D_out;
14    always@(posedge Clk)
15        begin
16            if (Rst == 1'b0)
17                begin
18                    D_out <= 4'b0000;
19                end
20            else
21                // normal operation after reset
22                begin
23                    if (Load == 1'b1)
24                        begin
25                            D_out <= D_in;
26                        end
27                end
28        end
29 endmodule
30
31

```

## LoadRegister Module Source Code

```
1 // Course Number: ECE 5440
2 // Author: Smithson Arrey, 0046
3 // Module Name: testbench_LoadRegister
4 // Description: This module is a testbench for the LoadRegister module
5 // it will show various functionality of the LoadRegister and demonstrate a single cycle pulse
6 // Comments: N/A
7
8 `timescale 1 ns/100 ps
9 module testbench_LoadRegister();
10    reg Clk;
11    reg Rst, Load;
12    reg [3:0] D_in;
13    wire [3:0] D_out;
14
15    always //empty sensitivity list
16        begin
17            Clk = 1'b0;
18            #10;
19            Clk = 1'b1;
20            #10;
21        end
22
23    LoadRegister DUT_LoadRegister1 (D_in, D_out, Clk, Rst, Load);
24
25    initial begin
26        Rst = 1'b1;
27        Load = 1'b0;
28        D_in = 4'b0000;
29
30        @(posedge Clk);
31        @(posedge Clk);
32        #5 Rst = 1'b0;
33        @(posedge Clk);
34        @(posedge Clk);
35        @(posedge Clk);
36        @(posedge Clk);
37        #5 Rst = 1'b1;
38        @(posedge Clk);
39        @(posedge Clk);
40        @(posedge Clk);
41        @(posedge Clk);
42        #5 D_in = 4'b0001;
43        @(posedge Clk);
```

```
44      //single cycle pulse in test bench
45      #5 Load = 1'b1;
46      @(posedge Clk);
47      #5 Load = 1'b0;
48      @(posedge Clk);
49      //          //
50      #5 D_in = 4'b1111;
51      @(posedge Clk);
52      @(posedge Clk);
53      @(posedge Clk);
54      #5 D_in = 4'b0111;
55      @(posedge Clk);
56      @(posedge Clk);
57      #5 Load = 1'b1;
58      @(posedge Clk);
59      #5 Load = 1'b0;
60      @(posedge Clk);
61  end
62 endmodule
63
```

LoadRegister Testbench Source Code

```

1 // Course Number: ECE 5440
2 // Author: Smithson Arrey, 0046
3 // Module Name: ButtonShaper
4 // Description: This module is a generic button shaper. It transforms multi clock cycle input pulses into a single cycle pulse
5 // Comments: N/A
6 module ButtonShaper(B_in, B_out, Clk, Rst);
7   input B_in, Clk, Rst;
8   output B_out;
9   reg B_out;
10  parameter INIT = 0, PULSE = 1, WAIT = 2;
11  reg [1:0] State, StateNext;
12
13  always@(State, B_in) begin
14    case(State)
15      INIT: begin
16        B_out = 1'b0;
17        if(B_in == 1'b0)
18          StateNext = PULSE;
19        else
20          StateNext = INIT;
21      end
22      PULSE: begin
23        B_out = 1'bl;
24        StateNext = WAIT;
25      end
26      WAIT: begin
27        B_out = 1'b0;
28        if(B_in == 1'bl)
29          StateNext = INIT;
30        else
31          StateNext = WAIT;
32      end
33      default: begin
34        B_out = 1'b0;
35        StateNext = WAIT;
36      end
37    endcase
38  end
39
40  always@(posedge Clk) begin
41    if(Rst == 1'b0)
42      State <= WAIT;
43
44    else
45      State <= StateNext;
46  end
endmodule

```

### Button Shaper Module Source Code

```

1 // Course Number: ECE 5440
2 // Author: Smithson Arrey, 0046
3 // Module Name: testbench_ButtonShaper
4 // Description: This module is intended to test the ButtonShaper module. It will observe two multicycle button press to ensure the system is functional
5 // Comments: N/A
6 timescale 1 ns/100 ps
7 module testbench_ButtonShaper();
8   reg Clk;
9   reg Rst;
10  reg B_in;
11  wire B_out;
12
13  always //empty sensitivity list
14  begin
15    Clk = 1'b0;
16    #10;
17    Clk = 1'bl;
18    #10;
19  end
20
21  ButtonShaper DUT (B_in, B_out, Clk, Rst);
22
23  initial begin
24    // Reset Cycle
25    Rst = 1'bl;
26    B_in = 1'b0;
27    @(posedge Clk);
28    @(posedge Clk);
29    #5 Rst = 1'b0;
30    @(posedge Clk);
31    @(posedge Clk);
32    @(posedge Clk);
33    @(posedge Clk);
34    #5 Rst = 1'bl;
35    @(posedge Clk);
36    @(posedge Clk);
37    @(posedge Clk);
38    @(posedge Clk);
39
40    // // 
41    // Button Triggered
42    #5 B_in = 1'bl;
43  end

```

```

31      @(posedge Clk);
32      @(posedge Clk);
33      @(posedge Clk);
34      #5 Rst = 1'b1;
35      @(posedge Clk);
36      @(posedge Clk);
37      @(posedge Clk);
38      @(posedge Clk);
39
40      //          //
41      // Button Triggered
42      #5 B_in = 1'b1;
43      @(posedge Clk);
44      @(posedge Clk);
45      @(posedge Clk);
46      @(posedge Clk);
47      //          //
48      //Button off
49      #5 B_in = 1'b0;
50      @(posedge Clk);
51      @(posedge Clk);
52      @(posedge Clk);
53      @(posedge Clk);
54      //          //
55
56      // Button Triggered
57      #5 B_in = 1'b1;
58      @(posedge Clk);
59      @(posedge Clk);
60      @(posedge Clk);
61      @(posedge Clk);
62      //          //
63      //Button off
64      #5 B_in = 1'b0;
65      @(posedge Clk);
66      @(posedge Clk);
67      @(posedge Clk);
68      @(posedge Clk);
69
70  end
71 endmodule
72

```

### Button Shaper Module Testbench Source Code

```

Lab2_ARREY_Smithson > src > AccessController.v
1  // Course Number: ECE 5440
2  // Author: Smithson Arrey, 0046
3  // Module Name: AccessController
4  // Description: This module is prevents the user from accessing the game without first logging in.
5  // Uses sequential logic to input a predetermined password. Can be used to log in and out of the game.
6  // Comments: N/A
7
8  module AccessController(PasswordEnter, PasswordDigit, Load_P1_In, Load_P2_In, LoggedIn, LoggedOut, Load_P1_Out, Load_P2_Out, Clk, Rst);
9    input PasswordEnter, Load_P1_In, Load_P2_In, Clk, Rst;
10   output Load_P1_Out, Load_P2_Out, LoggedIn, LoggedOut;
11   input [3:0] PasswordDigit;
12   reg Load_P1_Out, Load_P2_Out, LoggedIn, LoggedOut;
13   parameter DIGIT_ONE = 0, DIGIT_TWO = 1, DIGIT_THREE = 2, DIGIT_FOUR = 3, AUTHENTICATED = 4;
14   reg [2:0] State;
15
16   always@(posedge Clk)
17   begin
18     if(Rst == 1'b0)
19       begin
20         Load_P1_Out <= 1'b0;
21         Load_P2_Out <= 1'b0;
22         LoggedIn <= 1'b0;
23         LoggedOut <= 1'b1;
24         State <= DIGIT_ONE;
25       end
26     else
27
28       case(State)
29         DIGIT_ONE: begin
30           Load_P1_Out <= 1'b0;
31           Load_P2_Out <= 1'b0;
32           LoggedIn <= 1'b0;
33           LoggedOut <= 1'b1;
34           if (PasswordEnter == 1'b1)
35             begin
36               if(PasswordDigit == 4'd0)
37                 State <= DIGIT_TWO;
38               else
39                 State <= DIGIT_ONE;
40             end
41           else
42             begin State <= DIGIT_ONE; end
43         end

```

```
44 |         DIGIT_TWO: begin
45 |             Load_P1_Out <= 1'b0;
46 |             Load_P2_Out <= 1'b0;
47 |             LoggedIn <= 1'b0;
48 |             LoggedOut <= 1'b1;
49 |             if (PasswordEnter == 1'b1) begin
50 |                 if(PasswordDigit == 4'd0)
51 |                     State <= DIGIT_THREE;
52 |                 else
53 |                     //INCORRECT, START OVER
54 |                     State <= DIGIT_ONE;
55 |                 end
56 |             else //NOT ENTERED, STAY PUT
57 |                 begin State <= DIGIT_TWO; end
58 |             end
59 |         DIGIT_THREE: begin
60 |             Load_P1_Out <= 1'b0;
61 |             Load_P2_Out <= 1'b0;
62 |             LoggedIn <= 1'b0;
63 |             LoggedOut <= 1'b1;
64 |             if (PasswordEnter == 1'b1) begin
65 |                 if(PasswordDigit == 4'd4)
66 |                     State <= DIGIT_FOUR;
67 |                 else
68 |                     //INCORRECT, START OVER
69 |                     State <= DIGIT_ONE;
70 |                 end
71 |             else //NOT ENTERED, STAY PUT
72 |                 begin State <= DIGIT_THREE; end
73 |             end
74 |         DIGIT_FOUR: begin
75 |             Load_P1_Out <= 1'b0;
76 |             Load_P2_Out <= 1'b0;
77 |             LoggedIn <= 1'b0;
78 |             LoggedOut <= 1'b1;
79 |             if (PasswordEnter == 1'b1) begin
80 |                 if(PasswordDigit == 4'd6)
81 |                     State <= AUTHENTICATED;
82 |                 else
83 |                     //INCORRECT, START OVER
84 |                     State <= DIGIT_ONE;
85 |                 end
86 |             else //NOT ENTERED, STAY PUT
```

```

83           //INCORRECT, START OVER
84           | State <= DIGIT_ONE;
85           | end
86           else //NOT ENTERED, STAY PUT
87           begin State <= DIGIT_FOUR; end
88       end
89   AUTHENTICATED: begin
90       Load_P1_Out = Load_P1_In;
91       Load_P2_Out = Load_P2_In;
92       LoggedIn <= 1'b1;
93       LoggedOut <= 1'b0;
94       if (PasswordEnter == 1'b1) begin
95           //LOG OUT
96           State <= DIGIT_ONE;
97       end
98       else //NOT ENTERED, STAY PUT
99           begin State <= AUTHENTICATED; end
100      end
101  default: begin
102      Load_P1_Out <= 1'b0;
103      Load_P2_Out <= 1'b0;
104      LoggedIn <= 1'b0;
105      LoggedOut <= 1'b1;
106      State <= DIGIT_ONE;
107  end
108 endcase
109 end
110 endmodule
111

```

## AccessController Source Code

```

Lab2_ARREY_Smithson > src > testbench/AccessController.v
1  // Course Number: ECE 5440
2  // Author: Smithson Arrey, 0046
3  // Module Name: testbench_AccessController
4  // Description: This module is intended to test the AccessController module.
5  // It will ensure that this module correctly handles both a correct log in sequence and an incorrect log in sequence
6  // Comments: N/A
7  `timescale 1 ns/100 ps
8  module testbench_AccessController();
9      reg Clk;
10     reg Rst;
11     reg tPasswordEnter, tLoad_P1_In, tLoad_P2_In;
12     reg [3:0] tPasswordDigit;
13     wire tLoggedIn, tLoggedOut, tLoad_P1_Out, tLoad_P2_Out;
14
15     always //empty sensitivity list
16         begin
17             Clk = 1'b0;
18             #10;
19             Clk = 1'b1;
20             #10;
21         end
22
23     AccessController DUT_AccessController(tPasswordEnter, tPasswordDigit, tLoad_P1_In, tLoad_P2_In, tLoggedIn, tLoggedOut, tLoad_P1_Out, tLoad_P2_Out, Clk, Rst);
24
25     initial begin
26         Rst = 1'b1;
27         tPasswordEnter = 1'b0;
28         tLoad_P1_In = 1'b0;
29         tLoad_P2_In = 1'b0;
30
31         //testing valid password          //
32         //                                //
33         #5 tPasswordDigit = 4'd0;
34         @(posedge Clk);
35         #5 tPasswordEnter = 1'b1;
36         @(posedge Clk);
37         #5 tPasswordEnter = 1'b0;
38         @(posedge Clk);
39         //                                //
40         #5 tPasswordDigit = 4'd0;
41         @(posedge Clk);
42         #5 tPasswordDigit = 4'd0;
43         @(posedge Clk);

```

```
44      //          //
45      #5 tPasswordEnter = 1'b1;
46      @(posedge Clk);
47      #5 tPasswordEnter = 1'b0;
48      @(posedge Clk);
49
50      //          //
51      #5 tPasswordDigit = 4'd4;
52      @(posedge Clk);
53      @(posedge Clk);
54      #5 tPasswordEnter = 1'b1;
55      @(posedge Clk);
56      #5 tPasswordEnter = 1'b0;
57      @(posedge Clk);
58
59      //          //
60      #5 tPasswordDigit = 4'd6;
61      @(posedge Clk);
62      @(posedge Clk);
63      #5 tPasswordEnter = 1'b1;
64      @(posedge Clk);
65      #5 tPasswordEnter = 1'b0;
66      @(posedge Clk);
67
68      //    input     //
69      #5 tLoad_P1_In = 1'b1;
70      #5 tLoad_P2_In = 1'b1;
71      @(posedge Clk);
72      @(posedge Clk);
73      #5 tLoad_P1_In = 1'b0;
74      #5 tLoad_P2_In = 1'b0;
75      @(posedge Clk);
76      @(posedge Clk);
77
78      //logging out via password enter button
79      #5 tPasswordEnter = 1'b1;
80      @(posedge Clk);
81      @(posedge Clk);
82      #5 tLoad_P1_In = 1'b1; //confirming that there will be no output
83      #5 tLoad_P2_In = 1'b0;
84      @(posedge Clk);
85      @(posedge Clk);
```

Lab2\_ARREY\_Smithson > src > testbench\_AccessController.v

```

87      // Reset Cycle
88      #5 Rst = 1'b1;
89
90      @(posedge Clk);
91      @(posedge Clk);
92      #5 Rst = 1'b0;
93      @(posedge Clk);
94      @(posedge Clk);
95      @(posedge Clk);
96      @(posedge Clk);
97      #5 Rst = 1'b1;
98      @(posedge Clk);
99      @(posedge Clk);
100     @(posedge Clk);
101
102
103    //testing invalid password          //
104    //
105    #5 tPasswordDigit = 4'd1;
106    @(posedge Clk);
107    @(posedge Clk);
108    #5 tPasswordEnter = 1'b1;
109    @(posedge Clk);
110    @(posedge Clk);
111    tPasswordEnter = 1'b0;
112    //          //
113    #5 tPasswordDigit = 4'd2;
114    @(posedge Clk);
115    @(posedge Clk);
116    #5 tPasswordEnter = 1'b1;
117    @(posedge Clk);
118    @(posedge Clk);
119    #5 tPasswordEnter = 1'b0;
120    //          //
121    #5 tPasswordDigit = 4'd3;
122    @(posedge Clk);
123    @(posedge Clk);
124    #5 tPasswordEnter = 1'b1;
125    @(posedge Clk);
126    @(posedge Clk);
127    #5 tPasswordEnter = 1'b0;
128    //          //
129    #5 tPasswordDigit = 4'd4;

```

```

128    //          //
129    #5 tPasswordDigit = 4'd4;
130    @(posedge Clk);
131    @(posedge Clk);
132    #5 tPasswordEnter = 1'b1;
133    @(posedge Clk);
134    @(posedge Clk);
135    #5 tPasswordEnter = 1'b0;
136    //  input      //
137
138    #5 tLoad_P1_In = 1'b1;
139    #5 tLoad_P2_In = 1'b1;
140    @(posedge Clk);
141    @(posedge Clk);
142    #5 tLoad_P1_In = 1'b0;
143    #5 tLoad_P2_In = 1'b0;
144    @(posedge Clk);
145    @(posedge Clk);
146
147  end
148 endmodule
149

```

AccessController Testbench Source Code

```

1 // Course Number: ECE 5440
2 // Author: Smithson Arrey, 0046
3 // Module Name: Lab2_ARREY_Smithson
4 // Description: This is a top-level module intended to build the full circuit of Lab 2: MentalBinaryMathGame
5 // Comments: N/A
6
7 module Lab2_ARREY_Smithson(PasswordEnterButton, Load_Button_1, Load_Button_2, SwitchSetOne, SwitchSetTwo, PlayerOneDisplayCode, PlayerTwoDisplayCode,
8   input [3:0] SwitchSetOne, SwitchSetTwo;
9   input Rst, Clk;
10
11  input PasswordEnterButton, Load_Button_1, Load_Button_2;
12  output [16:0] PlayerOneDisplayCode, PlayerTwoDisplayCode, SummationDisplayCode;
13  output [1:0] VerificationLEDCode;
14
15  output LoggedInLED, LoggedOutLED;
16  wire Load_P1_In, Load_P2_In, Load_P1_Out, Load_P2_Out, PasswordEnter;
17  wire [3:0] P1_D_out, P2_D_out;
18
19 //Input shaping
20 ButtonShaper LoadButton1Shaper(Load_Button_1, Load_P1_In, Clk, Rst);
21 ButtonShaper LoadButton2Shaper(Load_Button_2, Load_P2_In, Clk, Rst);
22 ButtonShaper PasswordInputButtonShaper(PasswordEnterButton, PasswordEnter, Clk, Rst);
23
24 //Authentication
25 AccessController GameAccessor>PasswordEnter, SwitchSetTwo, Load_P1_In, Load_P2_In, LoggedInLED, LoggedOutLED, Load_P1_Out, Load_P2_Out, Clk, Rst
26
27 //Player One
28 LoadRegister PlayerOneLoadRegister(SwitchSetOne, P1_D_out, Clk, Rst, Load_P1_Out);
29 Decoder_4to7seg PlayerOneDecoder(P1_D_out, PlayerOneDisplayCode);
30
31 //Player Two
32 LoadRegister PlayerTwoLoadRegister(SwitchSetTwo, P2_D_out, Clk, Rst, Load_P2_Out);
33 Decoder_4to7seg PlayerTwoDecoder(P2_D_out, PlayerTwoDisplayCode);
34
35 //Summation
36 wire [3:0] InputAdderResult;
37
38 Adder_NC_4 InputAdder(P1_D_out, P2_D_out, InputAdderResult);
39 Decoder_4to7seg SummationDecoder(InputAdderResult, SummationDisplayCode);
40
41 //Verification
42 Game_Checker SummationChecker(InputAdderResult, VerificationLEDCode);
43

```

### Top Level Module Source Code