# Switch-Level Models

3/29/04 & 4/8/04

Hardware Description Languages and Synthesis

1

### Primitives Supported by Verilog

| COMBINA                  | TIONAL LOG                 | IC GATES                 | SWITC                         | H-LEVEL PF           | RIMITIVES                         |
|--------------------------|----------------------------|--------------------------|-------------------------------|----------------------|-----------------------------------|
| Multi-<br>input<br>gates | Multi-<br>ou tput<br>gates | Three-<br>state<br>gates | MOS<br>transistor<br>switches | MOS<br>Pull<br>gates | MOS<br>Bi-directional<br>switches |
| and                      | buf                        | bufif0                   | nmos                          | pullup               | tran                              |
| nand                     | not                        | bufif1                   | pmos                          | pulldown             | tranif0                           |
| or                       |                            | notif0                   | cmos                          |                      | tranif1                           |
| nor                      |                            | notito                   | rnmos                         |                      | rtran                             |
| xor                      |                            |                          | rpmos                         |                      | rtranif0                          |
| xnor                     |                            |                          | rcmos                         |                      | rtranif1                          |

notif1

3/29/04 & 4/8/04



# Primitives for MOS Transistors

#### nmos, pmos

- rnmos, rpmos (resistive version)
- Terminal list: (drain, source, gate) (i.e., (output, input, control))
- Input-output relationship
  - L: 0 or z
  - H: 1 or z

|   |               | E |   | 1      |   |
|---|---------------|---|---|--------|---|
|   |               |   | C | ontrol |   |
|   | pmos<br>romos | 0 | 1 | x      | Z |
| i | 0             | 0 | Z | L      | L |
| n | 1             | 1 | z | н      | Н |
| p | x             | х | z | х      | x |
| ļ | Z             | z | z | Z      | z |

ctrl





# Static CMOS Circuits

- Implement pull-up logic by p-channel transistors
- Implement pull-down logic by n-channel transistors
- p-channel and n-channel transistors are turned on by complementary signal values
- When a transistors is
  - on: very low source-to-drain resistance (short circuit)
  - off: very high source-to-drain resistance (open circuit)
- No DC path between power and ground
  - static power dissipation is 0
  - power is consumed during switching of the input signal

#### Example: Inverter

(a) CMOS circuit, (b) in = 0, (c) in = 1



3/29/04 & 4/8/04

#### Verilog Model for CMOS Inverter

module cmos\_inverter (inv\_out, inv\_in);
output inv\_out;
input inv\_in;
supply0 GND;
supply1 PWR;

pmos (inv\_out, PWR, inv\_in);
nmos (inv\_out, GND, inv\_in);
endmodule

3/29/04 & 4/8/04

#### Example: 3-input nand Gate

module nand\_3 (Y, A, B, C); output Υ; A, B, C; input GND; supply0 supply1 PWR; wire w1, w2; (Y, PWR, A); pmos (Y, PWR, B); pmos (Y, PWR, C); pmos (Y, w1, A); nmos (w1, w2, B); nmos

(w2, GND, C);

 $V_{dd}$ 

nmos endmodule

3/29/04 & 4/8/04



### Alternative Loads

- Silicon area can be reduced by replacing pull-up logic by a single transistor which acts like a resistor
  - fabricated with a single type of transistors
  - penalized by DC power consumption
- Example (using nmos)
  - enhancement-mode: gate connected to drain
  - depletion mode: gate connected to source
  - (a) enhancement-mode, (b) depletion-mode, (c) resistive pull-up



3/29/04 & 4/8/04

#### Primitives for MOS Pull Gates

#### pullup, pulldown

- Both have a single port element which is to be pulled to 1 or 0
- Pull-up (pull-down) gate has a predefined strength of pull1 (pull0)
- Synthesis tools sometimes use pull-up and pulldown gates to tie unused set/rest inputs on flipflops
- Do not get confused with **tri0** and **tri1**

#### Example: 2-input nand Gate

#### nmos pull-down logic + depletion load pullup device



3/29/04 & 4/8/04

#### **CMOS** Transmission Gates



