

# Computer System Design Lab

## Tutorial 1

Xilinx Schematic Editor

Xilinx ISim

1-bit and 4-bit Full Adder

Visual Walkthrough

Create New Project

Create Schematic

Simulate

Create Schematic Symbol

Please leave this handout in the lab. It will be available  
in Blackboard soon.







## New Project Wizard

### Project Summary

Project Navigator will create a new project with the following specifications.

#### Project:

Project Name: tutorial\_1

Project Path: [REDACTED]\Xilinx\ISE\tutorial\_1

Working Directory: [REDACTED]\Xilinx\ISE\tutorial\_1

Description:

Top Level Source Type: HDL

#### Device:

Device Family: Spartan6

Device: xc6slx45

Package: csg324

Speed: -3

**Check to make sure  
everything looks right. (Or  
just click 'Finish'.**

Top-Level Source Type: HDL

Synthesis Tool: XST (VHDL/Verilog)

Simulator: ISim (VHDL/Verilog)

Preferred Language: Verilog

Property Specification in Project File: Store all values

Manual Compile Order: false

VHDL Source Analysis Standard: VHDL-93

Message Filtering: disabled

More Info

Finish

Cancel





In many places in the rest of this tutorial, you will see references to the old device we used in previous years:

xc5vlx110t-3ff1136

Starting in Spring 2015, this should be:

xc6slx45-3csg324



















































➤ New Source Wizard

### Select Source Type

Select source type, file name and its location.

- BMM File
- ChipScope Definition and Connection File
- Implementation Constraints File
- IP (CORE Generator & Architecture Wizard)
- MEM File
- Schematic
- User Document
- Verilog Module
- Verilog Test Fixture
- VHDL Module
- VHDL Library
- VHDL Package
- VHDL Test Bench
- Embedded Processor

Select 'Verilog Test Fixture'  
and name it fulladd\_testbench

File name:

fulladd\_testbench

Location:

\tutorial\_1

Add to project

Click Next...

More Info

Next

Cancel





```
1 // Verilog test fixture created from schematic C:\Users\Chris\Xilinx\ISE\tutorial_1\fulladd
2
3 `timescale 1ns / 1ps
4
5 module fulladd_fulladd_sch_tb();
6
7 // Inputs
8
9 // Output
10
11 // Bidirs
12
13 // Instantiate the UUT
14     fulladd UUT (
15
16 );
17 // Initialize Inputs
18     `ifdef auto_init
19         initial begin
20             `endif
21     endmodule
22
```

It will open a new tab in the work area, which will have the generated Verilog code. We will modify this for our tests.

```
1 // Verilog test fixture created from schematic C:\Users\Chris\Xilinx\ISE\tutorial_1\full
2
3 `timescale 1ns / 1ps
4
5 module fulladd_fulladd_sch_tb();
6
7 // Inputs
8 reg C_in;
9 reg A_in;
10 reg B_in;
11
12 // Output
13 wire S_out;
14 wire C_out;
15
16 // Bidirs
17
18 // Instantiate the UUT
19 fulladd UUT (
20     .C_in(C_in),
21     .A_in(A_in),
22     .B_in(B_in),
23     .S_out(S_out),
24     .C_out(C_out)
25 );
26 // Initialize Inputs
27 `ifdef auto_init
28     initial begin
29         C_in = 0;
30         A_in = 0;
31         B_in = 0;
32     `endif
33 endmodule
```

Declares the inputs and outputs for the testbench. These do not have to match the inputs/outputs for your design, but these are the names the simulator will use.

Inputs are type 'reg' and outputs are type 'wire'

This maps the registers and wires in the testbench with the inputs/outputs of the fulladd schematic. The name after the dot is the name of the fulladd input/output, and the name in parentheses is the name of the wire/reg in the testbench that it connects to.

This sets the initial values of the inputs to zero.

A new tab will open in the Work Area which contains the Verilog code for the testbench.

Xilinx automatically generates some of the testbench design.

```
15
16 // Bidirs
17
18 // Instantiate the UUT
19     fulladd UUT (
20         .C_in(C_in),
21         .A_in(A_in),
22         .B_in(B_in),
23         .S_out(S_out),
24         .C_out(C_out)
25     );
26 // Initialize Inputs
27 initial begin
28     A_in=0;
29     B_in=0;
30     C_in=0;
31
32     #100;           Wait 100 ns
33
34     C_in=1;          Set C_in to 1
35
36     #100;           Wait 100 ns
37
38     A_in=1;          Set C_in to 1
39
40     #100;           Wait 100 ns
41
42     B_in=1;          Set C_in to 1
43
44     #100;           Wait 100 ns
45 end
46
47 endmodule
```

Remove the 'ifdef auto\_init' and 'endif' lines. We will not use them, since we initialize manually.

Set A\_in, B\_in and C\_in to 0.

Add the code as shown here between 'initial begin' and 'endmodule'

Wait 100 ns

Set C\_in to 1

Wait 100 ns

Set C\_in to 1

Wait 100 ns

Set C\_in to 1

Wait 100 ns

Done



























New Source Wizard

Select Source Type

Select source type, file name and its location.

- BMM File
- ChipScope Definition and Connection File
- Implementation Constraints File
- IP (CORE Generator & Architecture Wizard)
- MEM File
- Schematic
- User Document
- Verilog Module
- Verilog Test Fixture
- VHDL Module
- VHDL Library
- VHDL Package
- VHDL Test Bench
- Embedded Processor

Create a new Verilog Test  
Fixture and name it  
**fulladd4\_testbench**

File name:

fulladd4\_testbench

Location:

C:\Users\...\tutorial\_1

Add to project

More Info

Next

Cancel



ISE Project Navigator (O.87xd) - C:\Users\challa1\Xilinx\tutorial\_10\tutorial\_10.xise - [fulladd4\_testbench.v]

File Edit View Project Source Process Tools Window Layout Help

Design Implementation Simulation

Hierarchy

View: Implementation Simulation

Behavioral

tutorial\_10  
  xc6sx5-3csg24  
    fulladd4\_fulladd4\_sch\_tb (fulladd4\_testbench.v)  
      UUT - fulladd4 (fulladd4.sch)  
        XLXI\_1 - fulladd (fulladd.sch)  
        XLXI\_2 - fulladd (fulladd.sch)  
        XLXI\_3 - fulladd (fulladd.sch)  
        XLXI\_4 - fulladd (fulladd.sch)  
    fulladd4\_fulladd\_sch\_tb (fulladd\_testbench.v)  
      UUT - fulladd (fulladd.sch)

4  
5   module fulladd4\_fulladd4\_sch\_tb();  
6  
7   // Inputs  
8    reg [3:0] A\_in;  
9    reg [3:0] B\_in;  
10   reg C\_in;  
11  
12   // Output  
13    wire [3:0] S\_out;  
14    wire C\_out;  
15  
16   // Bidirs  
17  
18   // Instantiate the UUT  
19    fulladd4 UUT (  
20      .A\_in(A\_in[3:0]),  
21      .B\_in(B\_in[3:0]),  
22      .C\_in(C\_in),  
23      .S\_out(S\_out[3:0]),  
24      .C\_out(C\_out)  
25  );  
26   // Initialize Inputs  
27  
28    initial begin  
29      A\_in = 0;  
30      B\_in = 0;  
31      C\_in = 0;  
32  
33      #100;  
34  
35      A\_in = 4;  
36      B\_in = 3;  
37  
38      #100;  
39  
40      A\_in = 2;  
41      B\_in = 3;  
42      C\_in = 1;  
43  
44      #100;  
45  
46      A\_in = 7;  
47  
48    end  
49  
50 endmodule

No Processes Running

Processes: fulladd4\_fulladd4\_sch\_tb  
  iSim Simulator  
    Behavioral Check Syntax  
    Simulate Behavioral Model

Design Files Libraries Symbols Options

ISE Design Suite InfoCenter Design Summary fulladd\_testbench.v C:\Users\challa1\Xilinx\tutorial\_10\fulladd4.sch fulladd4\_testbench.v Support Keyword Search fulladd.sch

Errors

Ln 22 Col 20 | Verilog



## On your own:

- Create a schematic symbol for the 4-bit adder.
- Create an 8-bit adder from two 4-bit adders. (You do not need to make a symbol)