

## CprE 281: Digital Logic

#### **Instructor: Alexander Stoytchev**

http://www.ece.iastate.edu/~alexs/classes/

## **Simple Processor**

CprE 281: Digital Logic Iowa State University, Ames, IA Copyright © Alexander Stoytchev

## **Digital System**

#### Datapath circuit

- To store data
- To manipulate data
- To transfer data from one part of the system to another
- Comprise building blocks such as registers, shift registers, counters, multipliers, decoders, encoders, adders, etc.

#### Control circuit

- Controls the operation of the datapath circuit
- Designed as a FSM















#### A Closer Look at the Registers









## **4-Bit Register**











### **Keeping Data into the Register**



### **Keeping Data into the Register**



### **Keeping Data into the Register**



#### A Closer Look at the Data Bus



#### **Bus Structure**

- We need a way to transfer data from any register (device) to any other register (device)
- A bus is simply a set of n wires to transfer n-bit data



What if two registers write to the bus at the same time?

# One way to implement a data bus is to use multiplexers



# One way to implement a data bus is to use multiplexers



This requires one multiplexer per bit. Assuming there are four 4-bit registers, we need four 5-to-1 multiplexers.

# One way to implement a data bus is to use multiplexers



#### A Closer Look at the Tri-State Driver





#### **Tri-state driver** (see Appendix B for more details)



#### **Tri-state driver** (see Appendix B for more details)

- Alternative way to implement a data bus
- Allows several devices to be connected to a single wire (this is not possible with regular logic gates because their outputs are always active; an OR gate is needed)
- Note that at any time, at most one of e0, e1, e2, and e3 can be set to 1



#### An n-bit Tri-State Driver can be constructed using n 1-bit tri-state buffers



## 2-Bit Register



# How to connect two 2-bit registers to a bus (using tri-state drivers)



This shows only two 2-bit registers, but this design scales to more and larger registers.

[Figure 7.3 from the textbook]



Register 1 stores the number  $2_{10} = 10_2$  Register 2 stores the number  $1_{10} = 01_2$ 



Initially all control inputs are set to 0 (no reading or writing allowed).



R1<sub>out</sub> is set to 1 (this enables reading from register 1).



The bits of R1 are now on the data bus (2-bit data bus in this case).



R2<sub>in</sub> is set to 1 (this enables writing to register 2).



The bits of R1 are still on the bus and they propagate to the multiplexers...



... and on the next positive clock edge to the outputs of the flip-flops of R2.



After the copy is complete  $R1_{out}$  and  $R2_{in}$  are set to 0.



All control inputs are now disabled (no reading or writing is allowed).



Register 2 now holds the same value as register 1.

## **Another Example**



Initially all control inputs are set to 0 (no reading or writing allowed).



The number  $3_{10}=11_2$  is placed on the 2-bit data bus.



R2<sub>in</sub> is set to 1 (this enables writing to register 2).



The bits of the data propagate the the multiplexers...



... and on the next positive clock edge to the outputs of the flip-flops of R2.



After the loading is complete R2<sub>in</sub> is set to 0.



Register 2 now stores the number  $3_{10}=11_2$ .

## A Closer Look at the Arithmetic Logic Unit (ALU)



[Figure 7.9 from the textbook]



## **4-Bit Register**





## **Adder/Subtractor unit**



#### The first two stages of a carry-lookahead adder



#### A hierarchical carry-lookahead adder



## Adder/subtractor unit

 Subtraction can be performed by simply adding the 2's complement of the second number, regardless of the signs of the two numbers.

 Thus, the same adder circuit can be used to perform both addition and subtraction !!!

## **Adder/subtractor unit**



## **XOR Tricks**



### **XOR** as a repeater



## **XOR** as an inverter



## Addition: when control = 0



## Addition: when control = 0



## Addition: when control = 0



## Subtraction: when control = 1



# Subtraction: when control = 1



[ Figure 3.12 from the textbook ]

# Subtraction: when control = 1



[ Figure 3.12 from the textbook ]

# Subtraction: when control = 1



## A Closer Look at the Control Circuit



[Figure 7.9 from the textbook]



# Design a FSM with input w and outputs

- R0<sub>in</sub> A<sub>in</sub> AddSub
- R0<sub>out</sub>

• R1<sub>in</sub>

- Gin
- R1<sub>out</sub>
- G<sub>out</sub>

• Done

• Extern

- R2<sub>in</sub> Clear
- R2<sub>out</sub>
- R3<sub>in</sub> FR<sub>in</sub>
- R3<sub>out</sub>

# Design a FSM with input w and outputs

• R0<sub>in</sub> • A<sub>in</sub> • AddSub • R0<sub>out</sub>

• Gin

• G<sub>out</sub>

- Extern
- Done





