

# **FPGA experiment report**

Task: FPGA 7

Student 1      name: ahmad foqara      ID:322389982  
Student 2:      name: mohamed foqara      ID:212193916

## **Part 1 - Status update**

| Module name/Step      | status | notes/comments                       |
|-----------------------|--------|--------------------------------------|
| Ps2_Interface         | done   | This module is from past experiments |
| VGA_interface         | done   | This module is from past experiments |
| Seg_7_Display         | done   | This module is from past experiments |
| Lim_Inc               | done   | This module is from past experiments |
| CSA                   | done   | This module is from past experiments |
| FA                    | done   | This module is from past experiments |
| Snake_game            | done   | This is the TOP module               |
| Snake_Movement        | done   |                                      |
| tb_SnakeMovement      | done   |                                      |
| ScoreCounter          | done   |                                      |
| tb_ScoreCounter       | done   |                                      |
| SnakePixelRenderer    | done   |                                      |
| tb_SnakePixelRenderer | done   |                                      |
| SnakeGameLogic        | done   |                                      |
| tb_SnakeGameLogic     | done   |                                      |

## **Issues:**

In this section please describe the current issues you are facing.

- Per each module and simulation, if you receive any errors at the time of submission, please describe which errors and what they mean.

Fill here:

1. Ps2\_Interface:
2. VGA\_interface:
3. Seg\_7\_Display:
4. Lim\_Inc:
5. CSA:
6. FA:
7. Snake\_game:
8. Snake\_Movement:
9. tb\_SnakeMovement:
10. ScoreCounter:
11. tb\_ScoreCounter:
12. SnakePixelRenderer:
13. tb\_SnakePixelRenderer:
14. SnakeGameLogic:
15. tb\_SnakeGameLogic:
16. Elaborated Design:
17. Synthesis:
18. Setting up constraints:
19. Implementing the design:
20. FPGA programming and debugging:

## Block diagram:

The Ps2\_Interface & VGA\_interface & Seg\_7\_Display & Lim\_Inc & CSA & FA

Are the same from past experiments

The ps/2 gives snake game the inputs

**SnakeGameLogic**: this block is responsible for the movement logic of the snake and the food random generator.



## renderer:



The outputs goes to the VGA and to the screen

### ScoreCounter:



The output goes to the 7 seg on the fpga board



## Part 2 - Simulations and answers

Fill here:

1. Ps2\_Interface & VGA\_interface & Seg\_7\_Display & Lim\_Inc & CSA & FA

Are the same from past experiments

2.ScoreCounter:

The ScoreCounter module is designed to track and display the player's score during the snake game. It implements a 4-digit BCD (Binary-Coded Decimal) counter using a chain of four Lim\_Inc modules, each responsible for incrementing a single decimal digit: ones, tens, hundreds, and thousands. The score increases by one each time the inc\_score signal receives a rising-edge pulse, which occurs when the snake eats an apple.

The module receives three inputs: clk ,reset, and inc\_score (the pulse that triggers an increment). It outputs the current score to the 7-segment display. The display logic is handled by the module Seg\_7\_Display.



### 3. tb\_ScoreCounter:

This testbench verifies the core functionality of the ScoreCounter module by applying a series of inc\_score pulses and observing the resulting output on the 7-segment display. The segment output (seg) is decoded into a numerical digit using a common cathode mapping function, and only the active digit (an = 4'b1110, representing the ones place) is sampled.

The test confirms that the counter correctly resets, increments, and displays the expected values. By focusing on the least significant digit, we ensure that the basic counting and display logic function correctly without needing to track carry propagation across multiple digits.

This provides a simple yet effective way to validate that the scoring mechanism responds accurately to scoring events in the game.



### 4. SnakePixelRenderer

The SnakePixelRenderer module is responsible for determining the color of each pixel on the VGA screen based on the current game state. It compares the active pixel coordinates (XCoord, YCoord) against the positions of the snake body and the food. The snake's coordinates are stored in flattened vectors (snake\_x\_flat, snake\_y\_flat) and unpacked dynamically using a loop that checks each segment up to the current snake\_length. If a match is found, the pixel is colored green (12'h0F0). If the current pixel matches the food location and the food is active, it is colored red (12'hF00). All other pixels default to black (12'h000). This module runs on the pixel clock and updates the pixel\_color output in real time, enabling accurate visual rendering of the snake and food on screen.

