## Start a new project



Create ngc and test folders and download pwm\_tx.ngc, pwm\_tx.v, pwm\_rx.ngc, pwm\_rx.v to ngc and pwm\_loop\_test.v to test.





# Download pwm\_loop.v to project directory and add as a source





Notice u1 and u2 in the Hierarchy have? because ISE does not know what file to use for them.

### add all files in ngc folder





Notice u1 and u2 no longer have?

#### Add test file



# Create post translate simulation model and simulate





## Modify top level

```
module pwm_loop(
    input wire
                       clock,
    input wire
                       reset,
1 // input wire [15:0] data in,
5 // output wire
5 // output wire [15:0] data out,
7 // output wire [15:0] period,
3 // output wire
                         done rx,
  input wire [3:0] switches,
) output wire [3:0] leds,
l input wire
                       loop in,
output wire
                      loop_out);
  wire
                [15:0] data in;
 wire
                [15:0] data out;
5 // wire
                        loop;
    assign leds = data out[9:6];
    assign data in = {6'b000000, switches, 6'b000000);
) // assign loop out = loop;
    pwm tx u1 (
     .clock(clock),
     .reset (reset),
     .data(data in),
     .tx(loop out),
      .done(done tx));
    pwm rx u2 (
      .clock(clock),
      .reset (reset),
     .rx(loop in),
      .data(data out),
      .period(period),
      .done(done rx));
  endmodule
```

#### Create a UCF

```
1 NET clock LOC = C10 | IOSTANDARD = LVCMOS33;
 2 NET clock TNM NET = clock net;
 3 TIMESPEC TS clock = PERIOD clock net 100000.0 kHz;
 5 NET reset LOC = V4 | IOSTANDARD=LVCMOS33 | PULLDOWN;
   NET reset TIG;
 8 NET leds[0] LOC = P4 | IOSTANDARD = LVCMOS18;
 9 NET leds[1] LOC = L6 | IOSTANDARD = LVCMOS18;
10 NET leds[2] LOC = F5 | IOSTANDARD = LVCMOS18;
11 NET leds[3] LOC = C2 | IOSTANDARD = LVCMOS18;
12
13 NET switches[0] LOC = B3 | IOSTANDARD = LVCMOS33 | PULLDOWN;
14 NET switches[1] LOC = A3 | IOSTANDARD = LVCMOS33 | PULLDOWN;
15 NET switches[2] LOC = B4 | IOSTANDARD = LVCMOS33 | PULLDOWN;
16 NET switches[3] LOC = A4 | IOSTANDARD = LVCMOS33 | PULLDOWN;
17
18 NET loop out LOC = F15 | IOSTANDARD = LVCMOS33;
19 NET loop in LOC = F16 | IOSTANDARD = LVCMOS33;
20
21 CONFIG VCCAUX = 3.3;
22
```

### Generate bit and run