

Digital Systems 1 UT

2021-3-15



CA 1 Melika Minaei Bidgoli

Generate a 2-input CMOS NAND gate and verify its timing and functionality. Write the SystemVerilog description of this structure using NMOS and PMOS transistors. Use #(3,4,5) delay for the NMOS transistors and #(5,6,7) for the PMOS transistors. Generate a testbench for this circuit in SystemVerilog and examine it for various input changes. Among the various input changes, make sure you test the circuit for the worst-case delay of its output making To1 and To0 transitions. Make sure the time distance between your input changes is much larger than the gate delay values.

#### solution



```
'timescale lns/lns
                                    module NAND gate with transistors (input a, b, output w);
       3
                                                                                                                  supply1 VDD;
       4
                                                                                                                 supply0 GND;
       5
                                                                                                                 wire i:
       6
                                                                                                                 pmos# (5, 6, 7) T1 (w, VDD, a);
       7
                                                                                                                  pmos# (5, 6, 7) T2 (w, VDD, b);
      8
                                                                                                             nmos# (3, 4, 5) T3 (w, i, a);
                                                                                                                  nmos# (3, 4, 5) T4 (i, GND, b);
      9
10
                                          endmodule
                                                                                                                                                                                  When with transistors Q1(a, b, w): initial begin a = 0; b = 0; b = 0; b = 0; a = 0; a = 0; b = 0; a = 
                                                                                                                                                                                    a = 1; b = 0;

$100; a = 0; b = 1; $50;

a = 1; b = 0;

$100; a = 0; b = 0; $50;

a = 1; b = 0;

$100; a = 1; b = 1; $50;
                                                                                                                                                                                  #100; a = 1; b = 1;

#100; a = 0; b = 1; #50;

a = 1; b = 1;

#100; a = 1; b = 0; #50;

a = 1; b = 1;

#100; a = 0; b = 0; #50;
```

Generate a CMOS Tri-State Buffer (functionality like NOTIF1 of SystemVerilog) using four transistors for the buffer and two for its inverter. Generate a testbench for this circuit in SystemVerilog and examine it for various input changes. You are allowed to use inverts as needed. Among the various input changes, make sure you test the circuit for the worst-case delay of its output making To1, To0, and ToZ transitions. Make sure the time distance between your input changes is much larger than the gate delay values.

#### solution

```
NOTIF1:
                                            : 14 05
                                             :10 ns
    module Tristatebuffer with transistors(input a, en, output w);
18
               supplyl VDD:
19
               supply0 GND;
10
               wire w1, w2, w3;
11
               pmos# (5, 6, 7) Tl (wl, VDD, a);
               pmos# (5, 6, 7) T2 (w, w1, w3);
13
               nmos# (3, 4, 5) T3(w, w2, en);
14
               nmos# (3, 4, 5) T4 (w2, GND, a);
15
               nmos# (3, 4, 5) T5 (w3, VDD, en);
16
               pmos# (5, 6, 7) T6 (w3, GND, en);
       endmodule
```

Using NAND gates with as many inputs as needed based on that of Problem 1, generate a 4- to-1 MUX with two select inputs, s1 and s0, and four data inputs a, b, c, and d. Deduce gate delays based on your findings of Problem 1. Generate a testbench for this circuit in SystemVerilog and examine it for various input changes. Among the various input changes, make sure you test the circuit for the worst-case delay of its output making To1 and To0. Make sure the time distance between your input changes is much larger than the gate delay values.

#### solution



Using the Tri-State Buffer of Problem 2, generate a 4-to-1 MUX with two select inputs, s1 and s0, and four data inputs a, b, c, and d. Generate a testbench for this circuit in SystemVerilog and examine it for various input changes.

Among the various input changes, make sure you test the circuit for the worst-case delay of its output making To1 and To0 transitions. Make sure the time distance between your input changes is much larger than the gate delay values.

### solution





# problem 5

In a testbench, instantiate the MUX circuits of Part 3 and Part 4 and compare the timing of these circuits. Explain the differences between these two circuits as far as the number of transistors and other physical parameters such as power consumption.

