## Spring 2002 Midterm Exam Review

mr-1

When / Where

Friday, 22 March 2002, 13:40-14:30 CST

CEBA 1110 (Here)

### Conditions

Closed Book, Closed Notes

Bring one sheet of notes (both sides),  $216 \text{ mm} \times 280 \text{ mm}$ .

No communication devices.

#### Format

One or two medium-sized problems, short answers.

### Resources

Solved tests and homework: http://www.ece.lsu.edu/ee4720/prev.html

### Study Recommendations

 $\underline{Solve}$  Old Problems

Memorizing solutions is not the same as solving.

Following and understanding solutions is not the same as solving.

Use the solutions for brief hints and to check your own solutions.

#### mr-3

## Emphasis

They are a *team*, so study them together.

### Instruction Use

Should be able to easily write MIPS programs.

Should be able to use other instructions in examples.

For example, SPARC, DLX, etc.

Not required to memorize instruction names, except for common MIPS instructions.

# Topics

ISA v. Implementation.

Technological Factors: Transistor speed and quantity, memory speed and size.

Different factors influencing ISA and implementation.

Design principles: Amdahl's law, locality.

CPU Performance Equation

Benchmark types.

Instruction Set Design

Data Types: What to include, what to leave out.

Basic integer and floating point

Packed types: BCD, integer, saturating integer.

Size choices.

mr-4

Memory and Register Organization: Why  $\approx 32$  registers?

Stack and accumulator architectures.

Memory/Memory, Register/Memory.

Addressing Modes: What they do, which ones to include.

Register, Immediate, Direct, Register Deferred (Register Indirect), Displacement, Indexed, Memory Indirect, Autoincrement, Autodecrement, Scaled.

Control Transfer Instructions: Types, when to use.

Branch, Jump, Jump & Link, Call, Return

Format of displacements in instruction.

Specification of condition: condition code registers, integer registers, loop counter.

Delayed and predicated instructions; prediction hints.

Instruction Coding.

Fixed-length, variable-length, and bundled instructions.

Splitting of opcode field (as in MIPS type-R instructions).

ISA Classifications: RISC, CISC, VLIW, Stack, Accumulator

Synthetic Instructions

### MIPS and DLX

Classification: RISC

Goals: ISA should allow simple, high-speed implementation.

Instruction types.

Know how to read and write MIPS and DLX programs.

HP Chapter-3 (Statically Scheduled) MIPS Implementations

Unpipelined Implementation

Pipelined Implementations

Basic (3-cycle branch penalty).

Zero-cycle branch penalty.

Bypassed.

mr-7

#### Hazard Definitions

For a Given Pipelined ImplementationShow pipeline execution diagrams.Show register contents at any cycle.Determine control hardware.Determine CPI.

Interrupts and Exceptions and Traps, Oh my!

Difference between interrupt, exception, trap.

Causes of exceptions, role of handler.

Privileged Mode.

Pipeline activity leading to execution of handler.

SPARC trap mechanism. (Trap base register, etc.).

Precise exceptions, achieving with floating-point operations.

## Long Latency Operations

Types of operations. (Floating point and maybe load.)

Degree of pipelining: Initiation interval, latency.

Detecting functional unit structural hazards.

Detecting WB structural hazards: reservation register.

Detecting and handling RAW hazards: ID-stage v. pre-WB stall.

Handling WAW hazards.

Loop Unrolling