### **Computer Organization**

#### Instruction Set Characteristics, Instruction Formats, Addressing Modes, RTL & Micro-Operations, CISC, RISC.

Chapters (10 + 11 + Mano Ch.4 + 13)

# **The Von Neumann Computer Model**

- Partitioning of the computing engine into components:

   <u>Central Processing Unit (CPU)</u>: Control Unit (instruction decode, sequencing of operations), Datapath (registers, arithmetic and logic unit, buses).
  - <u>Memory</u>: Instruction and operand storage.
  - <u>Input/Output (I/O) sub-system</u>: I/O bus, interfaces, devices.
  - <u>The stored program concept</u>: Instructions from an instruction set are fetched from a common memory and <u>executed one at a time</u>



Major CPU Performance Limitation: The Von Neumann computing model implies <u>sequential</u> <u>execution</u> one instruction at a time

# **Hierarchy of Computer Architecture**



# **How to Speak Computer**



#### Need translation from application to physics

# **Generic CPU Machine Instruction Execution Steps**



# **Computing Element Choices**

- General Purpose Processors (GPPs): Intended for general purpose computing (desktops, servers, clusters..)
- Application-Specific Processors (ASPs): Processors with ISAs and architectural features tailored towards specific application domains
  - E.g Digital Signal Processors (DSPs), Network Processors (NPs), Media Processors, Graphics Processing Units (GPUs), Vector Processors??? ...
- <u>Co-Processors</u>: A hardware (hardwired) implementation of specific algorithms with limited programming interface (augment GPPs or ASPs)
- <u>Configurable Hardware:</u>
  - Field Programmable Gate Arrays (FPGAs)
  - Configurable array of simple processing elements
- Application Specific Integrated Circuits (ASICs): A custom VLSI hardware solution for a specific computational task
- The choice of one or more depends on a number of factors including:
  - Type and complexity of computational algorithm (general purpose vs. Specialized)
  - Desired level of flexibility/ programmability
  - Development cost/time System cost
  - Power requirements

- Performance requirements
- 6
- Real-time constrains

#### **Instruction Set Characteristics**

Chapter 10

## **Instruction Set Architecture (ISA)**

- Complete set of instructions used by a machine
- Abstract interface between the HW and lowestlevel SW.
- An ISA includes the following ...
  - Instructions and Instruction Formats
    - Data Types, Encodings, and Representations
    - Programmable Storage: Registers and Memory
    - Addressing Modes: to address Instructions and Data
    - Handling Exceptional Conditions (like division by zero)
- Examples(Versions) First Introduced in
  - -Intel (8086, 80386, Pentium, ...) 1978
  - -MIPS (MIPS I, II, III, IV, V) 1986
  - PowerPC (601, 604, ...) 1993

# **The Instruction Set Architecture**

- ISA is considered part of the SW
- Must be designed to survive changes in hardware technology, software technology, and application characteristic.
   —Is the agreed-upon interface between all the software that runs on the machine and the hardware that executes it.
- Advantages:
  - Different implementations of the same architecture
  - -Easier to change than HW
  - -Standardizes instructions, machine language bit patterns, etc.
- Disadvantage:
  - -Sometimes prevents using new innovations

# Instruction Set Architecture: Critical Interface



- Properties of a good abstraction
  - Lasts through many generations (portability)
  - Used in many different ways (generality)
  - Provides convenient functionality to higher levels
  - Permits an efficient implementation at lower levels

## **Elements of an Instruction**

- Operation code (Op code)
   —Specify the operation (e.g., ADD, I/O)
- Source Operand reference
  - Operands that are input to the operation.
- Result Operand reference
  - -Put the answer here
- Next Instruction Reference
  - Tells the processor where to fetch the next instruction

## **Instruction Representation**

- In machine code each instruction has a unique bit pattern
- For human consumption (well, programmers anyway) a symbolic representation is used

-e.g. ADD, SUB, LOAD

Operands can also be represented in this way

-ADD A,B

### **Simple Instruction Format**



#### Where have all the Operands Gone? Where is the next instruction to be fetched?

- Main memory (or virtual memory or cache)
- CPU register
- I/O device

# **Typical Instructions**

| Data Movement         | Load (from memory)<br>memory-to-memory move<br>input (from I/O device)<br>push, pop (to/from stack)                                                     | Store (to memory)<br>register-to-register move<br>output (to I/O device) |  |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--|
| Arithmetic            | Data Types: (signed & unsigned) Integer (binary + decimal)<br>(signed & unsigned) Floating Point Numbers<br>Operations: Add, Subtract, Multiply, Divide |                                                                          |  |
| Logical               | Not, and, or, set, clear                                                                                                                                |                                                                          |  |
| Shift                 | Arithmetic (& Logical) shift (left/right), rotate (left/right)                                                                                          |                                                                          |  |
| Control (Jump/Branch) | unconditional, conditional                                                                                                                              |                                                                          |  |
| Subroutine Linkage    | call, return                                                                                                                                            |                                                                          |  |
| Interrupt             | trap, return                                                                                                                                            |                                                                          |  |
| Synchronisation       | test & set (atomic r-m-w)                                                                                                                               |                                                                          |  |
| String                | search, compare, translate                                                                                                                              |                                                                          |  |