These are helper outputs that are one-hot encoded. They are used to simplify the expressions for the other outputs.

- R1<sub>in</sub>
- R1<sub>out</sub>
- R2<sub>in</sub> Clear
- R2<sub>out</sub>
- R3<sub>in</sub> FR<sub>in</sub>
- R3<sub>out</sub>



[Figure 7.11 from the textbook]



| Operation |     |      | Fun | nction Performed     |
|-----------|-----|------|-----|----------------------|
| Load      | Rx, | Data | Rx  | 🗲 Data               |
| Move      | Rx, | Ry   | Rx  | <b>←</b> [Ry]        |
| Add       | Rx, | Ry   | Rx  | <b>←</b> [Rx] + [Ry] |
| Sub       | Rx, | Ry   | Rx  | ← [Rx] - [Ry]        |

| Operation |     |      | Fun | ction Performed |
|-----------|-----|------|-----|-----------------|
| Load      | Rx, | Data | Rx  | 🗲 Data          |
| Move      | Rx, | Ry   | Rx  | <b>←</b> [Ry]   |
| Add       | Rx, | Ry   | Rx  | ← [Rx] + [Ry]   |
| Sub       | Rx, | Ry   | Rx  | ← [Rx] - [Ry]   |

Where Rx and Ry can be one of four possible options: R0, R1, R2, and R3

[Table 7.1 from the textbook]



| $f_1$ | $f_{	heta}$ | Function |
|-------|-------------|----------|
| 0     | 0           | Load     |
| 0     | 1           | Move     |
| 1     | 0           | Add      |
| 1     | 1           | Sub      |

| $Rx_1$ | $Rx_{\theta}$ | Register |
|--------|---------------|----------|
| 0      | 0             | R0       |
| 0      | 1             | R1       |
| 1      | 0             | R2       |
| 1      | 1             | R3       |

| $Ry_1$ | Ry <sub>0</sub> | Register |
|--------|-----------------|----------|
| 0      | 0               | R0       |
| 0      | 1               | R1       |
| 1      | 0               | R2       |
| 1      | 1               | R3       |



| $f_1$ | $f_{	heta}$ | Function |
|-------|-------------|----------|
| 0     | 0           | Load     |
| 0     | 1           | Move     |
| 1     | 0           | Add      |
| 1     | 1           | Sub      |

| $Rx_1$ | $Rx_{\theta}$ | Register |
|--------|---------------|----------|
| 0      | 0             | R0       |
| 0      | 1             | R1       |
| 1      | 0             | R2       |
| 1      | 1             | R3       |

| $Ry_1$ | Ry <sub>0</sub> | Register |
|--------|-----------------|----------|
| 0      | 0               | R0       |
| 0      | 1               | R1       |
| 1      | 0               | R2       |
| 1      | 1               | R3       |













| $f_1$ | $f_{	heta}$ | Function |
|-------|-------------|----------|
| 0     | 0           | Load     |
| 0     | 1           | Move     |
| 1     | 0           | Add      |
| 1     | 1           | Sub      |

| $Rx_1$ | $Rx_{\theta}$ | Register |
|--------|---------------|----------|
| 0      | 0             | R0       |
| 0      | 1             | R1       |
| 1      | 0             | R2       |
| 1      | 1             | R3       |

| $Ry_1$ | Ry <sub>0</sub> | Register |
|--------|-----------------|----------|
| 0      | 0               | R0       |
| 0      | 1               | R1       |
| 1      | 0               | R2       |
| 1      | 1               | R3       |



| $f_1$ | $f_{	heta}$ | Function |
|-------|-------------|----------|
| 0     | 0           | Load     |
| 0     | 1           | Move     |
| 1     | 0           | Add      |
| 1     | 1           | Sub      |

| $Rx_1$ | $Rx_{\theta}$ | Register  |
|--------|---------------|-----------|
| 0      | 0             | <b>R0</b> |
| 0      | 1             | R1        |
| 1      | 0             | R2        |
| 1      | 1             | R3        |

| $Ry_1$ | $Ry_{\theta}$ | Register |  |
|--------|---------------|----------|--|
| 0      | 0             | R0       |  |
| 0      | 1             | R1       |  |
| 1      | 0             | R2       |  |
| 1      | 1             | R3       |  |



| $f_1$ | $f_{	heta}$ | Function |  |
|-------|-------------|----------|--|
| 0     | 0           | Load     |  |
| 0     | 1           | Move     |  |
| 1     | 0           | Add      |  |
| 1     | 1           | Sub      |  |

| $Rx_1$ | $Rx_{\theta}$ | Register |
|--------|---------------|----------|
| 0      | 0             | R0       |
| 0      | 1             | R1       |
| 1      | 0             | R2       |
| 1      | 1             | R3       |