Primitives: cmos, rcmos (resistive version)
 Terminal list: (output, input, enable, ~enable)
 Example (transmission gate implemented by nmos and pmos primitives)

module Tgate\_str (data\_in, data\_out, n\_enable, p\_enable);
input data\_in, n\_enable, p\_enable;
output data\_out;

pmos (data\_out, data\_in, p\_enable);
nmos (data\_out, data\_in, n\_enable);
endmodule

3/29/04 & 4/8/04

# Example: Master-Slave D flip-flop with active-low clear

■ Use transmission gates and logic gates



13



3/29/04 & 4/8/04



# Verilog Model

```
module tgate_dflop (Q, Q_ , data, clock, clock_, clear_);
               input data, clock, clock_, clear_;
               output Q, Q_;
               wire w01, w1, w2, w3, w04,w4;
               assign w1 = w01;
               assign w4 = w04;
               cmos (w1, data, clock_, clock);
               nand #1 (w2, w1, clear_);
               not #1 (w3, w2);
               cmos (w01, w3, clock, clock_);
               cmos (w04, w2, clock, clock_);
               not #1 (Q, w4);
should be
               nand #1 (Q_, Q, clear_);
exchanged
               cmos (w4, Q_, clock_, clock);
            endmodule
                                                                     15
                       Hardware Description Languages
3/29/04 & 4/8/04
                              and Synthesis
```

# **Bi-Directional Switches**

- 2-terminal bi-directional switches
  - primitives: tran, rtran (resistive version)



one terminal may be declared as input or inout, and the other as inout or output

#### 3-terminal bi-directional switches

primitives: tranif0, tranif1, rtranif0 (resistive version),
 rtranif1 (resistive version)



- the third terminal is a control input 3/29/04 & 4/8/04 Hardware Description Languages and Synthesis



# Signal Strengths

- Verilog's logic system has logic values and logic strengths
- The strength of a signal refers to the ability to act as a driver determining the resultant logic value on a net
  - gives additional information that determines the result of contending drivers on a net when multiple drives are present, or when the nets are modeled as charge storage capacitors
- The signals in gate-level models are "strong" by default

# Strength Diagram



- supply0, strong0, pull0, weak0, highz0, supply1, strong1, pull1, weak1, highz1 may be assigned only to nets that are outputs of continuous assignments, combinational gates, or pull gates
- large0, medium0, small0, large1, medium1, small1 are "charge storage" strengths for nets of type trireg
- The strength of the output signal of a MOS transistor switch or bi-directional switch depends upon the switch type and the strength of the input signal (see page 25)

3/29/04 & 4/8/04



# Strength Specifications

- Two parts: strength for 0, and strength for 1
- When the logic value is known (0 or 1), the strength is one of the strengths (1, 2, ...7)
  - The integer associated with a strength indicates relative strength, with 7 being the highest
- When the logic value is z, the strength may be HiZ0 or HiZ1
- When the logic value is ambiguous (x), the strength may be in both sides of the scale
- Use "%v" in **\$display** or **\$monitor** to see the strength of a signal



#### Driven Nets

- Combinational logic primitives or pull gates
  - gate\_instantiation ::= [GATE\_TYPE] [drive\_strength] [delay]
    gate\_instance {, gate\_instance};
  - GATE\_TYPE: combinational logic gate or pull gate
  - drive\_strength: an unordered pair with one value from {supply0, strong0, pull0, weak0, highz0} and the other from {supply1, strong1, pull1, weak1, highz1}
- Continuous assignments
  - continuous\_assign ::= assign [drive\_strength] [delay] list\_of\_net\_assignments;
- Only scalar nets may receive strength assignments
- Examples
  - nand (pull1, strong0) a (out, in1, in2);
  - wire (pull0, weak1) b = c & d;
  - assign (pull1, weak0) e = f;

3/29/04 & 4/8/04

# Supply Nets

- Nets of supply0 (supply1) have predefined strength of supply0 (supply1)
- When a tri0 (tri1) net is not driven, it has the strength of pull0 (pull1)

### Charge Storage Nets

net\_declaration ::= trireg [vectored | scalared] [charge\_strength] [range] list\_of\_net\_identifiers