## Inputs and Outputs:

The module receives the current pixel clock (pixel\_clk), snake length, snake body coordinates, food position, and screen coordinates. Its single output is pixel\_color, a 12-bit RGB value that determines the color of the current pixel. The module's logic ensures that each VGA pixel is correctly colored according to the presence of the snake or food at that location.



## 5. tp\_SnakePixelRenderer



This testbench validates the pixel rendering logic of the SnakePixelRenderer module by simulating different screen coordinates and comparing them against known snake and food positions. The snake is initialized with three segments at positions (10,10), (11,10), and (12,10), and the food is placed at (15,15). The test then checks three scenarios: when the current pixel matches a snake segment, matches the food, and when it is empty. For each case, the pixel\_color output is monitored to ensure it reflects the correct color: green for snake, red for food, and black for background. This confirms that the module accurately determines pixel color based on game state.

## 6. Snake\_Movement

The SnakeMovement module controls the snake's position update logic during gameplay. At every positive clock edge and when enable\_move is active, it updates the snake's body based on the current direction, checks for border collisions, and detects whether the snake's head has reached an apple.

The module stores the snake's body positions in flattened vectors (snake\_x\_flat, snake\_y\_flat), with the head always at index 0. On movement, the snake's body is shifted forward, and a new head position is calculated. If this position matches the current food coordinates (food\_x, food\_y) and the food is active, the food\_eaten signal is asserted. The module also raises the border\_collision signal if the head goes out of bounds, as defined by GRID\_WIDTH and GRID\_HEIGHT.

### Inputs and Outputs:

- **Inputs:** Clock (clk), reset (reset), movement direction (direction), current snake length (snake\_length), move enable signal (enable\_move), food coordinates (food\_x, food\_y), and a food\_active flag.
- **Outputs:** snake\_x\_flat and snake\_y\_flat, food\_eaten, and border\_collision (high if the snake hits the screen boundary).



## 7. tp\_Snake\_Movement



This testbench evaluates the behavior of the SnakeMovement module by simulating directional movement, food detection, and snake growth. The test initializes the snake in the center of the grid and repeatedly moves it to the right. At specific positions, food is placed in the snake's path to trigger the food\_eaten signal. When food is eaten, the snake\_length is incremented to simulate the growth logic handled by external game control. Throughout the simulation, signals such as snake\_x\_flat, food\_eaten, and border\_collision are observed to verify correct snake behavior and boundary handling. This test effectively demonstrates the module's ability to update position, grow on food collision, and detect wall collisions.

## 8. SnakeGameLogic:

The `SnakeGameLogic` module acts as the main game controller for the Snake game, handling direction input, movement timing, food spawning, growth, and collision detection. It integrates the `SnakeMovement` module to update the snake's position and maintains internal logic to manage when the snake should grow, when to spawn food, and when the game is over.

## **Functionality:**

The module listens to keyboard scan codes (scancode) to update the direction of movement, ensuring the snake cannot reverse direction directly. A movement pulse (enable\_move\_pulse) is generated based on a timing counter to control the snake's pace. When a move occurs, the module checks for food collision, border collision, and self-collision. If the snake eats food, it activates a grow flag and disables the food until a new random position is generated. If a collision is detected, the game ends by asserting game\_over.

## Inputs and Outputs:

- **Inputs:**
    - clk, reset: Clock and synchronous reset