| $Ry_1$ | Ry <sub>0</sub> | Register |  |
|--------|-----------------|----------|--|
| 0      | 0               | R0       |  |
| 0      | 1               | R1       |  |
| 1      | 0               | R2       |  |
| 1      | 1               | R3       |  |

## Similar Encoding is Used by Modern Chips

# **MIPS32 Add Immediate Instruction**

# 001000 00001 00010 000000010101110

OP Code Addr 1 Addr 2 Immediate value

Equivalent mnemonic:

addi \$r1, \$r2, 350

[http://en.wikipedia.org/wiki/Instruction\_set]

#### Sample Assembly Language Program For This Processor

| Move | R3, | R0   |
|------|-----|------|
| Add  | R1, | R3   |
| Sub  | R0, | R2   |
| Load | R2, | Data |

| Machine Language | Assembly Language | Meaning / Interpretation |
|------------------|-------------------|--------------------------|
| 011100           | Move R3, R0       | R3 🗲 [R0]                |
| 100111           | Add R1, R3        | R1 🗲 [R1] + [R3]         |
| 110010           | Sub R0, R2        | R0 ← [R0] - [R2]         |
| 001000           | Load R2, Data     | R2 🗲 Data                |
|                  |                   |                          |

| Machine Language | Assembly Language |      | Meaning / Interpretation |
|------------------|-------------------|------|--------------------------|
| 011100           | Move R3,          | R0   | R3 🗲 [R0]                |
| <b>1001</b> 11   | Add R1,           | R3   | R1 🗲 [R1] + [R3]         |
| <b>1100</b> 10   | Sub R0,           | R2   | R0 ← [R0] - [R2]         |
| 001000           | Load R2,          | Data | R2 🗲 Data                |
|                  |                   |      |                          |

| Machine Language | Assembly Language | Meaning / Interpretation |  |
|------------------|-------------------|--------------------------|--|
| 011100           | Move R3, R0       | R3 🗲 [R0]                |  |
| 100111           | Add R1, R3        | R1 🗲 [R1] + [R3]         |  |
| 110010           | Sub R0, R2        | R0 ← [R0] - [R2]         |  |
| 001000           | Load R2, Data     | R2 🗲 Data                |  |
|                  |                   |                          |  |

For short, each line can be expressed as a hexadecimal number

| Machine Language | Assemb | oly Language | Meaning / Interpretation |
|------------------|--------|--------------|--------------------------|
| 1C               | Move   | R3, R0       | R3 🗲 [R0]                |
| 27               | Add    | R1, R3       | R1 🗲 [R1] + [R3]         |
| 32               | Sub    | R0, R2       | R0 🗲 [R0] - [R2]         |
| 08               | Load   | R2, Data     | R2 🗲 Data                |
|                  |        |              |                          |

| Intel 8086 |                                                                                                                                                                                   | ;<br>; Entry stack par<br>; [BP+6] = 1<br>; [BP+4] = s           | f memory from<br>rameters<br>len, Number of<br>src, Address o<br>dst, Address o | one location to another.<br>bytes to copy<br>f source data block<br>f target data block                                                                          |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0000:1000                                                                                                                                                                         | org                                                              | 1000h                                                                           | ; Start at 0000:1000h                                                                                                                                            |
|            | 0000:1000<br>0000:1000 55<br>0000:1001 89 E5<br>0000:1003 06<br>0000:1004 8B 4E 06<br>0000:1007 E3 11<br>0000:1009 8B 76 04<br>0000:100C 8B 7E 02<br>0000:100F 1E<br>0000:1010 07 | _memcpy proc<br>push<br>mov<br>push<br>mov<br>jcxz<br>mov<br>pop | <pre>cx,[bp+6] done si,[bp+4] di,[bp+2]</pre>                                   | ; Set up the call frame<br>; Save ES<br>; Set CX = len<br>; If len=0, return<br>; Set SI = src<br>; Set DI = dst<br>; Set ES = DS                                |
|            | 0000:1011 8A 04<br>0000:1013 88 05<br>0000:1015 46<br>0000:1016 47<br>0000:1017 49<br>0000:1018 75 F7<br>0000:101A 07                                                             | loop mov<br>mov<br>inc<br>inc<br>dec<br>jnz<br>done pop          | [di],al<br>si<br>di<br>cx<br>loop<br>es                                         | <pre>; Load AL from [src] ; Store AL to [dst] ; Increment src ; Increment dst ; Decrement len ; Repeat the loop ; Restore ES ; Bostore provious call frame</pre> |
|            | 0000:101B 5D<br>0000:101C 29 CO<br>0000:101E C3<br>0000:101F                                                                                                                      | pop<br>sub<br>ret<br>end p                                       | bp<br>ax,ax<br>proc                                                             | <pre>; Restore previous call frame ; Set AX = 0 ; Return [http://en.wikipedia.org/will</pre>                                                                     |

[http://en.wikipedia.org/wiki/Intel\_8086]

| Intel 8086<br>Memory Address                                                                                                                                                   | ; Copy a b<br>;<br>; Entry st<br>; [BP<br>; [BP<br>; [BP<br>;<br>; Return r | <pre>; _memcpy(dst, src, len) ; Copy a block of memory from one location to another. ; ; Entry stack parameters ; [BP+6] = len, Number of bytes to copy ; [BP+4] = src, Address of source data block ; [BP+2] = dst, Address of target data block ; ; Return registers ; AX = Zero</pre> |                                                                                                                                                                                                                            |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0000:1000                                                                                                                                                                      |                                                                             | org 1000h                                                                                                                                                                                                                                                                                | ; Start at 0000:1000h                                                                                                                                                                                                      |  |  |
| 0000:1000<br>0000:1000 55<br>0000:1001 89 E5<br>0000:1003 06<br>0000:1004 8B 4E 0<br>0000:1007 E3 11<br>0000:1009 8B 76 0<br>0000:100C 8B 7E 0<br>0000:100F 1E<br>0000:1010 07 | 4                                                                           | movcx,[bp+6]jcxzdonemovsi,[bp+4]                                                                                                                                                                                                                                                         | ; Set up the call frame<br>; Save ES<br>; Set CX = len<br>; If len=0, return<br>; Set SI = src<br>; Set DI = dst<br>; Set ES = DS                                                                                          |  |  |
| 0000:1011 8A 04<br>0000:1013 88 05<br>0000:1015 46<br>0000:1016 47<br>0000:1017 49<br>0000:1018 75 F7<br>0000:1018 5D<br>0000:1018 5D<br>0000:1016 C3                          | <b>loop</b><br>done                                                         |                                                                                                                                                                                                                                                                                          | <pre>; Load AL from [src]<br/>; Store AL to [dst]<br/>; Increment src<br/>; Increment dst<br/>; Decrement len<br/>; Repeat the loop<br/>; Restore ES<br/>; Restore previous call frame<br/>; Set AX = 0<br/>; Return</pre> |  |  |
| 0000:101F                                                                                                                                                                      |                                                                             | end proc                                                                                                                                                                                                                                                                                 | [http://en.wikipedia.org/wiki/Intel_8086]                                                                                                                                                                                  |  |  |

| Intel 8086                                                                                                                                                                        | ;<br>; Entry stack para<br>; [BP+6] = le<br>; [BP+4] = sr        | memory from o<br>ameters<br>an, Number of<br>cc, Address of | one location to another.<br>bytes to copy<br>f source data block<br>f target data block                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Machine<br>Language                                                                                                                                                               | ;<br>; Return registers<br>; AX = Zero                           | 3                                                           |                                                                                                                                                                                              |
| 0000:1000                                                                                                                                                                         | org                                                              | 1000h                                                       | ; Start at 0000:1000h                                                                                                                                                                        |
| 0000:1000<br>0000:1000 55<br>0000:1001 89 E5<br>0000:1003 06<br>0000:1004 8B 4E 06<br>0000:1007 E3 11<br>0000:1007 8B 76 04<br>0000:1007 8B 7E 02<br>0000:1007 1E<br>0000:1010 07 | _memcpy proc<br>push<br>mov<br>push<br>mov<br>jcxz<br>mov<br>pop | <pre>cx,[bp+6] done si,[bp+4]</pre>                         | <pre>; Set up the call frame ; Save ES ; Set CX = len ; If len=0, return ; Set SI = src ; Set DI = dst ; Set ES = DS</pre>                                                                   |
| 0000:1013 88 05<br>0000:1015 46<br>0000:1016 47<br>0000:1017 49<br>0000:1018 75 F7<br>0000:101A 07<br>0000:101B 5D                                                                | loop mov<br>mov<br>inc<br>inc<br>dec<br>jnz<br>done pop<br>pop   |                                                             | <pre>; Load AL from [src]<br/>; Store AL to [dst]<br/>; Increment src<br/>; Increment dst<br/>; Decrement len<br/>; Repeat the loop<br/>; Restore ES<br/>; Restore previous call frame</pre> |
| 0000:101C 29 CO<br>0000:101E C3<br>0000:101F                                                                                                                                      | sub<br>ret<br>end pr                                             | ax,ax                                                       | ; Set AX = 0<br>; Return<br>[http://en.wikipedia.org/wi                                                                                                                                      |

[http://en.wikipedia.org/wiki/Intel\_8086]

| Intel 8086                                                                                                                                                                        | <pre>; _memcpy(dst, src, len) ; Copy a block of memory from one location to another. ; ; Entry stack parameters ; [BP+6] = len, Number of bytes to copy ; [BP+4] = src, Address of source data block ; [BP+2] = dst, Address of target data block ; ; Return registers Assembly ; AX = Zero Language</pre> |                                                                   |                                                                                                                                                                                                               |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0000:1000                                                                                                                                                                         | org                                                                                                                                                                                                                                                                                                        | 1000h                                                             | ; Start at 0000:1000h                                                                                                                                                                                         |  |  |
| 0000:1000<br>0000:1000 55<br>0000:1001 89 E5<br>0000:1003 06<br>0000:1004 8B 4E 06<br>0000:1007 E3 11<br>0000:1009 8B 76 04<br>0000:100C 8B 7E 02<br>0000:100F 1E<br>0000:1010 07 | _memcpy proc<br>push<br>mov<br>push<br>mov<br>jcxz<br>mov<br>pop                                                                                                                                                                                                                                           | <pre>bp bp,sp es cx,[bp+6] done si,[bp+4] di,[bp+2] ds es</pre>   | ; Set up the call frame<br>; Save ES<br>; Set CX = len<br>; If len=0, return<br>; Set SI = src<br>; Set DI = dst<br>; Set ES = DS                                                                             |  |  |
| 0000:1011 8A 04<br>0000:1013 88 05<br>0000:1015 46<br>0000:1016 47<br>0000:1017 49<br>0000:1018 75 F7<br>0000:1018 5D<br>0000:1018 5D                                             | loop mov<br>mov<br>inc<br>inc<br>dec<br>jnz<br>done pop<br>pop<br>sub                                                                                                                                                                                                                                      | al,[si]<br>[di],al<br>si<br>di<br>cx<br>loop<br>es<br>bp<br>ax,ax | <pre>; Load AL from [src]<br/>; Store AL to [dst]<br/>; Increment src<br/>; Increment dst<br/>; Decrement len<br/>; Repeat the loop<br/>; Restore ES<br/>; Restore previous call frame<br/>; Set AX = 0</pre> |  |  |
| 0000:101E C3<br>0000:101F                                                                                                                                                         | ret<br>end pi                                                                                                                                                                                                                                                                                              | roc                                                               | ; Return<br>[http://en.wikipedia.org/w                                                                                                                                                                        |  |  |

[http://en.wikipedia.org/wiki/Intel\_8086]

| Intel 8086                                                                                                                                                                        | <pre>tel 8086 ; _memcpy(dst, src, len)<br/>; Copy a block of memory from one location to another.<br/>;<br/>; Entry stack parameters<br/>; [BP+6] = len, Number of bytes to copy<br/>; [BP+4] = src, Address of source data block<br/>; [BP+2] = dst, Address of target data block<br/>;</pre> |                                                                 |                                                                                                                            |      |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|------|--|--|--|
|                                                                                                                                                                                   | ; Return registers<br>; AX = Zero                                                                                                                                                                                                                                                              |                                                                 | Comments                                                                                                                   |      |  |  |  |
| 0000:1000                                                                                                                                                                         | org                                                                                                                                                                                                                                                                                            | 1000h                                                           | ; Start at 0000:1000h                                                                                                      |      |  |  |  |
| 0000:1000<br>0000:1000 55<br>0000:1001 89 E5<br>0000:1003 06<br>0000:1004 8B 4E 06<br>0000:1007 E3 11<br>0000:1009 8B 76 04<br>0000:100C 8B 7E 02<br>0000:100F 1E<br>0000:1010 07 | _memcpy proc<br>push<br>mov<br>push<br>mov<br>jcxz<br>mov<br>pop                                                                                                                                                                                                                               | <pre>bp bp,sp es cx,[bp+6] done si,[bp+4] di,[bp+2] ds es</pre> | <pre>; Set up the call frame ; Save ES ; Set CX = len ; If len=0, return ; Set SI = src ; Set DI = dst ; Set ES = DS</pre> |      |  |  |  |
| 0000:1011 8A 04<br>0000:1013 88 05<br>0000:1015 46<br>0000:1016 47<br>0000:1017 49<br>0000:1018 75 F7                                                                             | loop mov<br>mov<br>inc<br>inc<br>dec<br>jnz                                                                                                                                                                                                                                                    | al,[si]<br>[di],al<br>si<br>di<br>cx<br>loop                    | <pre>; Load AL from [src] ; Store AL to [dst] ; Increment src ; Increment dst ; Decrement len ; Repeat the loop</pre>      |      |  |  |  |
| 0000:101A 07<br>0000:101B 5D<br>0000:101C 29 C0<br>0000:101E C3<br>0000:101F                                                                                                      | done pop<br>pop<br>sub<br>ret<br>end pro                                                                                                                                                                                                                                                       | es<br>bp<br>ax,ax                                               | ; Restore ES<br>; Restore previous call frame<br>; Set AX = 0<br>; Return<br>[http://en.wikipedia.org/wiki/Intel_80        | )86] |  |  |  |

## **Another Part of The Control Circuit**

#### A part of the control circuit for the processor



[Figure 7.10 from the textbook]

#### What are the components?



## 2-Bit Up-Counter



[Figure 7.10 from the textbook]

## **2-bit Synchronous Up-Counter**



## 2-bit Synchronous Up-Counter with Enable



## 2-to-4 Decoder with Enable Input



[Figure 7.10 from the textbook]

# 2-to-4 Decoder with an Enable Input



[Figure 4.13c from the textbook]

# 2-to-4 Decoder with an Enable Input



(always enabled in this example)





















# **Meaning/Explanation**

- This is like a FSM that cycles through its four states one after another.
- But it also can be reset to go to state 0 at any time.
- The implementation uses a counter followed by a decoder. The outputs of the decoder are one-hotencoded.
- This is like choosing a state assignment for an FSM in which there is one Flip-Flop per state, i.e., one-hot encoding (see Section 6.2.1 in the textbook)

# **Deriving the Control Signals**

# Design a FSM with input w and outputs

• Done

• R0<sub>in</sub> • A<sub>in</sub> • AddSub

• G<sub>out</sub>

- R0<sub>out</sub>
- R1<sub>in</sub> Gin
- R1<sub>out</sub>
- R2<sub>in</sub> Clear
- R2<sub>out</sub>
- R3<sub>in</sub> FR<sub>in</sub>
- R3<sub>out</sub>

- AddSub  $T_0$ •  $T_1$ • Extern •  $T_2$ 
  - $T_3$   $X_3$

• X<sub>0</sub>

• X<sub>1</sub>

• X<sub>2</sub>

 $\begin{array}{cccc}
\cdot \, I_{0} & \cdot \, Y_{0} \\
\cdot \, I_{1} & \cdot \, Y_{1} \\
\cdot \, I_{2} & \cdot \, Y_{2} \\
\cdot \, I_{3} & \cdot \, Y_{3}
\end{array}$ 

These are helper outputs that are one-hot encoded. They are used to simplify the expressions for the other outputs.



[Figure 7.9 from the textbook]



## **Another Control Signal**



[Figure 7.11 from the textbook]

## Yet Another Control Signal



[Figure 7.10 from the textbook]

### Expressing the 'FR<sub>in</sub>' signal



 $FR_{in} = w T_0$ 

Load a new operation into the function register

#### **Expressing the 'Clear' signal**



## Control signals asserted in each time step

|           | T <sub>1</sub>                                                         | T <sub>2</sub>                                        | T <sub>3</sub>                                  |
|-----------|------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------|
| (Load): I | D Extern<br>R <sub>in</sub> = X<br>Done                                |                                                       |                                                 |
| (Move): I | $ \begin{array}{c c} R_{in} &= X \\ R_{out} &= Y \\ Done \end{array} $ |                                                       |                                                 |
| (Add): I  | R <sub>out</sub> = X<br>A <sub>in</sub>                                | R <sub>out</sub> = Y<br>G <sub>in</sub><br>AddSub = 0 | G <sub>out</sub><br>R <sub>in</sub> = X<br>Done |
| (Sub): I  | R <sub>out</sub> = X<br>A <sub>in</sub>                                | R <sub>out</sub> = Y<br>G <sub>in</sub><br>AddSub = 1 | G <sub>out</sub><br>R <sub>in</sub> = X<br>Done |

## Control signals asserted in each time step



These are the outputs of the first 2-to-4 decoder that is connected to the two most significant bits of the function register. They are one-hot encoded so only one of them is active at any given time (see Fig 7.11).

[ Table 7.2 from the textbook ]

## The $I_0$ , $I_1$ , $I_2$ , $I_3$ and $T_0$ , $T_1$ , $T_2$ , $T_3$ Signals



### **Different Operations Take Different Amount of Time**



## **Operations performed by this processor**

| Operation |     |      | <b>Function Performed</b> |               |  |
|-----------|-----|------|---------------------------|---------------|--|
| Load      | Rx, | Data | Rx                        | 🗲 Data        |  |
| Move      | Rx, | Ry   | Rx                        | <b>←</b> [Ry] |  |
| Add       | Rx, | Ry   | Rx                        | ← [Rx] + [Ry] |  |
| Sub       | Rx, | Ry   | Rx                        | ← [Rx] - [Ry] |  |

Where Rx and Ry can be one of four possible options: R0, R1, R2, and R3

[Table 7.1 from the textbook]



### **Expressing the 'Extern' signal**



Extern =  $I_0 T_1$ 

#### **Expressing the 'Done' signal**



Done =  $(I_0 + I_1)T_1 + (I_2 + I_3)T_3$ 

### Expressing the 'A<sub>in</sub>' signal



 $A_{in} = (I_2 + I_3)T_1$ 

### Expressing the 'G<sub>in</sub>' signal



 $G_{in} = (I_2 + I_3)T_2$ 

### Expressing the 'G<sub>out</sub>' signal



 $G_{out} = (I_2 + I_3)T_3$ 

### Expressing the 'AddSub' signal



AddSub =  $I_3$ 

### Expressing the 'R0<sub>in</sub>' signal



 $R0_{in} = (I_0 + I_1)T_1X_0 + (I_2 + I_3)T_3X_0$ 

### Expressing the 'R1<sub>in</sub>' signal



 $R_{i_{1}}^{1} = (I_{0} + I_{1})T_{1}X_{1} + (I_{2} + I_{3})T_{3}X_{1}$ 

#### Expressing the 'R2<sub>in</sub>' signal



 $R_{in}^{2} = (I_{0} + I_{1})T_{1}X_{2} + (I_{2} + I_{3})T_{3}X_{2}$ 

#### Expressing the 'R3<sub>in</sub>' signal



 $R_{in}^{3} = (I_{0} + I_{1})T_{1}X_{3} + (I_{2} + I_{3})T_{3}X_{3}$ 

### Expressing the 'R0<sub>out</sub>' signal



 $R0_{out} = I_1T_1Y_0 + (I_2 + I_3)(T_1X_0 + T_2Y_0)$ 

### Expressing the 'R1<sub>out</sub>' signal



 $R_{out}^{1} = I_{1}T_{1}Y_{1} + (I_{2} + I_{3})(T_{1}X_{1} + T_{2}Y_{1})$ 

### Expressing the 'R2<sub>out</sub>' signal



 $R_{out}^{2} = I_{1}T_{1}Y_{2} + (I_{2} + I_{3})(T_{1}X_{2} + T_{2}Y_{2})$ 

### Expressing the 'R3<sub>out</sub>' signal



 $R_{out}^{3} = I_{1}T_{1}Y_{3} + (I_{2} + I_{3})(T_{1}X_{3} + T_{2}Y_{3})$ 

## **Derivation of the Control Inputs**

• For more insights into these derivations see pages 434 and 435 in the textbook

## **Some Additional Topics**

## The ALU for the Simple Processor



[Figure 7.9 from the textbook]

## **Another Arithmetic Logic Unit (ALU)**

- Arithmetic Logic Unit (ALU) computes arithmetic or logic functions
- Example: A four-function ALU has two selection bits S1 S0 (also called OpCode) to specify the function
  - 00 (ADD), 01 (SUB), 10 (AND), 11 (OR)
- Then the following set up will work

| <b>S1</b> | <b>S0</b> | Function |
|-----------|-----------|----------|
| 0         | 0         | ADD      |
| 0         | 1         | SUB      |
| 1         | 0         | AND      |
| 1         | 1         | OR       |



## An Alternative Design of Four-Function ALU

- The previous design is not very efficient as it uses an adder and a subtractor circuit
- We can design an add/subtract unit as discussed earlier
- Then we can design a logical unit (AND and OR) separately
- Then select appropriate output as result
- What are the control signals, Add/Sub, Select0, and Select1?



## Examples of Some Famous Microprocessors

# Intel's 4004 Chip



[http://en.wikipedia.org/wiki/Intel\_4004]

## **Technical specifications**

- Maximum clock speed was 740 kHz
- Instruction cycle time: 10.8 µs (8 clock cycles / instruction cycle)
- Instruction execution time 1 or 2 instruction cycles (10.8 or 21.6 µs), 46300 to 92600 instructions per second
- Built using 2,300 transistors

# **Technical specifications**

- Separate program and data storage.
- The 4004, with its need to keep pin count down, used a single multiplexed 4-bit bus for transferring:
  - 12-bit addresses
  - 8-bit instructions
  - 4-bit data words
- Instruction set contained 46 instructions (of which 41 were 8 bits wide and 5 were 16 bits wide)
- Register set contained 16 registers of 4 bits each
- Internal subroutine stack, 3 levels deep.



| Intel 4004 registers                                                                                                                               |     |         |                 |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------|-----------------|--|--|--|--|--|
| $^{1}_{1}$ $^{0}_{0}$ $^{0}_{9}$ $^{0}_{8}$ $^{0}_{7}$ $^{0}_{6}$ $^{0}_{5}$ $^{0}_{4}$ $^{0}_{3}$ $^{0}_{2}$ $^{0}_{1}$ $^{0}_{0}$ (bit position) |     |         |                 |  |  |  |  |  |
| Main registers                                                                                                                                     |     |         |                 |  |  |  |  |  |
|                                                                                                                                                    |     | Α       | Accumulator     |  |  |  |  |  |
|                                                                                                                                                    | R0  | R1      |                 |  |  |  |  |  |
|                                                                                                                                                    | R2  | R3      |                 |  |  |  |  |  |
|                                                                                                                                                    | R4  | R5      |                 |  |  |  |  |  |
|                                                                                                                                                    | R6  | R7      |                 |  |  |  |  |  |
|                                                                                                                                                    | R8  | R9      |                 |  |  |  |  |  |
|                                                                                                                                                    | R10 | R11     |                 |  |  |  |  |  |
|                                                                                                                                                    | R12 | R13     |                 |  |  |  |  |  |
|                                                                                                                                                    | R14 | R15     |                 |  |  |  |  |  |
| Program counter                                                                                                                                    |     |         |                 |  |  |  |  |  |
|                                                                                                                                                    | PC  |         | Program Counter |  |  |  |  |  |
| Push-down address call stack                                                                                                                       |     |         |                 |  |  |  |  |  |
|                                                                                                                                                    | PC1 |         | Call level 1    |  |  |  |  |  |
|                                                                                                                                                    | PC2 |         | Call level 2    |  |  |  |  |  |
|                                                                                                                                                    | PC3 |         | Call level 3    |  |  |  |  |  |
| Status register                                                                                                                                    |     |         |                 |  |  |  |  |  |
|                                                                                                                                                    |     | C P Z S | Flags           |  |  |  |  |  |
|                                                                                                                                                    |     |         |                 |  |  |  |  |  |

# Intel's 8086 Chip



[http://en.wikipedia.org/wiki/Intel\_8086]

| Intel 8086 registers                                                                                                                                                           |         |         |         |                                     |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|---------|-------------------------------------|--|--|--|--|--|
| $^{1}9$ $^{1}8$ $^{1}7$ $^{1}6$ $^{1}5$ $^{1}4$ $^{1}3$ $^{1}2$ $^{1}1$ $^{1}0$ $^{0}9$ $^{0}8$ $^{0}7$ $^{0}6$ $^{0}5$ $^{0}4$ $^{0}3$ $^{0}2$ $^{0}1$ $^{0}0$ (bit position) |         |         |         |                                     |  |  |  |  |  |
| Main registers                                                                                                                                                                 |         |         |         |                                     |  |  |  |  |  |
|                                                                                                                                                                                | AH      | A       | NL .    | AX (primary accumulator)            |  |  |  |  |  |
|                                                                                                                                                                                | BH      | BH E    |         | BX (base, accumulator)              |  |  |  |  |  |
|                                                                                                                                                                                | СН      | C       | L       | CX (counter, accumulator)           |  |  |  |  |  |
|                                                                                                                                                                                | DH      | DL      |         | DX (accumulator, other functions)   |  |  |  |  |  |
| Index registers                                                                                                                                                                |         |         |         |                                     |  |  |  |  |  |
| 0000                                                                                                                                                                           | SI      |         |         | Source Index                        |  |  |  |  |  |
| 0000                                                                                                                                                                           | DI      |         |         | Destination Index                   |  |  |  |  |  |
| 0000                                                                                                                                                                           | BP      |         |         | Base Pointer                        |  |  |  |  |  |
| 0000                                                                                                                                                                           | SP      |         |         | Stack Pointer                       |  |  |  |  |  |
| Program counter                                                                                                                                                                |         |         |         |                                     |  |  |  |  |  |
| 0000                                                                                                                                                                           | I       | Р       |         | Instruction Pointer                 |  |  |  |  |  |
| Segment registers                                                                                                                                                              |         |         |         |                                     |  |  |  |  |  |
|                                                                                                                                                                                | CS      |         | 0000    | Code Segment                        |  |  |  |  |  |
|                                                                                                                                                                                | DS      |         | 0000    | Data Segment                        |  |  |  |  |  |
|                                                                                                                                                                                | ES      |         |         | ExtraSegment                        |  |  |  |  |  |
|                                                                                                                                                                                | SS      |         | 0000    | Stack Segment                       |  |  |  |  |  |
| Status register                                                                                                                                                                |         |         |         |                                     |  |  |  |  |  |
|                                                                                                                                                                                | O D I T | S Z - A | - P - C | Flags<br>[http://en.wikipedia.org/w |  |  |  |  |  |

ki/Intel\_8086]



[http://en.wikipedia.org/wiki/Intel\_8086]

Simplified block diagram of Intel 8088 (a variant of 8086); 1=main registers; 2=segment registers and IP; 3=address adder; 4=internal address bus; 5=instruction queue; 6=control unit (very simplified!); 7=bus interface; 8=internal databus; 9=ALU; 10/11/12=external address/ data/control bus.

## **Questions?**

## THE END