

Figure C.2 A state machine for the LC-3.



Figure C.3 The LC-3 data path.

| Table C.1 Data Path Control Signals                                                                                                                                                     |                                                                                                                                                          |                                                                                                                                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Signal Name                                                                                                                                                                             | Signal Values                                                                                                                                            |                                                                                                                                  |
| LD.MAR/1:<br>LD.MDR/1:<br>LD.IR/1:<br>LD.BEN/1:<br>LD.REG/1:<br>LD.PC/1:<br>LD.Priv/1:<br>LD.Priv/1:<br>LD.Priority/1:<br>LD.SavedSSP/1:<br>LD.SavedUSP/1:<br>LD.ACV/1:<br>LD.Vector/1: | NO, LOAD |                                                                                                                                  |
| GatePC/1:<br>GateMDR/1:<br>GateALU/1:<br>GateMARMUX/1:<br>GateVector/1:<br>GatePC-1/1:<br>GatePSR/1:<br>GateSP/1:                                                                       | NO, YES                                                                          |                                                                                                                                  |
| PCMUX/2:                                                                                                                                                                                | PC+1<br>BUS<br>ADDER                                                                                                                                     | ;select pc+1<br>;select value from bus<br>;select output of address adder                                                        |
| DRMUX/2:                                                                                                                                                                                | 11.9<br>R7<br>SP                                                                                                                                         | ;destination IR[11:9]<br>;destination R7<br>;destination R6                                                                      |
| SR1MUX/2:                                                                                                                                                                               | 11.9<br>8.6<br>SP                                                                                                                                        | ;source IR[11:9]<br>;source IR[8:6]<br>;source R6                                                                                |
| ADDR1MUX/1:                                                                                                                                                                             | PC, BaseR                                                                                                                                                |                                                                                                                                  |
| ADDR2MUX/2:                                                                                                                                                                             | ZERO<br>offset6<br>PCoffset9<br>PCoffset11                                                                                                               | ;select the value zero<br>;select SEXT[IR[5:0]]<br>;select SEXT[IR[8:0]]<br>;select SEXT[IR[10:0]]                               |
| SPMUX/2:                                                                                                                                                                                | SP+1<br>SP-1<br>Saved SSP<br>Saved USP                                                                                                                   | ;select stack pointer+1<br>;select stack pointer—1<br>;select saved Supervisor Stack Pointer<br>;select saved User Stack Pointer |
| MARMUX/1:                                                                                                                                                                               | 7.0<br>ADDER                                                                                                                                             | ;select ZEXT[IR[7:0]]<br>;select output of address adder                                                                         |
| TableMUX/1:                                                                                                                                                                             | ×00, ×01                                                                                                                                                 |                                                                                                                                  |
| VectorMUX/2:                                                                                                                                                                            | INTV<br>Priv.exception<br>Opc.exception<br>ACV.exception                                                                                                 |                                                                                                                                  |
| PSRMUX/1:                                                                                                                                                                               | individual settings, BUS                                                                                                                                 |                                                                                                                                  |
| ALUK/2:                                                                                                                                                                                 | ADD, AND, NOT, PASSA                                                                                                                                     |                                                                                                                                  |
| MIO.EN/1:<br>R.W/1:                                                                                                                                                                     | NO, YES<br>RD, WR                                                                                                                                        |                                                                                                                                  |
| Set.Priv/1:                                                                                                                                                                             | 0                                                                                                                                                        | ;Supervisor mode<br>;User mode                                                                                                   |

the event that causes the program that is executing to stop. Interrupts are events that usually have nothing to do with the program that is executing. Exceptions are events that are the direct result of something going awry in the program that is executing. The LC-3 specifies three exceptions: a privilege mode violation, an illegal opcode, and an ACV exception. Figure C.7 shows the state machine that carries these out. Figure C.8 shows the data path, after adding the additional structures to Figure C.3 that are needed to make interrupt and exception processing work.



Figure C.7 LC-3 state machine showing interrupt control.