- scancode, keyPressed: Keyboard input signals
  - **Outputs:**
    - snake\_x\_flat, snake\_y\_flat: Flattened coordinates of the snake body
    - food\_x, food\_y, food\_active: Current food state and position
    - food\_eaten, border\_collision: Status signals from SnakeMovement
    - snake\_length: Current length of the snake
    - game\_over: Indicates if the game has ended
    - direction: Current movement direction

The module ensures smooth game progression by managing movement intervals, directional changes, and game state updates like growth and collisions, forming the heart of the Snake game's logic.



## 9. tb\_SnakeGameLogic:



This testbench verifies the core gameplay logic of the Snake game. It simulates user input through keyboard scancodes to control the snake's direction and monitors

responses such as position updates, food spawning, snake growth, and game-over conditions.

The test begins by applying a reset, then simulates a sequence of directional keypresses (Right, Down, Left, Up) using press\_key. The movement timing is accelerated by setting a low INITIAL\_SPEED parameter to allow for quick simulation. The testbench also observes the food\_eaten and snake\_length signals to confirm that the snake grows correctly after eating and checks game\_over to verify proper collision detection.

**Inputs and Outputs Used:**

- Inputs: clk, reset, scanCode, keyPressed
- Outputs: snake\_x\_flat, snake\_y\_flat, food\_x, food\_y, food\_active, food\_eaten, border\_collision, snake\_length, game\_over, direction

The test provides effective functional coverage of input response, directional changes, growth logic, and collision handling, making it suitable for validating the integration of game control and movement modules.

## 10. Snake\_game:

The SnakeGameTop module serves as the top-level wrapper for the Snake game, integrating all subsystems including VGA display, keyboard input, game logic, rendering, and scoring. It takes a 100 MHz clk, active-high reset, and PS/2 keyboard inputs (PS2Clk, PS2Data). Its outputs drive the VGA interface (vgaRed, vgaGreen, vgaBlue, Hsync, Vsync) and a 4-digit 7-segment display (seg, an, dp) to show the score.

The core gameplay logic is handled by the SnakeGameLogic module, which processes direction input via decoded keyboard scanCode, manages snake movement, food spawning, colli



sion detection, and score updates. The snake's pixel positions and the food coordinates are passed to the SnakePixelRenderer module, which determines the correct RGB value for each pixel. The resulting color is forwarded to the VGA\_Interface, which generates proper VGA timing and downsampled pixel coordinates for a 100x75 grid. Additionally, whenever food is eaten, a score\_pulse is triggered, incrementing the score shown on the 7-segment display via the ScoreCounter module.

#### 11. Elaborated design:



## 12.Synthesis



## 13.Setting up constraints:

```

set_property BITSTREAM.GENERAL.COMPRESS TRUE [current_design]
set_property BITSTREAM.CONFIG.CONFIGRATE 33 [current_design]
set_property CONFIG_MODE SPIx4 [current_design]
set_property CFGBVS VCCO [current_design]
set_property CONFIG_VOLTAGE 3.3 [current_design]

```

```

set_property PACKAGE_PIN C17 [get_ports PS2Clk]
set_property IOSTANDARD LVCMS33 [get_ports PS2Clk]
set_property PULLUP true [get_ports PS2Clk]
set_property PACKAGE_PIN B17 [get_ports PS2Data]

```

