

# 4-Bit Baugh-Wooley Multiplier (IMT2023620 Unnath Ch)

This project implements a 4-bit signed Baugh-Wooley multiplier on a Xilinx FPGA (tested on a Basys 3 board) using the Vivado Suite. It includes two top modules: one for on-chip debugging with VIO/ILA, and another for physical interaction using DIP switches and LEDs.

[Github Link](#)

## Demonstration & Results

Here are the VIO and ILA dashboards monitoring the multiplier on the FPGA, along with key implementation reports.

### VIO Dashboard

*Controlling inputs and viewing the product in real-time.*

### ILA Waveform

*Capturing signal transitions for timing analysis.*



### Timing Summary Report

### Power Report



# Setup for VIO & ILA Debugging

This guide explains how to configure the project for on-chip debugging using Vivado's VIO and ILA IP cores.

## 1. Source File Hierarchy

First, ensure your project sources are set up correctly. The `top_vio_ilab` module should be set as the top-level module for this configuration.

```

└ Design Sources (4)
  └ top_vio_ilab (top_vio_ilab.v) (3)
    > multiplier_inst : baugh_wooley_4x4 (design.v) (20)
    > vio_inst : vio_0 (vio_0.xci)
    > ila_inst : ila_0 (ila_0.xci)
  └ top_dip_led (top_dip_led.v) (1)
    > multiplier_inst : baugh_wooley_4x4 (design.v) (20)
    & bw_gray_cell (design.v)
    & bw_white_cell (design.v)
  Constraints (1)
  & constrs_1 (1)
    constraints.xdc
  Simulation Sources (5)
  & sim_1 (5)
    & baugh_wooley_4x4_tb (testbench.v) (1)
      > uut : baugh_wooley_4x4 (design.v) (20)
    & top_vio_ilab (top_vio_ilab.v) (3)
      > multiplier_inst : baugh_wooley_4x4 (design.v) (20)
      > vio_inst : vio_0 (vio_0.xci)
      > ila_inst : ila_0 (ila_0.xci)
    & top_dip_led (top_dip_led.v) (1)
      > multiplier_inst : baugh_wooley_4x4 (design.v) (20)
      & bw_gray_cell (design.v)
      & bw_white_cell (design.v)
  Utility Sources
  & utils_1

```

## 2. IP Core Configuration

You'll need to add and configure two IP cores from the IP Catalog as follows:

| IP Core | Port       | Width | Direction | Purpose                             |
|---------|------------|-------|-----------|-------------------------------------|
| VIO     | probe_in0  | 8-bit | Input     | Monitors the 8-bit product <b>p</b> |
|         | probe_out0 | 4-bit | Output    | Controls the 4-bit input <b>a</b>   |
|         | probe_out1 | 4-bit | Output    | Controls the 4-bit input <b>b</b>   |
| ILA     | probe0     | 4-bit | Input     | Captures the signal <b>a</b>        |
|         | probe1     | 4-bit | Input     | Captures the signal <b>b</b>        |

| IP Core | Port   | Width | Direction | Purpose               |
|---------|--------|-------|-----------|-----------------------|
|         | probe2 | 8-bit | Input     | Captures the signal p |

### 3. Implementation Flow

- Create IP Cores:** Follow the detailed steps below to generate the VIO and ILA cores.
- Set Top Module:** Right-click `top_vio_ila.v` in the Sources window and select **Set as Top**.
- Configure Constraints:** Open `constraints.xdc` and uncomment the clock constraint for your board.  
**Only the clock constraint should be active.**

```
# For Basys3 board:
set_property -dict { PACKAGE_PIN W5    IO_STANDARD LVCMOS33 } [get_ports clk]
create_clock -add -name sys_clk_pin -period 10.00 -waveform {0 5} [get_ports clk]
```

- Run Full Flow:** Run **Synthesis**, **Implementation**, and **Generate Bitstream**.
- Program & Debug:** Open **Hardware Manager**, program the FPGA, and the VIO/ILA dashboards will be available for debugging.

## Setup for DIP Switch & LED Usage

If you prefer to use physical switches and LEDs instead of the on-chip debugger:

- Set Top Module:** In the Sources window, right-click `top_dip_led.v` and select **Set as Top**.
- Update Constraints:** Open `constraints.xdc` and ensure the pin assignments for the **DIP switches** (inputs a and b) and **LEDs** (output p) are uncommented. The VIO/ILA clock constraint should be commented out.
- Re-run Flow:** Run **Synthesis**, **Implementation**, and **Generate Bitstream**.
- Program FPGA:** Program the device with the new bitstream. You can now control the multiplier with switches and see the result on the LEDs.

## Troubleshooting

- VIO/ILA not in Hardware Manager?** Ensure `top_vio_ila` was set as the top module *before* you generated the bitstream. Reprogram the device.
- Synthesis fails with "vio\_0 not found"?** The VIO IP was not generated correctly. In the Sources window, right-click `vio_0.xci` → **Generate Output Products**.
- Clock constraint errors?** Make sure you have uncommented **only one** clock constraint in `constraints.xdc` and that the pin assignment (W5, E3, etc.) matches your specific FPGA board.