# **A Simplified Machine Model**



Autumn 2002

## **MIPS is a RISC Architecture**

**RISC** = Reduced Instruction Set Computer

- simple instructions
- arithmetic instructions do some operation on 2 source registers & put the results in a destination register
  - $reg_c = reg_b op reg_a$
- separate data transfer instructions
  - load from memory into  $\mathtt{reg}_a$  &  $\mathtt{reg}_b$
  - **store** from **reg**<sub>c</sub> to memory
- called a load/store architecture

### Instructions

An instruction tells the CPU

- the operation to be performed: opcode
- the operands (0 or more) on which to perform the operation

#### The instruction set architecture (ISA) specifies:

- · what the opcode means
- · how many operands it requires
- what is the type of the operands
  - an operand can be a:
    - · integer or floating point register
    - memory address
    - constant

CSE378

Autumn 2002

## **Registers**

High-speed storage for instruction operands

One set for integer values; one set for floating point values

Naming convention:

 named by their location in the register file & use for example, \$s7, \$f14

#### General purpose registers (GPRs)

- all registers are alike: any value can be in any register
- not quite true
  - \$0 is hardwired to 0
  - some have a special use by software convention (MIPS details later; see p. A-22)

Usually 32 registers in the ISA (of each type: integer, FP)

- seems a good trade-off between having enough high-speed storage for "live" values and a short register file access time
- only takes 5 bits to represent a register in an instruction
- there are other registers, but they are hidden from the programmer

3

## **Information Units**

Basic unit is a bit (stores a 0 or 1)

Bits are grouped to form other information units

- byte = 8 bits
- **word** = 32 bits
- double word = 64 bits
- Word size is "the size of the machine", e.g., a 32-bit processor has a 32-bit word size
  - determines several characteristics of the architecture or implementation
    - size of the registers = "word size" bits
      - number of integer values that can be represented is 2<sup>word size</sup>
    - number of integer values that can be stored is 2<sup>word size</sup>
    - size of addressable memory (memory locations from 0 to 2<sup>word size</sup>-1)

CSE378

Autumn 2002

5

6

#### Memory

Memory is an array of information units (the logical organization)

- each unit is the same size
- each unit has a unique address
- address & contents are different

#### address content



#### Memory

Most computers have byte addressable memory

- each address is a byte location
- on a 32-bit processor can address 2<sup>32</sup> different values
  → 4GB address space
- when address words, they must be on 4-byte boundaries
- today 64-bit architectures are being built (e.g., Alpha, UltraSPARC, R12000, Pentium Pro)

CSE378

Autumn 2002

## **Memory Hierarchy**

The memory system is a hierarchy of "memories"

the closer they are to the CPU, the smaller, faster, more expensive (per memory cell) they are

#### The hierarchy:

- registers
- · caches (one or more levels)
- main memory (primary memory)
- disks (secondary memory)

| Memory Level   | Capacity<br>(bytes)  | Speed                           |
|----------------|----------------------|---------------------------------|
| Registers      | 10's - low<br>100's  | < nanosecond                    |
| Cache: level 1 | 8 - 128KB<br>on-chip | ~1-3<br>nanoseconds             |
| Cache: level 2 | 1 - 16MB<br>off-chip | 10's of<br>nanoseconds          |
| Memory         | 10MB - 4GB           | 10's to 100's of<br>nanoseconds |
| Disk           | 1GB - 10GB           | 10's of<br>milliseconds         |

7

# **Execution Cycle**

The CPU executes a program by repeating this cycle:

- 1. fetch an instruction
- 2. execute the instruction
- 3. compute the address of the next instruction
- 4. go back to 1. until you run out of instructions

Now we're ready to dive in!

CSE378

Autumn 2002

9