– charge\_strength: small, medium (default), or
 large capacitor



# Ambiguous Signals

- When the strength of a signal is ambiguous, it is a member of a set of two or more strengths, but the exact strength is not known
  - a signal may have a range of strengths
- Examples





3/29/04 & 4/8/04

#### Strength Reduction by Primitives

For a combinational primitive (except threestate gates) or pull primitive, the strength of the output is independent of the strength of the input

For a MOS transistor switch or MOS bidirectional transistor switch, the strength of the output depends upon the the strength of the input and the switch type

#### Transistor Switches and Bi-Directional Switches

#### ■ For **nmos**, **pmos**, **cmos**, **tran**, **tranif0**, or **tranif1**

- if data input signal has strength supply0 (supply1),
   then the strength of the output is strong0 (strong1)
- otherwise, the strength of the output remains the same as that of the input
- For a resistive switch (rnmos, rpmos, rcmos, rtran, rtranif0, or rtranif1), use the following rule



3/29/04 & 4/8/04

#### Known Strengths and Known Values

- When a net is driven by signals having known values and known strengths, the one having the greatest strength dominates
- Example



|          |     |     | Stre     | ngth     | ofLog | ic O     |     |      |      |     | Stre | ngth | of Log | jic 1    |          |     |
|----------|-----|-----|----------|----------|-------|----------|-----|------|------|-----|------|------|--------|----------|----------|-----|
| Signal_1 | 7   | 6   | 5        | <b>4</b> | 3     | <b>2</b> | 1   | 0    | 0    | 1   | 2    | 3    | 4      | <b>5</b> | <b>6</b> | 7   |
|          | Su0 | St0 | Pu0      | La0      | We0   | Me0      | Sm0 | HiZ0 | HiZ1 | Sm1 | Me1  | We1  | La1    | Pu1      | St1      | Su1 |
|          |     |     | Stre     | ngth     | ofLog | ic 0     |     |      | 1    |     | Stre | ngth | of Log | lic 1    |          |     |
| Signal_2 | 7   | 6   | 5        | 4        | 3     | <b>2</b> | 1   | 0    | 0    | 1   | 2    | 3    | 4      | <b>5</b> | 6        | 7   |
|          | Su0 | St0 | Pu0      | La0      | We0   | Me0      | Sm0 | HiZ0 | HiZ1 | Sm1 | Me1  | We1  | La1    | Pu1      | St1      | Su1 |
|          |     |     | Stre     | ngth     | ofLog | ic 0     |     |      | ,    |     | Stre | ngth | of Log | lic 1    |          |     |
| Result   | 7   | 6   | <b>5</b> | 4        | 3     | <b>2</b> | 1   | 0    | 0    | 1   | 2    | 3    | 4      | 5        | 6        | 7   |
|          | Su0 | St0 | Pu0      | La0      | We0   | Me0      | Sm0 | HiZO | HiZ1 | Sm1 | Me1  | We1  | La1    | Pu1      | St1      | Su1 |

3/29/04 & 4/8/04

#### Known Strengths and Known Values

- When a net is driven by signals having same value and identical strength, the net has that value and strength
- When a net is driven by signals having same value, the net has that value and the strength of the greatest of the drivers
- When a net is driven by signals having same strength but different values, the value of the net depends upon the net type
  - if the type is wand, wor, triand or trior, the value is determined by the rules associated with the net type (see page 36)
  - otherwise, the value is x, and the strength is the range of all strengths between the greatest strength of each

3/29/04 & driver

# Example

Same strength and opposing values in two drivers => ambiguous value and strength in the driven net



3/29/04 & 4/8/04

# Ambiguous Strengths

- When two signals having ambiguous strengths drive the same net, the resultant strength of the net is also ambiguous and has the range including all of the strengths of the drivers
- Example



|          |     |     | Stre     | ngth | ofLog | ic 0     |     |      |      |          | Stre | ength o | of Log | lic 1    |     |     |
|----------|-----|-----|----------|------|-------|----------|-----|------|------|----------|------|---------|--------|----------|-----|-----|
| Result_1 | 7   | 6   | <b>5</b> | 4    | 3     | 2        | 1   | 0    | 0    | 1        | 2    | 3       | 4      | <b>5</b> | 6   | 7   |
|          | Su0 | St0 | Pu0      | La0  | We0   | Me0      | Sm0 | HiZ0 | HiZ1 | Sm1      | Me1  | We1     | La1    | Pu1      | St1 | Su1 |
|          |     |     | Stre     | ngth | ofLog | ic 0     |     |      |      |          | Stre | ength o | of Log | lic 1    |     |     |
| Result_2 | 7   | 6   | 5        | 4    | 3     | 2        | 1   | 0    | 0    | 1        | 2    | 3       | 4      | 5        | 6   | 7   |
|          | Su0 | St0 | Pu0      | La0  | We0   | Me0      | Sm0 | HiZ0 | HiZ1 | Sm1      | Me1  | We1     | La1    | Pu1      | St1 | Su1 |
|          | [   |     | Stre     | ngth | ofLog | ic 0     |     |      | 1    | 310      | Stre | ength   | ofLog  | jic 1    |     |     |
| Result   | 7   | 6   | 5        | 4    | 3     | <b>2</b> | 1   | 0    | 0    | <b>1</b> | 2    | 3       | 4      | <b>5</b> | 6   | 7   |
|          | Su0 | St0 | Pu0      | La0  | We0   | Me0      | Sm0 | HiZ0 | HiZ1 | Sm1      | Me1  | We1     | La1    | Pu1      | St1 | Su1 |

3/29/04 & 4/8/04



#### Sub-Example



reg reg\_ena, reg\_value;

wire Result\_1;

```
pulldown (Result_1);
```

```
nmos (Result_1, reg_value, reg_ena);
```

3/29/04 & 4/8/04

#### Sub-Example



reg reg1\_value, reg2\_value, reg\_enb; pullup (Vcc); wire Result\_2; nmos (Result\_2, Vcc, reg\_enb); nor (strong0, weak1) (Result\_2, reg1\_value, reg2\_value);

3/29/04 & 4/8/04

#### Complete Example



|          | 1000     | 0.0      | 1.00     |          | 1        |                 | 10       | 11120     | 1.021     | 10/11/   | 11101    | 1101     |          | 1.01     | Ou       | 1 our    |
|----------|----------|----------|----------|----------|----------|-----------------|----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|
|          |          |          | Stre     | ngth     | of Log   | ic 0            |          |           |           |          | Stre     | ength    | ofLog    | ic 1     | -        |          |
| Result_1 | 7<br>Su0 | 6<br>St0 | 5<br>Pu0 | 4<br>La0 | 3<br>We0 | <b>2</b><br>Me0 | 1<br>Sm0 | 0<br>HiZ0 | 0<br>HiZ1 | 1<br>Sm1 | 2<br>Me1 | 3<br>We1 | 4<br>La1 | 5<br>Pu1 | 6<br>St1 | 7<br>Su1 |
|          |          |          | Stre     | ngth     | of Log   | ic 0            |          |           |           |          | Stre     | ength    | ofLog    | lic 1    |          |          |
| Result   | 7<br>Su0 | 6<br>St0 | 5<br>Pu0 | 4<br>La0 | 3<br>We0 | 2<br>Me0        | 1<br>Sm0 | 0<br>HiZO | 0<br>HiZ1 | 1<br>Sm1 | 2<br>Me1 | 3<br>We1 | 4<br>La1 | 5<br>Pu1 | 6<br>St1 | 7<br>Su1 |

3/29/04 & 4/8/04

#### Combining a Signal Having Known Strength and Known Value with a Signal Having Ambiguous Strength

- Step 1: the result includes the strengths of the ambiguous signal that are greater than or equal to the strength of the unambiguous signal
- Step 2: if the unambiguous signal and the ambiguous signal now have different logic values, the result includes the strength of the unambiguous signal and the intermediate values in the gap between the strengths taken from Step 1 and the strength of the unambiguous signal



#### Examples

|            |          | 0.00 | Stre     | ngth | ofLog | ic O     |     |          |      |     | Stre | ength o | of Log | lic 1    |     |     |
|------------|----------|------|----------|------|-------|----------|-----|----------|------|-----|------|---------|--------|----------|-----|-----|
| Signal_1   | 7        | 6    | <b>5</b> | 4    | 3     | 2        | 1   | 0        | 0    | 1   | 2    | 3       | 4      | <b>5</b> | 6   | 7   |
|            | Su0      | St0  | Pu0      | La0  | We0   | Me0      | Sm0 | HiZ0     | HiZ1 | Sm1 | Me1  | We1     | La1    | Pu1      | St1 | Su1 |
|            |          |      | Stre     | ngth | ofLog | ic 0     |     |          |      |     | Stre | ength o | of Log | lic 1    | 110 |     |
| Signal_2 S | <b>7</b> | 6    | <b>5</b> | 4    | 3     | <b>2</b> | 1   | <b>0</b> | 0    | 1   | 2    | 3       | 4      | <b>5</b> | 6   | 7   |
|            | Su0      | St0  | Pu0      | La0  | We0   | Me0      | Sm0 | HiZ0     | HiZ1 | Sm1 | Me1  | We1     | La1    | Pu1      | St1 | Su1 |
|            |          |      | Stre     | ngth | ofLog | ic 0     |     |          |      |     | Stre | ength o | of Log | ic 1     |     |     |
| Result     | 7        | 6    | <b>5</b> | 4    | 3     | 2        | 1   | 0        | 0    | 1   | 2    | 3       | 4      | 5        | 6   | 7   |
|            | Su0      | St0  | Pu0      | La0  | We0   | Me0      | Sm0 | HiZ0     | HiZ1 | Sm1 | Me1  | We1     | La1    | Pu1      | St1 | Su1 |

|          |     |     | Stre     | ngth   | of Log | ic O     |     |      |      |     | Stre | ngth o | of Log   | ic 1 |     |     |
|----------|-----|-----|----------|--------|--------|----------|-----|------|------|-----|------|--------|----------|------|-----|-----|
| Signal_1 | 7   | 6   | 5        | 4      | 3      | 2        | 1   | 0    | 0    | 1   | 2    | 3      | 4        | 5    | 6   | 7   |
|          | Su0 | St0 | Pu0      | Ea0    | We0    | Mê0      | Sm0 | HiZ0 | HiZ1 | Sm1 | Me1  | We1    | La1      | Pu1  | St1 | Su1 |
|          |     |     | Stre     | ngth ( | of Log | ic 0     |     |      |      |     | Stre | ngth   | of Log   | ic 1 |     |     |
| Signal_2 | 7   | 6   | <b>5</b> | 4      | 3      | 2        | 1   | 0    | 0    | 1   | 2    | 3      | <b>4</b> | 5    | 6   | 7   |
|          | Su0 | St0 | Pu0      | La0    | We0    | Me0      | Sm0 | HiZ0 | HiZ1 | Sm1 | Me1  | We1    | La1      | Pu1  | St1 | Su1 |
|          |     |     | Stre     | ngth   | of Log | ic 0     |     |      |      |     | Stre | ngth   | of Log   | ic 1 |     |     |
| Result   | 7   | 6   | 5        | 4      | 3      | <b>2</b> | 1   | 0    | 0    | 1   | 2    | 3      | 4        | 5    | 6   | 7   |
|          | Su0 | St0 | Pu0      | La0    | We0    | Me0      | Sm0 | HiZ0 | HiZ1 | Sm1 | Me1  | We1    | La1      | Pu1  | St1 | Su1 |

|          |     |     | Stre     | ngth | ofLog | ic O     |     |          |      |          | Stre | ength | of Log | ic 1     |     |     |
|----------|-----|-----|----------|------|-------|----------|-----|----------|------|----------|------|-------|--------|----------|-----|-----|
| Signal_1 | 7   | 6   | 5        | 4    | 3     | 2        | 1   | 0        | 0    | 1        | 2    | 3     | 4      | 5        | 6   | 7   |
|          | Su0 | St0 | Pu0      | La0  | We0   | Me0      | Sm0 | HiZ0     | HiZ1 | Sm1      | Me1  | We1   | La1    | Pu1      | St1 | Su1 |
|          |     |     | Stre     | ngth | ofLog | ic 0     |     |          |      | 1        | Stre | ength | of Log | lic 1    |     |     |
| Signal_2 | 7   | 6   | <b>5</b> | 4    | 3     | 2        | 1   | <b>0</b> | 0    | <b>1</b> | 2    | 3     | 4      | <b>5</b> | 6   | 7   |
|          | Su0 | St0 | Pu0      | La0  | We0   | Me0      | Sm0 | HiZ0     | HiZ1 | Sm1      | Me1  | We1   | La1    | Pu1      | St1 | Su1 |
|          |     |     | Stre     | ngth | ofLog | ic 0     |     |          | 1    |          | Stre | ength | of Log | ic 1     |     |     |
| Result   | 7   | 6   | 5        | 4    | 3     | <b>2</b> | 1   | 0        | 0    | 1        | 2    | 3     | 4      | <b>5</b> | 6   | 7   |
|          | Su0 | St0 | Pu0      | La0  | We0   | Me0      | Sm0 | HiZO     | HiZ1 | Sm1      | Me1  | We1   | La1    | Pu1      | St1 | Su1 |

3/29/04 & 4/8/04



#### Example



nand (strong1, highz0) G2(Result, a,b)

|          |     |     | Stre     | ngth d | of Log   | ic O |     |      |      |     | Stre | ngth o | of Log | ic 1     |     | 1. 2 |
|----------|-----|-----|----------|--------|----------|------|-----|------|------|-----|------|--------|--------|----------|-----|------|
| Signal_1 | 7   | 6   | <b>5</b> | 4      | <b>3</b> | 2    | 1   | 0    | 0    | 1   | 2    | 3      | 4      | <b>5</b> | 6   | 7    |
|          | Su0 | St0 | Pu0      | La0    | We0      | Me0  | Sm0 | HiZ0 | HiZ1 | Sm1 | Me1  | We1    | La1    | Pu1      | St1 | Su1  |

|          |     |     | Stre | ngth | of Log | ic 0 |     |      |      |     | Stre | ngth o | of Log | ic 1 |     |     |
|----------|-----|-----|------|------|--------|------|-----|------|------|-----|------|--------|--------|------|-----|-----|
| Signal 2 | 7   | 6   | 5    | 4    | 3      | 2    | 1   | 0    | 0    | 1   | 2    | 3      | 4      | 5    | 6   | 7   |
| Signal_z | Su0 | St0 | Pu0  | La0  | We0    | Me0  | Sm0 | HiZ0 | HiZ1 | Sm1 | Me1  | We1    | La1    | Pu1  | St1 | Su1 |

|        |     |     | Stre | ngth o | of Log | ic O |     |      |      | 1. Brent | Stre | ength o | of Log | jic 1    |     |     |
|--------|-----|-----|------|--------|--------|------|-----|------|------|----------|------|---------|--------|----------|-----|-----|
| Result | 7   | 6   | 5    | 4      | 3      | 2    | 1   | 0    | 0    | 1        | 2    | 3       | 4      | <b>5</b> | 6   | 7   |
|        | Su0 | St0 | Pu0  | La0    | We0    | Me0  | Sm0 | HiZO | HiZ1 | Sm1      | Me1  | We1     | La1    | Pu1      | St1 | Su1 |

3/29/04 & 4/8/04

Hardware Description Languages and Synthesis 35



#### Signal Strengths and Wired Logic

- Nets of type wand, wor, triand, and trior automatically resolve contention between drivers having the same strength
  - wand and triand (wor and trior) produce a logic value 0 (1) if any driver is 0 (1)

#### Example (wired-and)

|          |     |          | Stre     | ngth | ofLog    | ic O     |          |      |      |          | Stre | ngth d   | of Log | lic 1    |     |     |
|----------|-----|----------|----------|------|----------|----------|----------|------|------|----------|------|----------|--------|----------|-----|-----|
| Signal_1 | 7   | <b>6</b> | <b>5</b> | 4    | 3        | 2        | <b>1</b> | 0    | 0    | <b>1</b> | 2    | <b>3</b> | 4      | <b>5</b> | 6   | 7   |
|          | Su0 | St0      | Pu0      | La0  | We0      | Me0      | Sm0      | HiZ0 | HiZ1 | Sm1      | Me1  | We1      | La1    | Pu1      | St1 | Su1 |
|          |     |          | Stre     | ngth | ofLog    | ic 0     |          |      |      |          | Stre | ngth     | of Log | lic 1    |     |     |
| Signal_2 | 7   | <b>6</b> | 5        | 4    | 3        | <b>2</b> | 1        | 0    | 0    | 1        | 2    | 3        | 4      | 5        | 6   | 7   |
|          | Su0 | St0      | Pu0      | La0  | We0      | Me0      | Sm0      | HiZ0 | HiZ1 | Sm1      | Me1  | We1      | La1    | Pu1      | St1 | Su1 |
|          |     |          | Stre     | ngth | ofLog    | ic 0     |          |      |      |          | Stre | ngth     | of Log | jic 1    |     |     |
| Result   | 7   | 6        | <b>5</b> | 4    | <b>3</b> | 2        | 1        | 0    | 0    | 1        | 2    | 3        | 4      | 5        | 6   | 7   |
|          | Su0 | St0      | Pu0      | La0  | We0      | Me0      | Sm0      | HiZ0 | HiZ1 | Sm1      | Me1  | We1      | La1    | Pu1      | St1 | Su1 |

3/29/04 & 4/8/04

# Signal Strengths and Wired Logic

When a net of type wand, wor, triand, or trior is driven by drivers having different strengths, the simulator considers all possible combinations of strengths between drivers and retains the dominant results, while taking into account the predefined wire behavior of the net

#### Example

|                     | Strength of Logic 0 |          |                 |                                          |          |          |          |                     | Strength of Logic 1 |                 |          |          |           |          |          |          |
|---------------------|---------------------|----------|-----------------|------------------------------------------|----------|----------|----------|---------------------|---------------------|-----------------|----------|----------|-----------|----------|----------|----------|
| Signal_1            | 7<br>Su0            | 6<br>St0 | 5<br>Pu0        | 4<br>La0                                 | 3<br>We0 | 2<br>Me0 | 1<br>Sm0 | <b>0</b><br>HiZ0    | 0<br>HiZ1           | 1<br>Sm1        | 2<br>Me1 | 3<br>We1 | 4<br>La1  | 5<br>Pu1 | 6<br>St1 | 7<br>Su1 |
| Strength of Logic 0 |                     |          |                 |                                          |          |          |          | Strength of Logic 1 |                     |                 |          |          |           |          |          |          |
| Signal_2            | 7<br>Su0            | 6<br>St0 | <b>5</b><br>Pu0 | 4<br>La0                                 | 3<br>We0 | 2<br>Me0 | 1<br>Sm0 | <b>0</b><br>HiZ0    | 0<br>HiZ1           | 1<br>Sm1        | 2<br>Me1 | 3<br>We1 | 4<br>La1  | 5<br>Pu1 | 6<br>St1 | 7<br>Su1 |
| wand                | Strength of Logic 0 |          |                 |                                          |          |          |          | Strength of Logic 1 |                     |                 |          |          |           |          |          |          |
| Result              | 7<br>Su0            | 6<br>St0 | 5<br>Pu0        | 4<br>La0                                 | 3<br>We0 | 2<br>Me0 | 1<br>Sm0 | 0<br>HiZ0           | 0<br>HiZ1           | <b>1</b><br>Sm1 | 2<br>Me1 | 3<br>We1 | 4<br>La1  | 5<br>Pu1 | 6<br>St1 | 7<br>Su1 |
| wor                 | Strength of Logic 0 |          |                 |                                          |          |          |          |                     | Strength of Logic 1 |                 |          |          |           |          |          |          |
| State               | 1 1 1 1 1 1         |          | - Aresta        | 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. | 1        |          | 11721223 |                     | 0                   | 10000000        | 1 0      | 1        | SCHOOL ST | 1 -      |          | 1 -      |

3/29/04 & 4/8/04