



# CprE 2810: Digital Logic

**Instructor: Alexander Stoytchev**

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

# i281 CPU Architecture

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





i281 CPU



i281 CPU

# Drawing Convention

- Inputs enter from the left (for each box)
- Outputs exit from the right (for each box)
- Control lines are vertical arrows (come from the top)

# i281 CPU

- The CPU was designed specifically for this class 😊

# i281 CPU

- The CPU was designed specifically for this class 😊
- It was designed by:  
**Kyung-Tae Kim and Alexander Stoytchev**

# **i281 CPU Web Links**

**Download link for the software and hardware that comes with Bubble Sort preinstalled:**

[https://www.ece.iastate.edu/~alexs/classes/i281\\_CPU/](https://www.ece.iastate.edu/~alexs/classes/i281_CPU/)

**Download link for a ZIP file with the hardware version that comes with PONG preinstalled:**

[https://www.ece.iastate.edu/~alexs/classes/2024\\_Fall\\_2810/labs/Lab\\_13/](https://www.ece.iastate.edu/~alexs/classes/2024_Fall_2810/labs/Lab_13/)

**Web link for the i281 Simulator:**

[https://www.ece.iastate.edu/~alexs/classes/i281\\_simulator/index.html](https://www.ece.iastate.edu/~alexs/classes/i281_simulator/index.html)

# i281 Simulator



To try the simulator, go to the class web page and follow the link.

# How to Play Pong in the Simulator



The screenshot shows a web-based assembly language tool. At the top is a dark header bar with the text "i281 Assembler", "About", and "Examples ▾". The "Examples" menu is open, displaying a list of code examples categorized by topic. The categories include "Arithmetic", "Array", "If Statement", "Loops", "Search Algorithms", "Sorting Algorithms", "Struct", "Switch Statement", "Pong" (which is highlighted with a red rounded rectangle), "Bios Switches", and "7-segment". Below the header, the main content area has a large heading "Load Assembly File Below" and a blue button labeled "Load file".

- Arithmetic ➔
- Array ➔
- If Statement ➔
- Loops ➔
- Search Algorithms ➔
- Sorting Algorithms ➔
- Struct
- Switch Statement
- Pong
- Bios Switches
- 7-segment ➔

click on Examples and then select Pong

# Successfully Assembled

[Downloads ▾](#)

Syntax Highlighting: ON

[Load New File](#)[Go to CPU →](#)

← click the Green button

**Assembly Code:**

| <b>.data</b> |         |      |           |
|--------------|---------|------|-----------|
| 0...3        | empty   | BYTE | 0,0,0,0   |
| 4...7        | display | BYTE | 64,0,0,4  |
| 8...11       | shape   | BYTE | 64,8,64,1 |
| 12           | incDec  | BYTE | 1         |
| 13...15      | switch  | BYTE | 0,0,3     |
| <b>.code</b> |         |      |           |
| 0            | NOOP    |      |           |

Current Instruction:

i281 CPU Running: Pong

About



0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Speed:50

- Auto Mode on     Show Description  
 Game Mode on     Show Bus Width  
 Register View     Syntax Highlighting  
 Start PC @ 32     Show Data Path  
 Stop At End     Show Control Path

RUN

STEP

RESET

LOAD

# Game Mode in the Simulator



Two digital displays show the binary values 01000000 and 00000000. To the right, the word "End" is displayed in red on a grey background.

0 1      0 0 0 0 0 0 0 0      0 0 0 0 0 0 0 0



A horizontal progress bar with a black dot at the far right end, indicating completion.

Speed:100

- |                                                  |                                                         |
|--------------------------------------------------|---------------------------------------------------------|
| <input checked="" type="checkbox"/> Auto Mode on | <input type="checkbox"/> Show Description               |
| <input checked="" type="checkbox"/> Game Mode on | <input type="checkbox"/> Show Bus Width                 |
| <input type="checkbox"/> Register View           | <input checked="" type="checkbox"/> Syntax Highlighting |
| <input type="checkbox"/> Start PC @ 32           | <input checked="" type="checkbox"/> Show Data Path      |
| <input checked="" type="checkbox"/> Stop At End  | <input checked="" type="checkbox"/> Show Control Path   |

RUN

STEP

RESET

LOAD

# Game Mode in the Simulator

The screenshot shows a digital display with two rows of seven segments each. The top row displays '88 88' in gray, and the bottom row displays 'End' in red. Below the display is a row of 16 small rectangular buttons labeled from 0 to 9. The button at index 6 is highlighted with a red box. To the right of the display, a red text box contains the instruction: "click on Switch 6 to move the paddle up/down".

Below the display is a horizontal slider with a black handle, set to the value 100. To the left of the slider, the text "Speed:100" is displayed. To the right of the slider, a red text box contains the instruction: "use the slider to increase the sped to 100".

On the left side of the interface, the text "check these two boxes" is displayed in red, pointing to two checkboxes. These checkboxes are highlighted with a red border and contain the following options:

- Auto Mode on
- Game Mode on
- Register View
- Start PC @ 32
- Stop At End

On the right side, there are four more checkboxes:

- Show Description
- Show Bus Width
- Syntax Highlighting
- Show Data Path
- Show Control Path

At the bottom of the interface are four buttons: RUN, STEP, RESET, and LOAD.

# Game Mode in the Simulator



Two digital displays show the binary values 01000000 and 00000000. To the right, the word "End" is displayed in red on a grey background.

0 1      0 0 0 0 0 0 0      0 0 0 0 0 0 0 0



A horizontal progress bar with a black slider at the 100 mark, indicating the current speed of the simulation.

Speed:100

- |                                                  |                                                         |
|--------------------------------------------------|---------------------------------------------------------|
| <input checked="" type="checkbox"/> Auto Mode on | <input type="checkbox"/> Show Description               |
| <input checked="" type="checkbox"/> Game Mode on | <input type="checkbox"/> Show Bus Width                 |
| <input type="checkbox"/> Register View           | <input checked="" type="checkbox"/> Syntax Highlighting |
| <input type="checkbox"/> Start PC @ 32           | <input checked="" type="checkbox"/> Show Data Path      |
| <input checked="" type="checkbox"/> Stop At End  | <input checked="" type="checkbox"/> Show Control Path   |

RUN

STEP

RESET

LOAD

click reset to play again

# The i281 Simulator Was Implemented by a Senior Design Team (Fall 2020/Spring 2021)



# The i281 Simulator Was Implemented by a Senior Design Team (Fall 2020/Spring 2021)



# **The i281e CPU**



**The hardware version of the i281 was implemented by another Senior Design Team (Fall 2023/Spring 2024)**



# **The CPU Components**



i281 CPU





i281 CPU



i281 CPU



















i281 CPU



## i281 CPU



## i281 CPU



i281 CPU





These 16 switches are used for input into the Code Memory.



0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0



These 8 switches are used for input into the Data Memory.



0 1 0 0 0 0 0 0



This switch controls  
the paddle in PONG

0 1 0 0 0 0 0 0







i281 CPU





i281 CPU



i281 CPU



i281 CPU





# **The Memory Layout**

# **Memory Layout**

- **The i281 CPU uses two different memories**



# **Memory Layout**

- The i281 CPU uses two different memories
  - Data Memory  
16 x 8 bits
  - Code Memory  
64 x 16 bits

# **Memory Layout**

- The i281 CPU uses two different memories

- Data Memory

**16 x 8 bits**

- Code Memory

**64 x 16 bits**

**Note that they have different number of bits**

# **Memory Layout**

- The i281 CPU uses two different memories
  - Data Memory  
**16 x 8 bits ( only 16 bytes! )**
  - Code Memory  
**64 x 16 bits ( only 128 bytes! )**

**This is a combined total of 144 bytes!**

# **Memory Layout**

- The i281 CPU uses two different memories
    - Data Memory  
**16 x 8 bits ( only 16 bytes! )**
    - Code Memory  
**64 x 16 bits ( only 128 bytes! )**
- This is a combined total of 144 bytes!  
Which is enough to represent 48 pixels on this slide!

# **Data Memory Layout**

- Organized as one contiguous block
- Data Memory
  - Random access
  - Read/write memory
  - 16 x 8 bits
  - Only 16 bytes!

# Data Memory Layout

- Organized as one contiguous block
- Data Memory
  - Random access
  - Read/write memory
  - 16 x 8 bits
  - Only 16 bytes!

Implemented as a register file with 16 registers, each of which is 8-bits wide.

The register file has one read port and one write port. It also has a write enable input.

# **Video Card**

## **Memory-mapped video memory**

**The first 8 bytes of the data memory are connected to the 7-segment displays on the Altera board**

**Writing to these memory cells automatically lights up the displays, which use only the 4 least significant bits**

**In video game mode each LED is controlled separately using a different set of 7-segment decoders & all 8 bits**

**The contents of the second 8 bytes of the data memory cannot be visualized, but programs can still use them**

# Data Memory Contents for the Bubble Sort Program

```
00000111
00000011
00000010
00000001
00000110
00000100
00000101
00001000
00000111
00000000
00000000
00000000
00000000
00000000
00000000
00000000
```

# Data Memory Contents for the Bubble Sort Program

| Address | Data     |
|---------|----------|
| 0000    | 00000111 |
| 0001    | 00000011 |
| 0010    | 00000010 |
| 0011    | 00000001 |
| 0100    | 00000110 |
| 0101    | 00000100 |
| 0110    | 00000101 |
| 0111    | 00001000 |
| 1000    | 00000111 |
| 1001    | 00000000 |
| 1010    | 00000000 |
| 1011    | 00000000 |
| 1100    | 00000000 |
| 1101    | 00000000 |
| 1110    | 00000000 |
| 1111    | 00000000 |

# Data Memory Contents for the Bubble Sort Program

| Address | Data     | Comment    |
|---------|----------|------------|
| 0000    | 00000111 | //array[0] |
| 0001    | 00000011 | //array[1] |
| 0010    | 00000010 | //array[2] |
| 0011    | 00000001 | //array[3] |
| 0100    | 00000110 | //array[4] |
| 0101    | 00000100 | //array[5] |
| 0110    | 00000101 | //array[6] |
| 0111    | 00001000 | //array[7] |
| 1000    | 00000111 | //last     |
| 1001    | 00000000 | //temp     |
| 1010    | 00000000 |            |
| 1011    | 00000000 |            |
| 1100    | 00000000 |            |
| 1101    | 00000000 |            |
| 1110    | 00000000 |            |
| 1111    | 00000000 |            |

# Memory-Mapped Video Memory

| Address | Data     |
|---------|----------|
| 0000    | 00000111 |
| 0001    | 00000011 |
| 0010    | 00000010 |
| 0011    | 00000001 |
| 0100    | 00000110 |
| 0101    | 00000100 |
| 0110    | 00000101 |
| 0111    | 00001000 |
| 1000    | 00000111 |
| 1001    | 00000000 |
| 1010    | 00000000 |
| 1011    | 00000000 |
| 1100    | 00000000 |
| 1101    | 00000000 |
| 1110    | 00000000 |
| 1111    | 00000000 |

# Memory-Mapped Video Memory

| Address | Data     |
|---------|----------|
| 0000    | 00000111 |
| 0001    | 00000011 |
| 0010    | 00000010 |
| 0011    | 00000001 |
| 0100    | 00000110 |
| 0101    | 00000100 |
| 0110    | 00000101 |
| 0111    | 00001000 |
| 1000    | 00000111 |
| 1001    | 00000000 |
| 1010    | 00000000 |
| 1011    | 00000000 |
| 1100    | 00000000 |
| 1101    | 00000000 |
| 1110    | 00000000 |
| 1111    | 00000000 |

# Memory-Mapped Video Memory



# Memory-Mapped Video Memory

| Address | Data     |                                                                                                 |
|---------|----------|-------------------------------------------------------------------------------------------------|
| 0000    | 00000111 | █                                                                                               |
| 0001    | 00000011 | █                                                                                               |
| 0010    | 00000010 | █                                                                                               |
| 0011    | 00000001 | █                                                                                               |
| 0100    | 00000110 | █                                                                                               |
| 0101    | 00000100 | █                                                                                               |
| 0110    | 01100101 | █                                                                                               |
| 0111    | 00001000 | █                                                                                               |
| 1000    | 00000111 |                                                                                                 |
| 1001    | 00000000 | Changing these bits<br>will not affect what is<br>displayed, but it will<br>affect the program. |
| 1010    | 00000000 |                                                                                                 |
| 1011    | 00000000 |                                                                                                 |
| 1100    | 00000000 |                                                                                                 |
| 1101    | 00000000 |                                                                                                 |
| 1110    | 00000000 |                                                                                                 |
| 1111    | 00000000 |                                                                                                 |

# Memory-Mapped Video Memory

| Address | Data     |                                                                                                 |
|---------|----------|-------------------------------------------------------------------------------------------------|
| 0000    | 01000111 | █                                                                                               |
| 0001    | 00010011 | █                                                                                               |
| 0010    | 10000010 | █                                                                                               |
| 0011    | 01000001 | █                                                                                               |
| 0100    | 00010110 | █                                                                                               |
| 0101    | 10000100 | █                                                                                               |
| 0110    | 01100101 | █                                                                                               |
| 0111    | 01001000 | █                                                                                               |
| 1000    | 00000111 |                                                                                                 |
| 1001    | 00000000 | Changing these bits<br>will not affect what is<br>displayed, but it will<br>affect the program. |
| 1010    | 00000000 |                                                                                                 |
| 1011    | 00000000 |                                                                                                 |
| 1100    | 00000000 |                                                                                                 |
| 1101    | 00000000 |                                                                                                 |
| 1110    | 00000000 |                                                                                                 |
| 1111    | 00000000 |                                                                                                 |

# Memory-Mapped Video Memory

| Address | Data     |
|---------|----------|
| 0000    | 00000111 |
| 0001    | 00000011 |
| 0010    | 00000010 |
| 0011    | 00000001 |
| 0100    | 00000110 |
| 0101    | 00000100 |
| 0110    | 00000101 |
| 0111    | 00001000 |
| 1000    | 00000111 |
| 1001    | 00000000 |
| 1010    | 00000000 |
| 1011    | 00000000 |
| 1100    | 00000000 |
| 1101    | 00000000 |
| 1110    | 00000000 |
| 1111    | 00000000 |

This memory cell  
is used by the program,  
but it cannot be visualized  
on the 7-segment displays.

# Memory-Mapped Video Memory

| Address | Data     |
|---------|----------|
| 0000    | 00000111 |
| 0001    | 00000011 |
| 0010    | 00000010 |
| 0011    | 00000001 |
| 0100    | 00000110 |
| 0101    | 00000100 |
| 0110    | 00000101 |
| 0111    | 00001000 |
| 1000    | 00000111 |
| 1001    | 00000000 |
| 1010    | 00000000 |
| 1011    | 00000000 |
| 1100    | 00000000 |
| 1101    | 00000000 |
| 1110    | 00000000 |
| 1111    | 00000000 |

All of these cannot be visualized  
on the 7-segment displays.

# Memory-Mapped Video Memory in Video Game Mode

| Address | Data     |
|---------|----------|
| 0000    | 00000000 |
| 0001    | 00000000 |
| 0010    | 00000000 |
| 0011    | 00000000 |
| 0100    | 01111001 |
| 0101    | 01010100 |
| 0110    | 01011110 |
| 0111    | 00000000 |
| 1000    | 00000000 |
| 1001    | 00000000 |
| 1010    | 00000000 |
| 1011    | 00000000 |
| 1100    | 00000000 |
| 1101    | 00000000 |
| 1110    | 00000000 |
| 1111    | 00000000 |

# Memory-Mapped Video Memory in Video Game Mode

| Address | Data     |
|---------|----------|
| 0000    | 00000000 |
| 0001    | 00000000 |
| 0010    | 00000000 |
| 0011    | 00000000 |
| 0100    | 01111001 |
| 0101    | 01010100 |
| 0110    | 01011110 |
| 0111    | 00000000 |
| 1000    | 00000000 |
| 1001    | 00000000 |
| 1010    | 00000000 |
| 1011    | 00000000 |
| 1100    | 00000000 |
| 1101    | 00000000 |
| 1110    | 00000000 |
| 1111    | 00000000 |

# Memory-Mapped Video Memory in Video Game Mode

| Address | Data     |
|---------|----------|
| 0000    | 00000000 |
| 0001    | 00000000 |
| 0010    | 00000000 |
| 0011    | 00000000 |
| 0100    | 01111001 |
| 0101    | 01010100 |
| 0110    | 01011110 |
| 0111    | 00000000 |
| 1000    | 00000000 |
| 1001    | 00000000 |
| 1010    | 00000000 |
| 1011    | 00000000 |
| 1100    | 00000000 |
| 1101    | 00000000 |
| 1110    | 00000000 |
| 1111    | 00000000 |



In this case the last 7 bits  
are used and each controls  
one of the 7 LEDs.

# **Code Memory Layout**

- Split into two parts
- BIOS Code Memory (addresses 0 to 31)
  - Read only memory
  - 32 x 16 bits
- User Code Memory (addresses 32 to 63)
  - Read only memory (in User mode)
  - Read/Write memory (in BIOS mode)
  - 32 x 16 bits



This shows only the first half  
of the data memory

i281 CPU



i281 CPU

# **The OPCODE Decoder**



i281 CPU

# The i281 Assembly Instructions

|         |                                                    |
|---------|----------------------------------------------------|
| NOOP    | NO OPERATION                                       |
| INPUTC  | INPUT into Code memory                             |
| INPUTCF | INPUT into Code memory with offset                 |
| INPUTD  | INPUT into Data memory                             |
| INPUTDF | INPUT into Data memory with offset                 |
| MOVE    | MOVE the contents of one register into another     |
| LOADI   | LOAD Immediate value                               |
| LOADP   | LOAD Pointer address                               |
| ADD     | ADD two registers                                  |
| ADDI    | ADD an Immediate value to a register               |
| SUB     | SUBtract two registers                             |
| SUBI    | SUBtract an Immediate value from a register        |
| LOAD    | LOAD from a data memory address into a register    |
| LOADF   | LOAD with an offset specified by another register  |
| STORE   | STORE a register into a data memory address        |
| STOREF  | STORE with an offset specified by another register |
| SHIFTL  | SHIFT Left all bits in a register                  |
| SHIFTR  | SHIFT Right all bits in a register                 |
| CMP     | CoMPare the values in two registers                |
| JUMP    | JUMP unconditionally to a specified address        |
| BRE     | BRanch if Equal                                    |
| BRZ     | BRanch if Zero                                     |
| BRNE    | BRanch if Not Equal                                |
| BRNZ    | BRanch if Not Zero                                 |
| BRG     | BRanch if Greater                                  |
| BRGE    | BRanch if Greater than or Equal                    |

# The i281 Assembly Instructions

|         |                                                    |
|---------|----------------------------------------------------|
| NOOP    | NO OPeration                                       |
| INPUTC  | INPUT into Code memory                             |
| INPUTCF | INPUT into Code memory with offset                 |
| INPUTD  | INPUT into Data memory                             |
| INPUTDF | INPUT into Data memory with offset                 |
| MOVE    | MOVE the contents of one register into another     |
| LOADI   | LOAD Immediate value                               |
| LOADP   | LOAD Pointer address                               |
| ADD     | ADD two registers                                  |
| ADDI    | ADD an Immediate value to a register               |
| SUB     | SUBtract two registers                             |
| SUBI    | SUBtract an Immediate value from a register        |
| LOAD    | LOAD from a data memory address into a register    |
| LOADF   | LOAD with an offset specified by another register  |
| STORE   | STORE a register into a data memory address        |
| STOREF  | STORE with an offset specified by another register |
| SHIFTL  | SHIFT Left all bits in a register                  |
| SHIFTR  | SHIFT Right all bits in a register                 |
| CMP     | COMPARE the values in two registers                |
| JUMP    | JUMP unconditionally to a specified address        |
| BRE     | BRanch if Equal                                    |
| BRZ     | BRanch if Zero                                     |
| BRNE    | BRanch if Not Equal                                |
| BRNZ    | BRanch if Not Zero                                 |
| BRG     | BRanch if Greater                                  |
| BRGE    | BRanch if Greater than or Equal                    |

# There are only 26 OPCODEs

|         |        |        |
|---------|--------|--------|
| NOOP    | ADD    | SHIFTL |
| INPUTC  | ADDI   | SHIFTR |
| INPUTCF | SUB    | CMP    |
| INPUTD  | SUBI   | JUMP   |
| INPUTDF | LOAD   | BRE    |
| MOVE    | LOADF  | BRZ    |
| LOADI   | STORE  | BRNE   |
| LOADP   | STOREF | BRNZ   |
|         |        | BRG    |
|         |        | BRGE   |

# There are only 26 OPCODEs

|         |        |        |
|---------|--------|--------|
| NOOP    | ADD    | SHIFTL |
| INPUTC  | ADDI   | SHIFTR |
| INPUTCF | SUB    | CMP    |
| INPUTD  | SUBI   | JUMP   |
| INPUTDF | LOAD   | BRE    |
| MOVE    | LOADF  | BRZ    |
| LOADI   | STORE  | BRNE   |
| LOADP   | STOREF | BRNZ   |
|         |        | BRG    |
|         |        | BRGE   |

All of these are available in the assembly language for this processor.  
However, three pairs are aliased at the machine language level.

25

# There are only ~~26~~ OPCODEs

|                          |        |        |
|--------------------------|--------|--------|
| NOOP                     | ADD    | SHIFTL |
| INPUTC                   | ADDI   | SHIFTR |
| INPUTCF                  | SUB    | CMP    |
| INPUTD                   | SUBI   | JUMP   |
| INPUTDF                  | LOAD   | BRE    |
| MOVE                     | LOADF  | BRZ    |
| LOADI                    | STORE  | BRNE   |
| LOADP                    | STOREF | BRNZ   |
| these two<br>are aliased |        | BRG    |
|                          |        | BRGE   |

They have a different meaning in the assembly language, but the assembler maps them to the same machine language OPCODE.

There are only ~~26~~<sup>25</sup> OPCODEs

|             |        |        |
|-------------|--------|--------|
| NOOP        | ADD    | SHIFTL |
| INPUTC      | ADDI   | SHIFTR |
| INPUTCF     | SUB    | CMP    |
| INPUTD      | SUBI   | JUMP   |
| INPUTDF     | LOAD   | BRE    |
| MOVE        | LOADF  | BRZ    |
| LOADI/LOADP | STORE  | BRNE   |
|             | STOREF | BRNZ   |
|             |        | BRG    |
|             |        | BRGE   |

24  
There are only ~~26~~ OPCODEs

|             |        |        |
|-------------|--------|--------|
| NOOP        | ADD    | SHIFTL |
| INPUTC      | ADDI   | SHIFTR |
| INPUTCF     | SUB    | CMP    |
| INPUTD      | SUBI   | JUMP   |
| INPUTDF     | LOAD   | BRE    |
| MOVE        | LOADF  | BRZ    |
| LOADI/LOADP | STORE  | BRNE   |
|             | STOREF | BRNZ   |
|             |        | BRG    |
|             |        | BRGE   |

these two  
are aliased

23  
There are only ~~26~~ OPCODEs

|             |        |        |
|-------------|--------|--------|
| NOOP        | ADD    | SHIFTL |
| INPUTC      | ADDI   | SHIFTR |
| INPUTCF     | SUB    | CMP    |
| INPUTD      | SUBI   | JUMP   |
| INPUTDF     | LOAD   | BRE    |
| MOVE        | LOADF  | BRZ    |
| LOADI/LOADP | STORE  | BRNE   |
|             | STOREF | BRNZ   |
|             |        | BRG    |
|             |        | BRGE   |

these two  
are aliased

these two  
are aliased

# There are only 23 OPCODEs

|             |        |           |
|-------------|--------|-----------|
| NOOP        | ADD    | SHIFTL    |
| INPUTC      | ADDI   | SHIFTR    |
| INPUTCF     | SUB    | CMP       |
| INPUTD      | SUBI   | JUMP      |
| INPUTDF     | LOAD   | BRE/BRZ   |
| MOVE        | LOADF  | BRNE/BRNZ |
| LOADI/LOADP | STORE  | BRG       |
|             | STOREF | BRGE      |



i281 CPU









i281 CPU







|                       |                       |                       |                       |                       |                       |                      |                      |
|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|----------------------|----------------------|
| <b>I<sub>15</sub></b> | <b>I<sub>14</sub></b> | <b>I<sub>13</sub></b> | <b>I<sub>12</sub></b> | <b>I<sub>11</sub></b> | <b>I<sub>10</sub></b> | <b>I<sub>9</sub></b> | <b>I<sub>8</sub></b> |
|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|----------------------|----------------------|









i281 CPU

# **The Control Logic**



i281 CPU



23 one-hot encoded lines from OPCODE decoder

## 18 control lines

23 one-hot  
encoded  
OPCODEs

Taken from  
these bits of the  
instruction



|             | $c_1$ | $c_2$ | $c_3$         | $c_4$ | $c_5$ | $c_6$ | $c_7$ | $c_8$ | $c_9$ | $c_{10}$ | $c_{11}$ | $c_{12}$ | $c_{13}$ | $c_{14}$ | $c_{15}$ | $c_{16}$ | $c_{17}$ | $c_{18}$ |
|-------------|-------|-------|---------------|-------|-------|-------|-------|-------|-------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| NOOP        |       |       | 1             |       |       |       |       |       |       |          |          |          |          |          |          |          |          |          |
| INPUTC      | 1     |       | 1             |       |       |       |       |       |       |          |          |          |          |          |          |          |          |          |
| INPUTCF     | 1     |       | 1 X1 X0       |       |       |       |       |       |       |          |          |          | 1 1      |          |          |          |          |          |
| INPUTD      |       |       | 1             |       |       |       |       |       |       |          |          |          |          |          | 1 1 1    |          |          |          |
| INPUTDF     |       |       | 1 X1 X0       |       |       |       |       |       |       |          |          |          | 1 1      |          |          | 1 1      |          |          |
| MOVE        |       |       | 1 Y1 Y0       |       | X1 X0 | 1     | 1     | 1     |       |          |          |          |          |          |          |          |          |          |
| LOADI/LOADP |       |       | 1             |       |       | X1 X0 | 1     |       |       |          |          |          |          |          | 1        |          |          |          |
| ADD         |       |       | 1 X1 X0 Y1 Y0 | X1 X0 | 1     |       |       |       |       |          |          |          | 1        |          |          |          |          |          |
| ADDI        |       |       | 1 X1 X0       |       | X1 X0 | 1     | 1     | 1     |       |          |          |          | 1        |          |          |          |          |          |
| SUB         |       |       | 1 X1 X0 Y1 Y0 | X1 X0 | 1     |       |       |       |       |          |          |          | 1 1 1    |          |          |          |          |          |
| SUBI        |       |       | 1 X1 X0       |       | X1 X0 | 1     | 1     | 1     | 1     |          |          |          |          |          |          |          |          |          |
| LOAD        |       |       | 1 Y1 Y0       |       | X1 X0 | 1     |       |       |       |          |          |          |          | 1        |          |          | 1        |          |
| LOADF       |       |       | 1 Y1 Y0       |       | X1 X0 | 1     | 1     | 1     |       |          |          |          |          |          |          |          | 1        |          |
| STORE       |       |       | 1             |       | X1 X0 |       |       |       |       |          |          |          |          | 1        |          |          | 1        |          |
| STOREF      |       |       | 1 Y1 Y0 X1 X0 |       |       |       |       |       |       | 1 1      |          |          |          |          |          |          | 1        |          |
| SHIFTL      |       |       | 1 X1 X0       |       | X1 X0 | 1     |       |       |       |          |          |          |          | 1        |          |          |          |          |
| SHIFTR      |       |       | 1 X1 X0       |       | X1 X0 | 1     |       |       |       |          |          |          | 1 1      |          |          |          |          |          |
| CMP         |       |       | 1 X1 X0 Y1 Y0 |       |       |       |       |       |       |          | 1 1 1    |          |          |          |          |          |          |          |
| JUMP        | 1     | 1     |               |       |       |       |       |       |       |          |          |          |          |          |          |          |          |          |
| BRE/BRZ     | B1    | 1     |               |       |       |       |       |       |       |          |          |          |          |          |          |          |          |          |
| BRNE/BRNZ   | B2    | 1     |               |       |       |       |       |       |       |          |          |          |          |          |          |          |          |          |
| BRG         | B3    | 1     |               |       |       |       |       |       |       |          |          |          |          |          |          |          |          |          |
| BRGE        | B4    | 1     |               |       |       |       |       |       |       |          |          |          |          |          |          |          |          |          |

computed using  
the flags register

B1= ZF  
B2= ~ZF  
B3= AND (~ZF, XNOR(NF, OF))  
B4= XNOR(NF, OF)

Zero Flag (ZF)  
Negative Flag (NF)  
Overflow Flag (OF)

# **The Control Signals**



i281 CPU



i281 CPU



i281 CPU



## i281 CPU



i281 CPU



## i281 CPU



i281 CPU



i281 CPU



i281 CPU



i281 CPU



i281 CPU



i281 CPU



i281 CPU



i281 CPU



i281 CPU



# **The Five Bus Multiplexers**





i281 CPU

# 2-to-1 Bus Multiplexer (with 8-bit lines)





















i281 CPU





i281 CPU









i281 CPU



# 2-to-1 Bus Multiplexer (with 6-bit lines)



# 2-to-1 Bus Multiplexer (with 6-bit lines)



Note that the 0 and the 1 are swapped  
(in order to simplify the large diagram).







# **The Four Registers**





i281 CPU



## i281 CPU



i281 CPU



i281 CPU

# Register A



8-Bit Parallel-Access Register

# Register A



# Register A



8-Bit Parallel-Access Register

# Register B



8-Bit Parallel-Access Register

# Register C



8-Bit Parallel-Access Register

# Register D



8-Bit Parallel-Access Register



# 4-to-1 Bus Multiplexer (with 8-bit lines)





























i281 CPU

# 4-to-1 Bus Multiplexer (with 8-bit lines)







These 8 lines form the output bus  
for Port\_1 of the register file.













# **The Data Memory**





i281 CPU

# 8-Bit Parallel-Access Register



# **The Code Memory**



i281 CPU



i281 CPU

# 16-Bit Parallel-Access Register



**To Be Covered  
Next Time**





i281 CPU



i281 CPU



i281 CPU

# **Some Additional Topics**

# **Examples of Some Famous Microprocessors**

# Intel's 4004 Chip



[[http://en.wikipedia.org/wiki/Intel\\_4004](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

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

# **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.

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

## Intel 4004 Architecture



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

### *Intel 4004 registers*

$^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

|     | A   | 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](http://en.wikipedia.org/wiki/Intel_8086)]

### *Intel 8086 registers*

1<sub>9</sub> 1<sub>8</sub> 1<sub>7</sub> 1<sub>6</sub> 1<sub>5</sub> 1<sub>4</sub> 1<sub>3</sub> 1<sub>2</sub> 1<sub>1</sub> 1<sub>0</sub> 0<sub>9</sub> 0<sub>8</sub> 0<sub>7</sub> 0<sub>6</sub> 0<sub>5</sub> 0<sub>4</sub> 0<sub>3</sub> 0<sub>2</sub> 0<sub>1</sub> 0<sub>0</sub> (bit position)

#### Main registers

|    |    |                                          |
|----|----|------------------------------------------|
| AH | AL | <b>AX</b> (primary accumulator)          |
| BH | BL | <b>BX</b> (base, accumulator)            |
| CH | CL | <b>CX</b> (counter, accumulator)         |
| DH | DL | <b>DX</b> (accumulator, other functions) |

#### Index registers

|         |    |                   |
|---------|----|-------------------|
| 0 0 0 0 | SI | Source Index      |
| 0 0 0 0 | DI | Destination Index |
| 0 0 0 0 | BP | Base Pointer      |
| 0 0 0 0 | SP | Stack Pointer     |

#### Program counter

|         |    |                     |
|---------|----|---------------------|
| 0 0 0 0 | IP | Instruction Pointer |
|---------|----|---------------------|

#### Segment registers

|    |         |               |
|----|---------|---------------|
| CS | 0 0 0 0 | Code Segment  |
| DS | 0 0 0 0 | Data Segment  |
| ES | 0 0 0 0 | ExtraSegment  |
| SS | 0 0 0 0 | Stack Segment |

#### Status register



[[http://en.wikipedia.org/wiki/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**