**IOHNS HOPKINS** 

Exceptions affect the pipeline like a function call control is diverted to the exception handler interrupts are a particular type of exception

Exceptions are triggered by unexpected events detecting invalid instructions during decode arithmetic overflow memory errors syscall interrupts from external I/O controllers

**IOHNS HOPKINS** 

System Coprocessor (CPO) manages MIPS exceptions EPC is the exception program counter (CPO \$14) Holds address of offending (or interrupted) instruction

Cause register (CPO \$13) indicates problem

Control is transferred to handler at 0x80000018 handler takes the appropriate action resumes program using address in EPC terminates program if problem cannot be resolved

Transfer to exception handler causes a control hazard program instructions are flushed from pipeline this creates pipeline bubbles

The effect on pipeline is similar to a mispredicted branch

## Exception on add in

```
40
          $11, $2, $4
     sub
44
          $12, $2, $5
     and
          $13, $2, $6
48
     or
     add $1, $2, $1
4C
50
     slt $15, $6, $7
          $16, 50($7)
54
     ٦w
```

. . .

## Handler

```
80000180 sw $25, 1000($0)
80000184 sw $26, 1004($0)
```

...

JOHNS HOPKINS

UNIVERSITY

## **Exception Example**



Flush control signal inserts bubbles

JOHNS HOPKINS

UNIVERSITY



Flush control signal inserts bubbles

Some systems support precise exceptions no register writes after the offending instruction leaves the system in a consistent state

Imprecise exceptions instruction causing exception is identified but succeeding instructions may complete allows the system to be in an inconsistent state