

# COL215 - Digital Logic and System Design

Department of Computer Science & Engineering, IIT Delhi Semester  
I, 2025-26

## Lab Assignment 8 (Friday)

Developed By:  
Bharmal Bhakar (2024CS10403)  
Ritik Raj (2024CS10086)

### 1 Introduction

This report documents the implementation and results for Part I of the COL215 Lab Assignment 8: Road Fighter Game. The primary objective of Part I is to establish the fundamental video output infrastructure on the Basys 3 FPGA board using the Video Graphics Array (VGA) interface. This involves utilizing pre-designed modules (e.g., VGA\_driver.v, counters) to achieve a standard  $640 \times 480$  resolution and subsequently displaying a composite static image of the game background and the main car sprite. A critical task within this part is refining the display logic to correctly handle sprite transparency, ensuring the car is rendered seamlessly onto the road background by removing the dedicated pink color used as a transparent key.

### 2. Design Decisions

The Display\_sprite module was adapted from the provided template. It instantiates the VGA\_driver and two memory modules (bg\_rom and main\_car\_rom) to store the color data for the background and the car sprite, respectively.

1. clk\_divider.v: Generates the 25MHz pixel\_clock from the 100MHz system clock (clk) for VGA timing adherence ( $100\text{MHz}/4 = 25\text{MHz}$ ).
2. Horizontal and Vertical Counters: (Horiz\_counter.v and Vert\_counter.v) Generate the current pixel coordinates (hor\_pix, ver\_pix) necessary for memory addressing and sync signal generation.
3. VGA\_driver.v: Consolidates the clock and counter modules to generate the VGA synchronization signals (HS, VS) and the video\_on signal, which indicates the active display area.
4. Display\_sprite.v: The top-level rendering module for Part I. It uses the pixel coordinates to address two ROMs (Background and Car Sprite) and multiplexes their outputs to produce the final 12-bit VGA color signal (vgaRGB).

#### 2.1. Sprite and Background Location Logic

The display logic determines whether the current pixel coordinate (hor\_pix, ver\_pix) falls within the bounds of the background or the car sprite.

##### Background Bounding Box:

- The background starts at an offset of  $(\text{OFFSET\_BG\_X}, \text{OFFSET\_BG\_Y}) = (200, 150)$ .
- The logic checks if  $200 \leq \text{hor\_pix} < (200 + 160)$  and  $150 \leq \text{ver\_pix} < (150 + 240)$ .

- If within bounds (`bg_on` = 1), the address for `bg_rom` is calculated as:  

$$\text{bg\_rom\_addr} \leftarrow (\text{hor\_pix} - 200) + (\text{ver\_pix} - 150) \times 14.$$

### Car Sprite Bounding Box:

- The car is fixed at a starting position of (`car_x`, `car_y`) = (270, 300).
- The logic checks if  $270 \leq \text{hor\_pix} < (270 + 14)$  and  $300 \leq \text{ver\_pix} < (300 + 16)$ .
- If within bounds (`car_on` = 1), the address for `main_car_rom` is calculated as:  

$$\text{car\_rom\_addr} \leftarrow (\text{hor\_pix} - 270) + (\text{ver\_pix} - 300) \times 14.$$

## 2.2. Transparency Implementation

