#### EECS150 - Digital Design

## <u>Lecture 8 - CMOS Implementation</u> <u>Technologies</u>

Feb 11, 2010 John Wawrzynek

Spring 2010 EECS150 - Lec8-cmos Page 1

#### Mux4 Testbench

```
module testmux4;
reg [5:0] count = 6'b000000;
                                     Declaration and initialization all at once.
                                    Generally not available in synthesis.
  reg a, b, c, d, expected;
  reg [1:0] S;
           -, DUT instantiation
  wire f;
 mux4|myMux (.select(S), .in0(a), .in1(b), .in2(c), .in3(d), .out(f));
                  Enumerate all possible input patterns.
    begin
     repeat(64)
                                        Apply pattern to DUT
         begin
           2'b00: expected = a;
            2'b01: expected = b;
                                        $strobe displays data at a selected time. That
            2'b10: expected = c;
                                        time is just before simulation time is
            2'b11: expected = d;
                                        advanced (after all other events).
          endcase // case(S)
         expected=%b time=%d", S, a, b, c, d, f, expected, $time);
          #2 count = count + 1'b1;
                                           Delay to allow mux outputs to stabilize.
       end
                Wait a bit, then bump count.
                                           Here we assume mux delay < 8ns.
       $stop;
    end
                                          Alternative to $strobe in this case,
endmodule
                                            #8 if (f != expected) $display("Mismatch: ...);
     Spring 2010
                                  EECS150 - Lec8-cmos
```

**FSM Testbench Example** 

```
in=0
module testFSM;
                                  Test all arcs.
 reg in;
 wire out;
                                                                   IDLE
 reg clk=0, rst;
                                                                   out=0
                    DUT instantiation
 reg expect;
                                                                                in=0
 FSM1 myFSM (.out(out), .in(in), .clk(clk), .rst(rst));
 always #5 clk = clk; 100MHz clk signal
                                                                    in=1
                                                                                     in=1
  initial
                                                           S0
                                                                              S1
   begin
                                  start in IDLE
                                                          out=0
                                                                             out=1
     rst=1;
                                                                    in=1
      #10 in=0; rst=0; expect=0; self-loop
      #10 in=1; rst=0; expect=0; transition to S0
      #10 in=0; rst=0; expect=0; transition to IDLE
      #10 in=1; rst=0; expect=0; transition to S0
      #10 in=1; rst=0; expect=1; transition to S1
      #10 in=1; rst=0; expect=1; self-loop
                                                        Note: Input changes are forced to
                                                        occur on negative edge of clock.
      #10 in=0; rst=0; expect=0; transition to IDLE
   end
                            Strobe output occurs 1ns
  always
                            before rising edge of clock.
   begin
      #4 $strobe($time, in=%b, rst=%b, expect=%b out=%b", in, rst, expect, out);
      #6:
   end
                  FSM Verification/Debug is easier if you have access to state value
endmodule
                  also. Either 1) bring out to ports, or 2) use waveform viewer.
```

#### Final Words (for now) on Simulation

Testing is not always fun, but you should view it as part of the design process. Untested potentially buggy designs are a dime-a-dozen. Verified designs more rare and have real value.

Devising a test strategy is an integral part of the the design process. It shows that you have your head around the design. It should not be an afterthought.

#### **Overview of Physical Implementations**

The stuff out of which we make systems.

- Integrated Circuits (ICs)
  - Combinational logic circuits, memory elements, analog interfaces.
- Printed Circuits (PC) boards
  - substrate for ICs and interconnection, distribution of CLK, Vdd, and GND signals, heat dissipation.
- Power Supplies
  - Converts line AC voltage to regulated DC low voltage levels.
- Chassis (rack, card case, ...)
  - holds boards, power supply, fans, provides physical interface to user or other systems.
- Connectors and Cables.

Spring 2010 EECS150 - Lec8-cmos Page 5

#### **Printed Circuit Boards**



#### Multichip Modules (MCMs)

 Multiple chips directly connected to a substrate. (silicon, ceramic, plastic, fiberglass) without chip packages.

#### **Integrated Circuits**



#### Chip in Package



- Package provides:
  - spreading of chip-level signal paths to board-level
  - heat dissipation.
