

#### 4.9.1 The Fetch-Decode-Execute Cycle



Figure 4.11 The Fetch-Decode-Execute Cycle

**Load X**

| Step        | RTN                                          | Explanation                                                                                               |
|-------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| Fetch       | $\text{MAR} \leftarrow \text{PC}$            | Store the address of the next instruction in memory address register                                      |
|             | $\text{IR} \leftarrow \text{M}[\text{MAR}]$  | Read the next instruction from memory and store it in the instruction register.                           |
|             | $\text{PC} \leftarrow \text{PC}+1$           | Increment the program counter to the address of the next instruction.                                     |
| Decode      | $\text{MAR} \leftarrow \text{IR}[11-0]$      | Place the value of the address field in the instruction in the memory address register.                   |
|             | (Decode $\text{IR}[15-12]$ )                 | At the same time decode                                                                                   |
| Get operand | $\text{MBR} \leftarrow \text{M}[\text{MAR}]$ | Store the contents of memory at the address in the memory address register to the memory buffer register. |
| Execute     | $\text{AC} \leftarrow \text{MBR}$            | Store the value in the memory buffer register to the accumulator.                                         |

#### 4.9.2 Interrupts and the Instruction Cycle



Figure 4.12 Fetch-Decode-Execute Cycle with Interrupt Checking



Figure 4.13 Processing and Interrupt

| Term             | Explanation                                                                                      |
|------------------|--------------------------------------------------------------------------------------------------|
| <b>Interrupt</b> | A signal or mechanism that momentarily disrupts or alters the normal fetch-decode-execute cycle. |

|                                   |                                                                                                                                                            |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                   | Examples include division by zero, stack overflow, or memory access violation.                                                                             |
| <b>Hardware interrupt</b>         | Hardware interrupts are efficiently used to notify the CPU that a peripheral device requires service.                                                      |
| <b>Software interrupt</b>         | Called <b>traps</b> or <b>exceptions</b> . Used by various software applications. An example is a debugger.                                                |
| <b>Interrupt handler</b>          | An interrupt handler is a function that services either a software or a hardware interrupt.                                                                |
| <b>Interrupt service routines</b> | An interrupt service routine ( <b>ISR</b> ) is equivalent to an interrupt handler.                                                                         |
| <b>Interrupt vector table</b>     | An interrupt vector table contains an indexed list of addresses of interrupt handlers.                                                                     |
| <b>Address vector</b>             | An address vector is the starting address of an interrupt handler.                                                                                         |
| <b>Interrupt masking</b>          | Interrupt masking is the process of suspending lower priority interrupts. For example, most systems mask keyboard interrupts when processing a page fault. |
| <b>Maskable interrupt</b>         | Interrupts that can be suspended via masking are called "maskable."                                                                                        |
| <b>Nonmaskable interrupt</b>      | A nonmaskable interrupt is one where the system would enter an unstable or unpredictable state if the interrupt were serviced.                             |

#### 4.9.3 MARIE's I/O

| Instruction   | Action                                                   |
|---------------|----------------------------------------------------------|
| <b>Input</b>  | The CPU waits for a character to be placed in the InREG. |
| <b>Output</b> | The CPU places a character in the OutREG.                |