

The interrupt and exception are implemented by states 43-62, which is shown at the bottom of the page. In these states, user stack pointer is saved. PC and PSR are pushed onto the supervisor stack and the supervisor mode is changed. Then the appropriate vector is loaded into MAR and PC is loaded with the starting address of the handler. States 36-52 on the top implement the RTI instruction. They pop PC and PSR from the supervisor stack and switch R6 back to the user stack pointer. States 18 and 19 now also store the old PC in a temp register and branch based on INT, which is set for an interrupt.

SSP is a register which is used to store the supervisor stack pointer while USP is for storing user stack pointer. SPMUX is used to take an input from SR1 of the register file and select between SR1+2 and SR1-2. It can also drive the bus. TEMP is a register which is used to store PC before it is pushed onto the stack when going to a handler. The PSR register is added to store the PSR. The PSR [15] bit can be loaded with 0 directly with LD.PRIV. PSR[2:0] store the condition codes by connecting to the input of the condition code register. The other added structure (on the right of the picture) is used to detect exceptions and load the correct vector for interrupts and exceptions. EX is a 2-bit register which is set by an exception. EXSMUX selects 0 or EX based on the control signal. The output of EXSMUX is connected to EXMUX, which is used to select the vector based on which exception is detected, and the result is stored in EXCV if LD.EXCV is set. I/EMUX selects between the interrupt and exception vector to be loaded.

## 10APPENDIX C. THE MICROARCHITECTURE OF THE LC-3B, BASIC MACHINE



Figure C.5: The microsequencer of the LC-3b base machine

unused opcodes, the microarchitecture would execute a sequence of microinstructions, starting at state 10 or state 11, depending on which illegal opcode was being decoded. In both cases, the sequence of microinstructions would respond to the fact that an interesting with an illegal opcode had been fetched.

In this design, we have more conditions than before. Only 2 condition bits are not enough so we have to add one more condition bit. The six conditions are shown in the picture.