- Ceramic or plastic with gold wires.

Spring 2010 EECS150 - Lec8-cmos Page 7

#### **Integrated Circuits**

Moore's Law has fueled innovation for the last 3 decades.



- "Number of transistors on a die doubles every 18 months."
- What are the consequences of Moore's law?

#### **Chip-level Function Implementation Alternatives**

All circuits/transistor layouts Full-custom:

optimized for application.

Arrays of small function blocks Standard-cell:

(gates, FFs) automatically placed

and routed.

Gate-array/structured-ASIC: Partially prefabricated wafers

customized with metal layers.

**ASIC** 

FPGA: Prefabricated chips customized

with switches and wires.

GPP (general purpose processor): fixed architecture

customized through software.

Domain Specific Processor: (Digital Signal Processor, Network Processor, Graphics Processing Unit).

What are the important metrics of comparison?

Spring 2010 EECS150 - Lec8-cmos Page 9

#### Why FPGAs?

A tradeoff exists between NRE\* cost and manufacturing costs:



The ASIC approach is only viable for products with very high volume (where NRE could be amortized), and which were not time to market (TTM) sensitive.

Cross-over point has moved to the right (favoring FPGA) implementation as ASIC NREs have increased.

\*Non-recurring Engineering Costs

#### **CMOS Devices**

MOSFET (Metal Oxide Semiconductor Field Effect Transistor).



The gate acts like a capacitor. A high voltage on the gate attracts charge into the channel. If a voltage exists between the source and drain a current will flow. In its simplest approximation, the device acts like a switch.



Spring 2010

EECS150 - Lec8-cmos

Page 11

Page 12

#### **Transistor-level Logic Circuits**

# Inverter (NOT gate):

Note:

out = 0 iff a AND b =1 therefore
 out = (ab)'

NAND gate:

• pFET network and nFET networks are duals of one another.

How about AND gate?

#### **Transistor-level Logic Circuits**

Simple rule for wiring up MOSFETs:

nFET is used only to pass logic zero. pFET is used only to pass logic one.

For example, consider the NAND gate:



Note: This rule is sometimes violated by expert designers under special conditions.

Spring 2010 EECS150 - Lec8-cmos Page 13

#### **Transistor-level Logic Circuits**



Note:

- out = 0 iff a OR b = 1 therefore out = (a+b)'
- · Again pFET network and nFET networks are duals of one another.

Other more complex functions are possible. Ex: out = (a+bc)'

#### **CMOS Logic Gates in General**



#### **Transmission Gate**

- Transmission gates are the way to build "switches" in CMOS.
- In general, both transistor types are needed:
  - nFET to pass zeros.
  - pFET to pass ones.
- · The transmission gate is bi-directional (unlike logic gates).



 Does not directly connect to Vdd and GND, but can be combined with logic gates or buffers to simplify many logic structures.

#### **Transmission-gate Multiplexor**

#### 2-to-multiplexor:

$$C = sa + s'b$$



### Switches simplify the implementation:





Compare the cost to logic gate implementation.

Spring 2010 EECS150 - Lec8-cmos Page 17

#### 4-to-1 Transmission-gate Mux



- The series connection of pass-transistors in each branch effectively forms the AND of s1 and s0 (or their complement).
  - Compare cost to logic gate implementation

· Lec8-cmos Page 18

#### Alternative 4-to-1 Multiplexor

- This version has less delay from in to out.
- In both versions, care must be taken to avoid turning on multiple paths simultaneously (shorting together the inputs).



Spring 2010 EECS150 - Lec8-cmos Page 19

#### **Tri-state Buffers**



#### **Tri-state Buffers**



Tri-state buffers enable "bidirectional" connections.



Tri-state buffers are used when multiple circuits all connect to a common wire. Only one circuit at a time is allowed to drive the bus. All others "disconnect" their outputs, but can "listen".



Spring 2010 EECS150 - Lec8-cmos Page 21

#### **Tri-state Based Multiplexor**

#### Multiplexor



#### If s=1 then c=a else





Transistor Circuit for inverting multiplexor:



#### **Latches and Flip-flops**

#### Positive level-sensitive latch:





## Positive Edge-triggered **flip-flop** built from two level-sensitive latches:



#### Latch Implementation:

