

School of Engineering

# Spiral 1 / Unit 2

Basic Boolean Algebra Logic Functions Decoders Multiplexers

## Outcomes

- I know the difference between combinational and sequential logic and can name examples of each.
- I understand latency, throughput, and at least 1 technique to improve throughput
- I can identify when I need state vs. a purely combinational function
  - I can convert a simple word problem to a logic function (TT or canonical form) or state diagram
- I can use Karnaugh maps to synthesize combinational functions with several outputs
- I understand how a register with an enable functions & is built
- I can design a working state machine given a state diagram
- I can implement small logic functions with complex CMOS gates



**BOOLEAN ALGEBRA INTRO** 



## **Boolean Algebra**

- A set of theorems to help us manipulate logical expressions/equations
- Axioms = Basis / assumptions used
- Theorems = manipulations that we can use

#### Axioms

- Axioms are the basis for Boolean Algebra
- Notice that these axioms are simply restating our definition of digital/binary logic
  - A1/A1' = Binary variables (only 2 values possible)
  - A2/A2' = NOT operation
  - A3,A4,A5 = AND operation
  - A3',A4',A5' = OR operation

| (A1) | X = 0 if X ≠ 1              | (A1') | $X = 1$ if $X \neq 0$ |
|------|-----------------------------|-------|-----------------------|
| (A2) | If X = 0, then X' = 1       | (A2') | If X = 1, then X' = 0 |
| (A3) | $0 \bullet 0 = 0$           | (A3') | 1 + 1 = 1             |
| (A4) | 1 • 1 = 1                   | (A4') | 0 + 0 = 0             |
| (A5) | $1 \cdot 0 = 0 \cdot 1 = 0$ | (A5') | 0 + 1 = 1 + 0 = 1     |

## Duality

1-2.6

- Every truth statement can yields another truth statement
  - I exercise if I have time <u>and</u> energy (original statement)
  - I don't exercise if I don't have time <u>or</u> don't have energy (dual statement)
- To express the dual, swap...

$$1's \longleftrightarrow 0's$$

$$\bullet \longleftrightarrow +$$

## Duality

• The "dual" of an expression is not equal to the original



• Taking the "dual" of both sides of an equation yields a new equation

$$\mathbf{X} + \mathbf{1} = \mathbf{1} \qquad \mathbf{X} \bullet \mathbf{0} = \mathbf{0}$$

Original equation

Dual

1-2.7



## Single Variable Theorems

- Provide some simplifications for expressions containing:
  - a single variable
  - a single variable and a constant bit
- Each theorem has a dual (another true statement)
- Each theorem can be proved by writing a truth table for both sides (i.e. proving the theorem holds for all possible values of X)

| T1 | X + 0 = X  | T1' | X • 1 = X         |
|----|------------|-----|-------------------|
| T2 | X + 1 = 1  | T2' | X • 0 = 0         |
| Т3 | X + X = X  | T3' | $X \bullet X = X$ |
| T4 | (X')' = X  |     |                   |
| Т5 | X + X' = 1 | T5' | X • X' = 0        |



Whenever a variable is OR'ed with 0, the output will be the same as the variable...

"0 OR Anything equals that anything"

Whenever a variable is AND'ed with 1, the output will be the same as the variable...

"1 AND Anything equals that anything"



Whenever a variable is OR'ed with 1, the output will be 1...

"1 OR anything equals 1"

Whenever a variable is AND'ed with 0, the output will be 0...**"0 AND anything equals 0"** 



Whenever a variable is OR'ed with itself, the result is just the value of the variable

Whenever a variable is AND'ed with itself, the result is just the value of the variable

This theorem can be used to reduce two identical terms into one *OR* to replicate one term into two.



School of Engineering

## Single Variable Theorem (T4)

## $(X')' = X (T4) \qquad (\overline{X}) = X (T4)$



#### Anything inverted twice yields its original value



Whenever a variable is OR'ed with its complement, one value has to be 1 and thus the result is 1

Whenever a variable is AND'ed with its complement, one value has to be 0 and thus the result is 0

This theorem can be used to simplify variables into a constant or to expand a constant into a variable.



# **Application: Channel Selector**

- Given 4 input, digital music/sound channels and 4 output channels
- Given individual "select" inputs that select 1 input channel to be routed to 1 output channel





## Application: Steering Logic

- 4-input music channels (ICHx)
  - Select one input channel (use ISELx inputs)
  - Route to one output channel (use OSELx inputs)





# **Application: Steering Logic**

- 1<sup>st</sup> Level of AND gates act as barriers only passing 1 channel
- OR gates combines 3 streams of 0's with the 1 channel that got passed (i.e. ICH1)
- 2<sup>nd</sup> Level of AND gates passes the channel to only the selected output



#### Your Turn

School of Engineering

- Build a circuit that takes 3 inputs: S, INO, IN1 and outputs a single bit Y.
- It's functions should be:

- If S = 0, Y = INO (INO passes to Y)

- If S = 1, Y = IN1 (IN1 passes to Y)





## **CHECKERS / DECODERS**

#### Gates

- Gates can have more than 2 inputs but the functions stay the same
  - AND = output = 1 if ALL inputs are 1
    - Outputs 1 for only 1 input combination
  - OR = output = 1 if ANY input is 1
    - Outputs 0 for only 1 input combination

|   | X | Y | Ζ | F |
|---|---|---|---|---|
|   | 0 | 0 | 0 | 0 |
|   | 0 | 0 | 1 | 0 |
| F | 0 | 1 | 0 | 0 |
|   | 0 | 1 | 1 | 0 |
|   | 1 | 0 | 0 | 0 |
|   | 1 | 0 | 1 | 0 |
|   | 1 | 1 | 0 | 0 |
|   | 1 | 1 | 1 | 1 |

3-input AND



| Χ   | Y          | Ζ | F |  |  |
|-----|------------|---|---|--|--|
| 0   | 0          | 0 | 0 |  |  |
| 0   | 0          | 1 | 1 |  |  |
| 0   | 1          | 0 | 1 |  |  |
| 0   | 1          | 1 | 1 |  |  |
| 1   | 0          | 0 | 1 |  |  |
| 1   | 0          | 1 | 1 |  |  |
| 1   | 1          | 0 | 1 |  |  |
| 1   | 1          | 1 | 1 |  |  |
| 3_1 | 3_input OR |   |   |  |  |

-2.19

School of Engineering

3-input OR

# Checkers / Decoders

- An AND gate only outputs '1' for 1 combination
  - That combination can be changed by adding inverters to the inputs
  - We can think of the AND gate as "checking" or "decoding" a specific combination and outputting a '1' when it matches.



| AND gate decoding |
|-------------------|
| (checking for)    |
| combination 101   |

| Х | Y | Z | F |  |
|---|---|---|---|--|
| 0 | 0 | 0 | 0 |  |
| 0 | 0 | 1 | 0 |  |
| 0 | 1 | 0 | 0 |  |
| 0 | 1 | 1 | 0 |  |
| 1 | 0 | 0 | 0 |  |
| 1 | 0 | 1 | 1 |  |
| 1 | 1 | 0 | 0 |  |
| 1 | 1 | 1 | 0 |  |



AND gate decoding (checking for) combination 000

| Χ | Y | Ζ | F |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 0 |

#### USC Viterbi

## Checkers / Decoders

- Place inverters at the input of the AND gates such that
  - F produces '1' only for input combination  $\{x,y,z\} = \{010\}$
  - G produces '1' only for input combination  $\{x,y,z\} = \{110\}$

| x — |      |
|-----|------|
| у — | )— F |
| z — |      |

AND gate decoding

(checking for)

combination 010

| Х | Y | Ζ | F |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 0 |



combination 110

| 0 | 0 | 0 | 0 |
|---|---|---|---|
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |

Ζ

G

#### USC Viterbi

## Checkers / Decoders

- Place inverters at the input of the AND gates such that
  - F produces '1' only for input combination  $\{x,y,z\} = \{010\}$
  - G produces '1' only for input combination  $\{x,y,z\} = \{110\}$

| x _q     |      |
|----------|------|
| <u>y</u> | )— F |
| z Y      |      |

AND gate decoding

(checking for)

combination 010

| ^ | • | 2 | • |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 0 |



AND gate decoding (checking for) combination 110

| Χ | Y | Ζ | G |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |



# Checkers / Decoders

- An OR gate only outputs '0' for 1 combination
  - That combination can be changed by adding inverters to the inputs



Add inverters to create an OR gate decoding (checking for) combination 010

| Х | Y | Ζ | F |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |



Add inverters to create an OR gate decoding (checking for) combination 110

| Х | Υ | Ζ | F |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |

# Checkers / Decoders

- An OR gate only outputs '0' for 1 combination
  - That combination can be changed by adding inverters to the inputs
  - We can think of the OR gate as "checking" or "decoding" a specific combination and outputting a '0' when it matches.



OR gate decoding (checking for) combination 010

| Y | Ζ                          | F                                                                                                                                                                                                                                                   |
|---|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | 0                          | 1                                                                                                                                                                                                                                                   |
| 0 | 1                          | 1                                                                                                                                                                                                                                                   |
| 1 | 0                          | 0                                                                                                                                                                                                                                                   |
| 1 | 1                          | 1                                                                                                                                                                                                                                                   |
| 0 | 0                          | 1                                                                                                                                                                                                                                                   |
| 0 | 1                          | 1                                                                                                                                                                                                                                                   |
| 1 | 0                          | 1                                                                                                                                                                                                                                                   |
| 1 | 1                          | 1                                                                                                                                                                                                                                                   |
|   | 0<br>0<br>1<br>1<br>0<br>0 | 0       0         0       1         1       0         1       1         0       0         0       1         1       0         0       0         1       1         0       0         0       1         0       0         0       1         0       0 |



OR gate decoding (checking for) combination 110

| Χ | Υ   | Ζ | F |
|---|-----|---|---|
| 0 | 0   | 0 | 1 |
| 0 | 0   | 1 | 1 |
| 0 | 1   | 0 | 1 |
| 0 | 1   | 1 | 1 |
| 1 | 0   | 0 | 1 |
| 1 | 0   | 1 | 1 |
| 1 | 1 0 | 0 | 0 |
| 1 | 1   | 1 | 1 |



#### Decoder Exercise

 Design an instruction decoder that uses opcode[5:0] and func[5:0] as inputs and produces a separate output {ADD, SRL, SUB, etc.} for each instruction type that will produce '1' when that instruction is loaded

|          | opcode | rs           | rt    | rd                  | shamt     | func   |  |  |  |
|----------|--------|--------------|-------|---------------------|-----------|--------|--|--|--|
|          | 000000 | 01000        | 10001 | 00101               | 00111     | 100000 |  |  |  |
| )e       | ADD    | \$8          | \$17  | \$5 00000           |           |        |  |  |  |
| R-Type   | 000000 | 01000        | 10001 | 00101               | 00111     | 000010 |  |  |  |
| R        | SRL    | \$8          | \$17  | \$5 7               |           |        |  |  |  |
|          | 000000 | 01000        | 10001 | 00101               | 00111     | 100010 |  |  |  |
|          | SUB    | \$8          | \$17  | \$5 7               |           |        |  |  |  |
|          | opcode | rs           | rt    | immediate           |           |        |  |  |  |
|          | 001000 | 11000        | 00101 | 0000 0000 0000 0001 |           |        |  |  |  |
|          | ADDI   | \$24         | \$5   | 20                  |           |        |  |  |  |
| Ð        | 100011 | 00011        | 00101 | 1111 1111 1111 1000 |           |        |  |  |  |
| I-Type   | LW     | \$3          | \$5   |                     | -8        |        |  |  |  |
| <u> </u> | 101011 | 00011        | 00101 | 1111                | 1111 1111 | 1000   |  |  |  |
|          | SW     | \$3          | \$5   |                     | -8        |        |  |  |  |
|          | 000100 | 00011        | 00101 | 1111 1111 1111 1000 |           |        |  |  |  |
|          | BEQ    | \$3          | \$5   |                     | -8        |        |  |  |  |
| e        | opcode | Jump address |       |                     |           |        |  |  |  |
| J-Type   | 000010 | Jump address |       |                     |           |        |  |  |  |
| ŀ        | J      | 26-bits      |       |                     |           |        |  |  |  |



#### Decoder Exercise

|     |        | opcode | rs           | rt    | rd                  | shamt     | func   |  |  |  |
|-----|--------|--------|--------------|-------|---------------------|-----------|--------|--|--|--|
| ADD |        | 000000 | 01000        | 10001 | 00101               | 00111     | 100000 |  |  |  |
|     | ЭС     | ADD    | \$8          | \$17  | \$5                 | 00000     |        |  |  |  |
|     | R-Type | 000000 | 01000        | 10001 | 00101               | 00111     | 000010 |  |  |  |
|     | æ      | SRL    | \$8          | \$17  | \$5                 | 7         |        |  |  |  |
|     |        | 000000 | 01000        | 10001 | 00101               | 00111     | 100010 |  |  |  |
| SRL |        | SUB    | \$8          | \$17  | \$5                 | 7         |        |  |  |  |
|     |        | opcode | rs           | rt    | i                   | immediate | Э      |  |  |  |
|     | I-Type | 001000 | 11000        | 00101 | 0000 0000 0000 0001 |           |        |  |  |  |
|     |        | ADDI   | \$24         | \$5   |                     | 20        |        |  |  |  |
|     |        | 100011 | 00011        | 00101 | 1111                | 1111 1111 | 1000   |  |  |  |
| SUB |        | LW     | \$3          | \$5   |                     | -8        |        |  |  |  |
|     |        | 101011 | 00011        | 00101 | 1111                | 1111 1111 | 1000   |  |  |  |
|     |        | SW     | \$3          | \$5   |                     | -8        |        |  |  |  |
|     |        | 000100 | 00011        | 00101 | 1111                | 1111 1111 | 1000   |  |  |  |
|     |        | BEQ    | \$3          | \$5   |                     | -8        |        |  |  |  |
|     | θ      | opcode |              | Ju    | mp addre            | SS        |        |  |  |  |
|     | J-Type | 000010 | Jump address |       |                     |           |        |  |  |  |
|     | ۔<br>ب | J      |              |       | 26-bits             |           |        |  |  |  |



#### **Decoder Exercise**

| -    |        |        |              |       |                     |           |        |
|------|--------|--------|--------------|-------|---------------------|-----------|--------|
|      |        | opcode | rs           | rt    | rd                  | shamt     | func   |
| ADDI | R-Type | 000000 | 01000        | 10001 | 00101               | 00111     | 100000 |
|      |        | ADD    | \$8          | \$17  | \$5                 | 00000     |        |
|      |        | 000000 | 01000        | 10001 | 00101               | 00111     | 000010 |
|      | æ      | SRL    | \$8          | \$17  | \$5                 | 7         |        |
| 1347 |        | 000000 | 01000        | 10001 | 00101               | 00111     | 100010 |
| LW   |        | SUB    | \$8          | \$17  | \$5                 | 7         |        |
|      |        | opcode | rs           | rt    | immediate           |           |        |
|      |        | 001000 | 11000        | 00101 | 0000 0000 0000 0001 |           |        |
|      |        | ADDI   | \$24         | \$5   | 20                  |           |        |
|      | I-Type | 100011 | 00011        | 00101 | 1111                | 1111 1111 | 1000   |
| SW   |        | LW     | \$3          | \$5   |                     | -8        |        |
|      |        | 101011 | 00011        | 00101 | 1111                | 1111 1111 | 1000   |
|      |        | SW     | \$3          | \$5   |                     | -8        |        |
|      |        | 000100 | 00011        | 00101 | 1111                | 1111 1111 | 1000   |
|      |        | BEQ    | \$3          | \$5   |                     | -8        |        |
|      | θ      | opcode | Jump address |       |                     |           |        |
|      | J-Type | 000010 |              | Ju    | ump address         |           |        |
|      | -C     | J      | 26-bits      |       |                     |           |        |

USC Viterbi

School of Engineering

#### Single-Cycle CPU



## **Full Decoders**

-2.29

- A full decoder is a building block that:
  - Takes in an n-bit binary number as input
  - Decodes that binary number and activates the corresponding output
  - Individual outputs for EVERY (MOST) input combination (i.e. 2<sup>n</sup> outputs)



#### Decoders

-2.30

- A decoder is a building block that:
  - Takes a binary number as input
  - Decodes that binary number and activates the corresponding output
  - Put in 6=110, Output 6 activates ('1')
  - Put in 5=101, Output 5 activates ('1')



#### Decoders

-2.31

- A decoder is a building block that:
  - Takes a binary number as input
  - Decodes that binary number and activates the corresponding output
  - Put in 6=110, Output 6 activates ('1')
  - Put in 5=101, Output 5 activates ('1')





#### **Decoder Sizes**

- A decoder w/ an **n-bit input** has **2<sup>n</sup> outputs** 
  - 1 output for every combination of the n-bit input





#### Exercise

• Complete the design of a 2-to-4 decoder





School of Engineering

## **Building Decoders**





#### **Enables**

- Exactly one output is active at all times
- It may be undesirable to always have an active output
- Add an extra input (called an enable) that can independently force all the outputs to their inactive values



2-to-4 Decoder



-2.35



Enable



# **Implementing Enables**

• Original 2-to-4 decoder



When E=0, force all outputs = 0

When E=1, outputs operate as they did originally

#### **Enables**

1-2.38

School of Engineering

• Enables can be implemented by connecting it to each AND gate of the decoder



When E=0, 0 AND anything = 0

When E=1, 1 AND anything = that anything, which was the normal decoding logic

#### USC Viterbi (1-2.39) School of Engineering

# **Multiplexers**

- Along with adders, multiplexers are most used building block
- n data inputs, log<sub>2</sub>n select bits, 1 output
- A multiplexer ("mux" for short) selects one data input and passes it to the output





# **Multiplexers**





2 Thus, input 2 = C[31:0] is selected and passed to the output



# **Multiplexers**



2



## **Multiplexers**



# USC Viterbi

# Recall Using T1/T2

- 1<sup>st</sup> Level of AND gates act as barriers only passing 1 channel
- OR gates combines 3 streams of 0's with the 1 channel that got passed (i.e. ICH1)
- 2<sup>nd</sup> Level of AND gates passes the channel to only the selected output





# Exercise: Build a 4-to-1 mux

 $S_1$  $S_0$ 

 Complete the 4-to-1 mux to the right by drawing wires between the 2-to-4 decode and the AND gates





# **Building a Mux**

- To build a mux
  - Decode the select bits and include the corresponding data input.
  - Finally OR all the first level outputs together.





# **Building a Mux**

- To build a mux
  - Decode the select bits and include the corresponding data input.
  - Finally OR all the first level outputs together.





# **Building a Mux**

- To build a mux
  - Decode the select bits and include the corresponding data input.
  - Finally OR all the first level outputs together.



# **Building Wide Muxes**

- So far muxes only have single bit inputs...
  - I<sub>0</sub> is only 1-bit
  - I<sub>1</sub> is only 1-bit
- What if we still want to select between 2 inputs but now each input is a 4bit number
- Use a 4-bit wide 2-to-1 mux



-2.48

School of Engineering

USC Viter bi

# **Building Wide Muxes**

- To build a 4-bit wide 2-to-1 mux, use 4 separate 2-to-1 muxes
- When S=0, all muxes pass their I<sub>0</sub> inputs which means all the A bits get through
- When S=1, all muxes pass their I<sub>1</sub> inputs which means all the B bits get through
- In general, to build an m-bit wide n-to-1 mux, use m individual (separate) n-to-1 muxes



USC Viter bi

# **Building Wide Muxes**

- To build a 4-bit wide 2-to-1 mux, use 4 separate 2-to-1 muxes
- When S=0, all muxes pass their I<sub>0</sub> inputs which means all the A bits get through
- When S=1, all muxes pass their I<sub>1</sub> inputs which means all the B bits get through
- In general, to build an m-bit wide n-to-1 mux, use m individual (separate) n-to-1 muxes





# Exercise

- How many 1-bit wide muxes and of what size would you need to build a 4-to-1, 8-bit wide mux (i.e. there are 4 numbers: W[7:0], X[7:0], Y[7:0] and Z[7:0] and you must select one)
- How many 1-bit wide muxes and of what size would you need to build a 8-to-1, 2-bit wide mux?

USC Viterbi (1-2.52)

School of Engineering

# Single-Cycle CPU



USC Viterbi (1-2.53)

School of Engineering

# Single-Cycle CPU





# **Building Large Muxes**

- Similar to a tournament of sports teams
  - Many teams enter and then are narrowed down to 1 winner
  - In each round winners play winners



# Design an 8-to-1 mux with School of Engineering

#### 2-to-1 Muxes





# **Cascading Muxes**

- Use several small muxes to build large ones
- Rules
  - Arrange the muxes in stages (based on necessary number of inputs in 1<sup>st</sup> stage)
  - 2. Outputs of 1 stage feed to inputs of the next
  - 3. All muxes in a stage connect to the same group of select bits
    - Usually, LSB connects to first stage
    - MSB connect to last stage



# Building a 4-to-1 Mux





# Building a 4-to-1 Mux

| <b>S</b> <sub>1</sub> | S <sub>0</sub> | Y              |
|-----------------------|----------------|----------------|
| 0                     | 0              | $D_0$          |
| 0                     | 1              | D <sub>1</sub> |
| 1                     | 0              | $D_2$          |
| 1                     | 1              | $D_3$          |

Walk through an example:

$$S_1 S_0 = 01$$





# Building a 4-to-1 Mux

| <b>S</b> <sub>1</sub> | S <sub>0</sub> | Y              |
|-----------------------|----------------|----------------|
| 0                     | 0              | $D_0$          |
| 0                     | 1              | D <sub>1</sub> |
| 1                     | 0              | D <sub>2</sub> |
| 1                     | 1              | $D_3$          |

Walk through an example:

$$S_1S_0 = 01$$





# Building a 4-to-1 Mux

| <b>S</b> <sub>1</sub> | S <sub>0</sub> | Y              |
|-----------------------|----------------|----------------|
| 0                     | 0              | D <sub>0</sub> |
| 0                     | 1              | D <sub>1</sub> |
| 1                     | 0              | $D_2$          |
| 1                     | 1              | $D_3$          |

Walk through an example:

$$S_1S_0 = 01$$





#### Exercise

- Create a 3-to-1 mux using 2-to-1 muxes
  - Inputs: I0, I1, I2 and select bits S1,S0
  - Output: Y

