## **EXAMPLE**

## **Exception in a Pipelined Computer**

Given this instruction sequence,

assume the instructions to be invoked on an exception begin like this:

```
80000180_{\text{hex}} sw $25, 1000($0)
80000184_{\text{hex}} sw $26, 1004($0)
```

Show what happens in the pipeline if an overflow exception occurs in the add instruction.

## **ANSWER**

Figure 4.67 shows the events, starting with the add instruction in the EX stage. The overflow is detected during that phase, and  $8000\ 0180_{\rm hex}$  is forced into the PC. Clock cycle 7 shows that the add and following instructions are flushed, and the first instruction of the exception code is fetched. Note that the address of the instruction *following* the add is saved:  $4C_{\rm hex} + 4 = 50_{\rm hex}$ .