

**Lecture and Hands-on Workshop on Design for Test (DFT)**

**Laboratory:  
Importing Modules, Pin Assignment via QSF, and  
Signal Verification in Simulation and on the DE10-  
Standard FPGA**

Electronics Engineering Department, Costa Rica Institute of Technology

Intel, Costa Rica

2025

# General Lecture and Workshop Content

| Module 1                                                      | Module 2                                              | Module 3                      |
|---------------------------------------------------------------|-------------------------------------------------------|-------------------------------|
| Semiconductor fabrication and assembly of integrated circuits | High volume manufacturing test approaches             | Hands-on labs on testing      |
| Testing of integrated circuits                                | Structural and automated test approaches              | DFT CAD Tools                 |
| Automated test equipment                                      | Automated test pattern generation and standardization | FPGA-based DFT implementation |
| Introduction to high volume manufacturing flow                | Functional content                                    |                               |

# Outline

- **Laboratory**

# Create project

1. Create new LabFPGA2 project
2. Import **LabFPGA2.sv** module



```
module LabFPGA2 #(  
    parameter int WIDTH = 24,  
    parameter int DIVIDER = 20e6  
) (  
    input logic  
    input logic [3:0]  
    input logic [3:0]  
    output logic [3:0]  
    output logic [41:0]  
    output logic [1:0]  
    output logic  
);  
    clk_i,  
    rst_i,  
    en_reg_i,  
    sw_reg_b_i,  
    slct_op_i,  
    slct_byte_i,  
    slct_sb_i,  
    cntrl_alu_i,  
    op_i,  
    flag_o,  
    display_o,  
    counter_slct_op_o,  
    counter_slct_byte_o,  
    sb_op_o
```

# Pin Assignment via QSF

1. Open **LabFPGA2\_pinout.qsf**
2. Assign the signals to the corresponding pins
3. Import the **LabFPGA2\_pinout.qsf**

No signal assigned

```
# -----#
# Clock
#   set_location_assignment PIN_AF14 -to clk
# -----
# -----
# Clock
#   set_location_assignment PIN_AF14 -to clk_i
# -----#
```

Signal assigned

```
# Slide Switches

#SW[0]
  set_location_assignment PIN_AB30 -to op_i[0]
#SW[1]
  set_location_assignment PIN_Y27 -to op_i[1]
#SW[2]
  set_location_assignment PIN_AB28 -to op_i[2]
#SW[3]
  set_location_assignment PIN_AC30 -to op_i[3]
#SW[4]
  set_location_assignment PIN_W25 -to sw_reg_b_i
#SW[5]
  set_location_assignment PIN_V25 -to cntrl_alu_i[0]
#SW[6]
  set_location_assignment PIN_AC28 -to cntrl_alu_i[1]
#SW[7]
  set_location_assignment PIN_AD30 -to cntrl_alu_i[2]
#SW[8]
  set_location_assignment PIN_AC29 -to cntrl_alu_i[3]
#SW[9]
  set_location_assignment PIN_AA30 -to rst_i
```

# Peripherals



# ModelSim Simulation

- Modify the testbench

```
// === Main test sequence ===
initial begin

    // Initialize all control signals
    rst = 1;
    en_reg_i = 1;
    sw_reg_b_i = 0;
    slct_op_i = 1;
    slct_byte_i = 1;
    slct_sb_i = 1;
    cntrl_alu_i = 0;
    op_i = 0;
    #10;

    // Apply reset pulse
    rst = 0;
    #20;
    rst = 1;
    #30;

    // Test case 1: A = 0x005A5, B = 0x00A5A, operation = ADD (0)
    calc(4'd0, 24'h5A5, 24'hA5A);

    // Continue your code here....

    // Test case 2: A = 0x00xxx, B = 0x00xxx, operation = ? (x)
    // calc(4'dx, 24'hxxx, 24'hxxx);

    $finish;
end
```

# ModelSim Simulation

- Create a new Project
- Import **LabFPGA2\_sim.sv** and **tb\_LabFPGA2.sv**



# ModelSim Simulation

- *Compile* Project



A screenshot of a table showing the status of the compiled files. The columns are labeled 'Name', 'Status', 'Type', and 'Order'. The table contains two rows, both of which are marked as successful (indicated by green checkmarks). A red box highlights the 'Status' column header.

| Name            | Status    | Type | Order |
|-----------------|-----------|------|-------|
| tb_LabFPGA2.sv  | ✓ Syst... | 0    |       |
| LabFPGA2_sim.sv | ✓ Syst... | 1    |       |

# ModelSim Simulation

- *Simulate* Project



# ModelSim Simulation

- *Run simulation*



**TEC** | Tecnológico  
de Costa Rica