#### **Types of Operation**

#### Shift and Rotate Operations





## **Types of Operation**

- Input/Output
  - —May be specific instructions
  - —May be done using data movement instructions (memory mapped)
  - -May be done by a separate controller (DMA)
- Systems Control
  - -For operating systems use

## **Transfer of Control**

## • Branch

- -e.g. **BRZ X** branch to x if result of (ADD,SUB,...) is zero
- Uses condition bits register
- See next slide
- Skip
  - —e.g. increment and skip if zero ISZ 301
  - \* eg. R1is set to -1000, the loop will be executed 1000 times
- Subroutine call
  - -c.f. interrupt call

### **Branch Instruction**



## **Procedure Calls Instructions**

- Computer program that is incorporated with larger program.
- At any point in the program the procedure may be invoked, or *called*
- When the procedure is executed, return to the point at which the call took place.
- Advantages:
  - -Economy:
    - +The same piece of Code can be used many timesefficient use of storage space in the system

-Modularity

 + Allow large programming tasks to be divided into smaller units which eases the programming task

#### **Procedure Calls Instructions**



### **Procedure Calls Instructions**

- Involves two basic instructions
  - -Call: branch to the procedure location
  - Return: from the procedure to the place from which it was called
- Stack can be used to store the return address.

#### **Use of Stack**



# **Types of Operand**

- Addresses
- Numbers

—Integer/floating point

- Characters
  - -ASCII (IRA) etc.
- Logical Data
  - -Bits or flags

### **Number of Addresses in Instruction**

- 3 addresses
  - -Operand 1, Operand 2, Result
  - -ADD a,b,c (a = b + c;)



- 2 addresses
  - One address doubles as operand and result
  - ADD a,c (a = a + b)
  - Reduces length of instruction
  - Requires some extra work
    - Temporary storage to hold some results



- 1 address
  - Implicit second address
  - -Usually a register (accumulator)
  - -ADDB (AC = AC + B)
  - Common on early machines

| Instruction | Comment                     |
|-------------|-----------------------------|
| LOAD D      | $AC \leftarrow D$           |
| MPY E       | $AC \leftarrow AC \times E$ |
| ADD C       | $AC \leftarrow AC + C$      |
| STOR Y      | $Y \leftarrow AC$           |
| LOAD A      | $AC \leftarrow A$           |
| SUB B       | $AC \leftarrow AC - B$      |
| DIV Y       | $AC \leftarrow AC \div Y$   |
| STOR Y      | $Y \leftarrow AC$           |

- 0 (zero) addresses
  - Applicable to a special memory organization called Stack
  - -Stack is known location
  - Often at least the top two stack elements are in processor registers
    - ADD
    - All addresses implicit

- 4 addresses
  - Operand 1, Operand 2, Result, and next instruction
  - -Not common
  - -Needs very long words to hold everything

| Number of Addresses | Symbolic Representation | Interpretation                 |
|---------------------|-------------------------|--------------------------------|
| 3                   | OP A, B, C              | $A \leftarrow B \text{ OP } C$ |
| 2                   | OP A, B                 | $A \leftarrow A \text{ OP } B$ |
| 1                   | OP A                    | $AC \leftarrow AC OP A$        |
| 0                   | OP                      | T ← (T − 1) OP T               |

## **How Many Addresses**

- More addresses
  - —More complex (powerful?) instructions
  - -More registers
    - Inter-register operations are quicker
  - -Fewer instructions per program
- Fewer addresses
  - —Less complex (powerful?) instructions
  - —More instructions per program
  - -Faster fetch/execution of instructions
- Most processor designs involve a variety of instruction formats.

#### **Fundamental Issues in Instruction Set Design**

- Operation repertoire
  - How many ops?
  - What can they do?
  - How complex are they?
- Data types
  - The data type that the processor can deal with
  - -E.g., Pentium can deal wit data types of:
    - Byte, 8 bits
    - Word, 16 bits
    - Doubleword, 32 bits
    - Quadword, 64 bits
    - Other data type...
- Instruction formats
  - Length of op code field
  - Number of addresses

#### **Fundamental Issues in Instruction Set Design**

- Registers
  - -Number of CPU registers available
  - —Which operations can be performed on which registers?
- Addressing modes (later...)
- RISC v CISC

# **Types of Operand**

- Addresses
- Numbers

—Integer/floating point

Characters

-ASCII etc.

- Logical Data
  - -Bits or flags

#### Where have all the Operands Gone? Where is the next instruction to be fetched?

- Main memory (or virtual memory or cache)
- CPU register
- I/O device

#### **Code Example**

 In a CPU with registers s0 – s4, interpret the following code:

```
mov s0, 5
mov s1, -3
mul s2, s1, s0
mul s0, s0
mul s1, s1
sub s1, s0
add s2, s1
```

## **Summary points**

- What is an instruction set architecture (ISA)?
- What are the instruction types?
- What are the basic components of an instruction?
- What is the stack?