

regardless of where the program might be located in memory. Assume PC initially contains address of memory word containing instr\_0. Data A and B are in consecutive memory words as part of program. Don't worry about what happens after the end of the program is reached.

Below we explore LC3 instructions and their execution. Register Transfer Language (RTL) indicates the operation and the required control signals are listed. For example,

MAR <== PC LD\_MAR

indicates that the content of PC transfers into MAR, and LD\_MAR control signal must be 1 (all other control signals are assumed to be 0.) Necessary signal paths are shown like this, for example,

IR[15:12]->FSM.in

which indicates that the 4 high-order bits of the IR need to be routed to the control FSM's input.

NB--Control state numbers look strange: F1 is state-18, F2 is state-33, F3 is state-35, etc.

The test bench, "top\_rtl\_testInstr", in the test.jelib Electric library displays the current simulation tick, the FSM's state, non-zero control signals, and non-zero MUX controls, eg.,

------((( 18 )))------[ LD\_MAR ]------[ ]------[

indicates the current tick is 3, the current state is 18, the LD\_MAR is 1, and all MUX select signals are zeroes. Following the above is a listing of the content of all CPU registers (PC, MAR, MDR, IR, PSR, and all eight registers in RegFile).



2. See test.testInstr (initializing memory).





A - B? How about A + (-B) using 2s-complement?

 $R1 \leftarrow NOT(R1)$ ,  $B \stackrel{.}{\longrightarrow} R1 \rightarrow \overline{B}$ 1001 001 001 111111 1gnore? TON RI RI (DR) (SRI)  $R2 \leftarrow R1 + R3$ , 1 = R3 (how?) -B = R2 0001010001000011 R3 RI ADD R2  $R^2 \leftarrow R\phi + R^2$ ,  $A \stackrel{.}{in} R\phi$ (A-B)  $\stackrel{.}{in} R^2$ (DR) (SRI) (SR2AVX) (SB2) 000101000000010



A - B? How about A + (-B) using 2s-complement with immediate constants?

| 1001 001 001 111111<br>ADD DR SRI                                  | $RI \leftarrow NoT(RI),  RI \leftarrow B$                                |
|--------------------------------------------------------------------|--------------------------------------------------------------------------|
| 0001 010 001 1 00001<br>ADD DR SR1 ( IMM5<br>SR2MVX                | $R_2 \leftarrow R_1 + SEXT(0000), R_2 \leftarrow (B+1)$                  |
| $\begin{array}{c} 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 $ | $RI \leftarrow R\phi + R2$ , $RI \leftarrow (A-B)$<br>(See Appendix A.3) |

Load/Store (load a register from memory, store register contents in memory)