The assignment required implementing transparency for the car sprite by treating the pink color (12'b101000001010) as a "transparent" key. This logic is implemented in the `MUX_VGA_OUTPUT` always block.

**Design Decision:** The priority of the car sprite over the background is ensured by checking the `car_on` signal first.

```
always @ (posedge clk) begin : MUX_VGA_OUTPUT
    if (car_on) begin
        // High priority: If the current pixel is part of the car sprite
        if (car_color == PINK_COLOR) begin
            // Transparency logic: if pink, show the background color
            next_color <= bg_color;
        end
        else begin
            // Otherwise, show the car color
            next_color <= car_color;
        end
    end
    else if (bg_on) begin
        // Second priority: If the current pixel is only part of the background
        next_color <= bg_color;
    end
    else
        // Default: Outside both, show black (0)
        next_color <= 0;
end
```

## 2.3. TestBench

A dedicated test bench was created to verify the functionality of all modules. The primary focus of the simulation was to validate the VGA timing parameters, specifically checking the behavior of the 'HS' (Horizontal Sync) and 'VS' (Vertical Sync) signals and the generated pixel coordinates. The test bench was clocked using the 100MHz system clock, and the simulation was run long enough to observe at least two complete frames to confirm the stability of the VGA signals and the correct calculation of the pixel clock.

### 3. Simulation Snapshots

The module was simulated using a test bench to analyze the VGA synchronization signals (HS and VS). The measured values from the simulation, given a clock period of 10 ns per clock cycle, are recorded and analyzed below:



In this picture we can see the horizontal sync(HS), in which Gap between Successive Pulses is **3.2 K** (3200) clock cycles which is equals to 32000 ns which is time for one scanline.



We can see the vertical sync(VS). Gap between successive pulses is **1.68 Million** (1,680,000) clock cycles which is equals to 16,800,000 ns which shows the time for one videoframe.

**Timing Consistency Check:** The relationship provided,  $1 \text{ VS} = 525 \times 1\text{HS}$ , means one frame is composed of 525 scanlines. We can verify this relationship with the cycle counts:

$$\frac{\text{VS Cycles}}{\text{HS Cycles}} = \frac{1,680,000}{3,200} = 525$$

The measured cycle counts are perfectly consistent with the standard VGA timing resolution of  $640 \times 480$ (which uses 525 total lines per frame), confirming the correct functionality of the VGA\_driver module.

## 4. Synthesis Report

| Tcl Console                                                         | Messages    | Log       | Reports         | Design Runs | x DRC | Methodology | Power | Timing | ?                 | -        |                                                             |                                                                    |
|---------------------------------------------------------------------|-------------|-----------|-----------------|-------------|-------|-------------|-------|--------|-------------------|----------|-------------------------------------------------------------|--------------------------------------------------------------------|
| Q   $\frac{1}{2}$   $\frac{1}{3}$   $\frac{1}{4}$   <<   >>   +   % |             |           |                 |             |       |             |       |        |                   |          |                                                             |                                                                    |
| Solved Routes                                                       | Methodology | RQA Score | QoR Suggestions | LUT         | FF    | BRAM        | URAM  | DSP    | Start             | Elapsed  | Run Strategy                                                | Report Strategy                                                    |
| 0 <b>49 CW</b>                                                      |             |           |                 | 78          | 73    | 0           | 0     | 2      | 10/31/25, 5:34 PM | 00:00:33 | Vivado Synthesis Defaults (Vivado Synthesis 2022)           | Vivado Synthesis Default Reports (Vivado Synthesis 2022)           |
|                                                                     |             |           |                 | 130         | 84    | 14          | 0     | 2      | 10/31/25, 5:47 PM | 00:00:26 | Vivado Implementation Defaults (Vivado Implementation 2022) | Vivado Implementation Default Reports (Vivado Implementation 2022) |

The implementation uses 78 LUTs for all combinatorial logic, which includes the pixel boundary checks (for both background and car) and the critical 12-bit color multiplexer (MUX) that implements the transparency feature (comparing car\_color to PINK\_COLOR). The 73 Flip-Flops (FFs) are utilized for the synchronous sequential elements, such as the bg\_on, car\_on status flags, and the registered color pipeline (output\_color) required for stable VGA output. Crucially, the utilization report shows 0 BRAMs and 0 DSPs used by the Display\_sprite module itself. This confirms that the module is purely a control and logic path. The actual memory used for the background and car data is implemented via separate Block Memory Generator IP cores (which consume the FPGA's BRAM resources but are not attributed to this module's logic count), resulting in a highly efficient and resource-minimal design for image display.

## 5. On-Board Implementation

This implementation successfully displays the road background and the car sprite on the VGA, using a color multiplexer to achieve **sprite transparency** by replacing the car's pink background color with the corresponding background road color.



## **6. Conclusion**

Part I successfully achieved the objective of displaying a stationary background and a car sprite with functional transparency on the VGA display. The core achievement was the implementation of a prioritized color MUX within the Display\_sprite module that correctly overlays the car onto the road by treating the designated pink color as a transparent key. Simulation results verified the standard VGA timing relationship  $1VS = 525 \times 1HS$  with a line-time of  $32.0 \mu s$  and a frame-time of  $16.8 \text{ ms}$ .

## **7. Generated Schematic**

The Generated Schematic for part1 of this project is attached below