```

set_property IOSTANDARD LVCMOS33 [get_ports PS2Data]
set_property PULLUP true [get_ports PS2Data]

set_property PACKAGE_PIN G19 [get_ports {vgaRed[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaRed[0]}]
set_property PACKAGE_PIN H19 [get_ports {vgaRed[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaRed[1]}]
set_property PACKAGE_PIN J19 [get_ports {vgaRed[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaRed[2]}]
set_property PACKAGE_PIN N19 [get_ports {vgaRed[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaRed[3]}]

set_property PACKAGE_PIN N18 [get_ports {vgaBlue[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaBlue[0]}]
set_property PACKAGE_PIN L18 [get_ports {vgaBlue[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaBlue[1]}]
set_property PACKAGE_PIN K18 [get_ports {vgaBlue[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaBlue[2]}]
set_property PACKAGE_PIN J18 [get_ports {vgaBlue[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaBlue[3]}]

set_property PACKAGE_PIN J17 [get_ports {vgaGreen[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaGreen[0]}]
set_property PACKAGE_PIN H17 [get_ports {vgaGreen[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaGreen[1]}]
set_property PACKAGE_PIN G17 [get_ports {vgaGreen[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaGreen[2]}]
set_property PACKAGE_PIN D17 [get_ports {vgaGreen[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {vgaGreen[3]}]

set_property PACKAGE_PIN P19 [get_ports Hsync]
set_property IOSTANDARD LVCMOS33 [get_ports Hsync]
set_property PACKAGE_PIN R19 [get_ports Vsync]
set_property IOSTANDARD LVCMOS33 [get_ports Vsync]

# 7-segment display
set_property PACKAGE_PIN W7 [get_ports {seg[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[0]}]
set_property PACKAGE_PIN W6 [get_ports {seg[1]}]

```

```
set_property IOSTANDARD LVCMOS33 [get_ports {seg[1]}]
set_property PACKAGE_PIN U8 [get_ports {seg[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[2]}]
set_property PACKAGE_PIN V8 [get_ports {seg[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[3]}]
set_property PACKAGE_PIN U5 [get_ports {seg[4]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[4]}]
set_property PACKAGE_PIN V5 [get_ports {seg[5]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[5]}]
set_property PACKAGE_PIN U7 [get_ports {seg[6]}]
set_property IOSTANDARD LVCMOS33 [get_ports {seg[6]}]

set_property PACKAGE_PIN V7 [get_ports dp]
set_property IOSTANDARD LVCMOS33 [get_ports dp]

set_property PACKAGE_PIN U2 [get_ports {an[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {an[0]}]
set_property PACKAGE_PIN U4 [get_ports {an[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {an[1]}]
set_property PACKAGE_PIN V4 [get_ports {an[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {an[2]}]
set_property PACKAGE_PIN W4 [get_ports {an[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {an[3]}]
```

```
#Buttons
set_property PACKAGE_PIN U18 [get_ports reset]
set_property IOSTANDARD LVCMOS33 [get_ports reset]
```

```
set_property PACKAGE_PIN W5 [get_ports clk]
set_property IOSTANDARD LVCMOS33 [get_ports clk]
create_clock -period 10.000 -name sys_clk_pin -waveform {0.000 5.000} -add [get_ports clk]
```

14.Implementing the design:



| General Information                           |                    | Setup  |             | Hold                             |                                  | Pulse Width |             |           |             |
|-----------------------------------------------|--------------------|--------|-------------|----------------------------------|----------------------------------|-------------|-------------|-----------|-------------|
| Timer Settings                                |                    |        |             |                                  |                                  |             |             |           |             |
| Design Timing Summary                         |                    |        |             |                                  |                                  |             |             |           |             |
| Clock Summary (1)                             |                    |        |             |                                  |                                  |             |             |           |             |
| Methodology Summary (107)                     |                    |        |             |                                  |                                  |             |             |           |             |
| Check Timing (347)                            |                    |        |             |                                  |                                  |             |             |           |             |
| Intra-Clock Paths                             |                    |        |             |                                  |                                  |             |             |           |             |
| Inter-Clock Paths                             |                    |        |             |                                  |                                  |             |             |           |             |
| Other Path Groups                             |                    |        |             |                                  |                                  |             |             |           |             |
| Clock Summary (1)                             |                    |        |             |                                  |                                  |             |             |           |             |
| Methodology Summary (107)                     |                    |        |             |                                  |                                  |             |             |           |             |
| Check Timing (347)                            |                    |        |             |                                  |                                  |             |             |           |             |
| Intra-Clock Paths                             |                    |        |             |                                  |                                  |             |             |           |             |
| sys_clk_pin                                   |                    |        |             |                                  |                                  |             |             |           |             |
| Setup -0.552 ns (10)                          |                    |        |             |                                  |                                  |             |             |           |             |
| Hold 0.090 ns (10)                            |                    |        |             |                                  |                                  |             |             |           |             |
| Pulse Width 4.500 ns (30)                     |                    |        |             |                                  |                                  |             |             |           |             |
| Inter-Clock Paths                             |                    |        |             |                                  |                                  |             |             |           |             |
| <b>Timing constraints are not met.</b>        |                    |        |             |                                  |                                  |             |             |           |             |
| Name                                          | Slack <sup>1</sup> | Levels | High Fanout | From                             | To                               | Total Delay | Logic Delay | Net Delay | Requirement |
| Path 1                                        | -0.552             | 13     | 102         | game_logic/move...flat_reg[10]/C | game_logic/game_over_req_inv/D   | 10.376      | 2.786       | 7.590     | 10.0        |
| Path 2                                        | 0.894              | 2      | 138         | game_logic/ena...move_raw_reg/C  | game_logic/move...flat_reg[13]/R | 8.153       | 0.919       | 7.234     | 10.0        |
| Path 3                                        | 0.894              | 2      | 138         | game_logic/ena...move_raw_reg/C  | game_logic/move...flat_reg[17]/R | 8.153       | 0.919       | 7.234     | 10.0        |
| Path 4                                        | 0.894              | 2      | 138         | game_logic/ena...move_raw_reg/C  | game_logic/move...flat_reg[20]/R | 8.153       | 0.919       | 7.234     | 10.0        |
| Path 5                                        | 0.894              | 2      | 138         | game_logic/ena...move_raw_reg/C  | game_logic/move...flat_reg[12]/R | 8.153       | 0.919       | 7.234     | 10.0        |
| Path 6                                        | 0.894              | 2      | 138         | game_logic/ena...move_raw_req/C  | game_logic/move...flat_reg[15]/R | 8.153       | 0.919       | 7.234     | 10.0        |
| Path 7                                        | 0.894              | 2      | 138         | game_logic/ena...move_raw_req/C  | game_logic/move...flat_req[19]/R | 8.153       | 0.919       | 7.234     | 10.0        |
| <b>Intra-Clock Paths - sys_clk_pin - Hold</b> |                    |        |             |                                  |                                  |             |             |           |             |
| Name                                          | Slack <sup>1</sup> | Levels | High Fanout | From                             | To                               | Total Delay | Logic Delay | Net Delay | Requirement |
| Path 11                                       | 0.090              | 0      | 3           | game_logic/move...lat_reg[261]/C | game_logic/move...lat_reg[272]/D | 0.456       | 0.177       | 0.279     | 0.          |
| Path 12                                       | 0.098              | 0      | 3           | game_logic/move...flat_reg[37]/C | game_logic/move...flat_reg[48]/D | 0.446       | 0.177       | 0.269     | 0.          |
| Path 13                                       | 0.110              | 0      | 3           | game_logic/move...lat_reg[127]/C | game_logic/move...lat_reg[138]/D | 0.489       | 0.193       | 0.296     | 0.          |
| Path 14                                       | 0.114              | 0      | 3           | game_logic/move...lat_reg[158]/C | game_logic/move...lat_req[169]/D | 0.489       | 0.193       | 0.296     | 0.          |
| Path 15                                       | 0.117              | 0      | 3           | game_logic/move...flat_reg[39]/C | game_logic/move...flat_reg[50]/D | 0.426       | 0.177       | 0.249     | 0.          |
| Path 16                                       | 0.125              | 0      | 3           | game_logic/move...lat_reg[263]/C | game_logic/move...lat_req[274]/D | 0.533       | 0.193       | 0.340     | 0.          |
| Path 17                                       | 0.128              | 0      | 3           | game_logic/move...lat_req[227]/C | game_logic/move...lat_req[238]/D | 0.476       | 0.177       | 0.299     | 0.          |

## 15.FPGA programming and debugging:



