#### EE460N Lab 5 Documentation

## Modifications from lab 4 are included for clarity. Updated sections implemented for lab 5 are bolded.

#### FSM Modifications

## **o** Virtual Memory Translation

• Any state requiring translation that asserts LD.MAR also asserts LD.VA. At this time, the default next state is saved to the JSave register, and the microsequencer then disregards the J bits to instead hard branch to state 44. States 44-50, described below, manually conduct the virtual to physical translation, then return back to the stock state machine destination state using the JSave register. From here, the machine continues per usual with the translated MAR.

# Exceptions

- Exceptions begin in state 10 or 11 (identical). An unknown opcode exception may be naturally initiated by the microsequencer setting next\_state to IR[15:12], since 1010 and 1011 are both unknown opcodes. Otherwise, the unaligned access and protection exceptions are generated by logic hardware which sets the EXCS high. This logic reads from the PSR, control store, IR, MAR and J bits, to see if either a.) a word sized load/store is about to occur and the MAR[0]==1 or b.) PSR[15]==0 and the instruction is not a trap, we are in the middle of translation, and a page is protected.
- This logic shown below generates the EXCS signal as well as the EXCV vector that is passed into the VEC register. Once the EXCS signal goes high, the microsequencer mux ignores the J bits and IR and instead sets next\_state to 11, where the exception begins. This state sets VEC as the relevant exception vector, prepares R6 and the MAR as the decremented Supervisor Stack Pointer, saves the User Stack Pointer, then branches to the interrupt states that service the pushing of VEC and PC-2 on the stack in addition to moving system & PC to the service routine.

## Interrupts

Interrupts are detected when the INTS signal goes high. Only state 18 is sensitive to the INTS signal. When the simulator detects the interrupt in state 18, it will branch to state 49 instead of 33 (per the microsequencer). State 49 saves the interrupt vector to the VEC register, saves the User Stack Pointer, and loads the destination address on the stack to R6 and the MAR. The next state copies the PSR to the MDR in preparation for pushing it on the stack, and clears bit 15 of the PSR to indicate Supervisor mode. After storing the PSR to the stack, R6 and the MAR are then decremented by 2, the MDR is loaded with PC-2 (the -2 ensures the current instruction will be executed post-interrupt), and the store on the stack occurs. Next, the hardware loads 0x0200+2\*VEC to calculate the pointer to the ISR, loads this value to the MAR, then performs a memory access to bring the ISR pointer into the PC. The machine is now in state 18 and pointing at the ISR, so the interrupt has now been successfully completed.

## o RTI

• When RTI is executed, the system moves to state 8 for the execution phase. The RTI states pop the PC and PSR off the stack, in that order, save R6 to the SSP register, and restores the USP into R6. While the PSR is being popped off the stack, it passes through the bus into the PSR register. While it is on the bus, the condition code mux (controlled by CCMUX) makes the NZP registers peek at the PSR while on the bus to restore the system state accordingly, using direct wire connections.

## Microsequencer

- Since there are 5 different potential sources for the next state calculation, a large mux could be impractical and inefficient. I modified the microsequencer to instead use tristate buffers, where different combinations of control signals, either dedicated to the microsequencer (IRD) or otherwise (LD.VA), and logic inputs (EXCS) are used to select which value is gated out.
- o The INTS signal may set up bit 4 of next\_state if COND2 (a new control signal) is high. This allows the FSM to begin servicing an interrupt once it is in state 18 and INTS is high.
- o I passed the EXCS signal from the datapath into the mux at the base of the microsequencer. This means that the next time next\_state is computed after EXCS goes high, next\_state is hardset at state 11, the first state for exceptions.

### Hardware Added

#### o Lab 5

- Per the lab document, I added registers for VA and the PTBR. PTBR has a constant value at initialization, but VA requires both the LD.VA and GateVA signals.
- I added a series of control signals to the MDR to set particular bits up/down for ease of PTE editing (reference/modified bits etc).
- TMPPSR register was added to protect the old PSR during interrupt translations.
- Added hardware for calculating PTE index from VA register and PTBR.

# Logic Blocks

• In the microsequencer, I used 2 logic blocks. Logic B determines whether the current state is one which requires translation, using comparators on the J bits. Logic A is an encoder that takes the IRD, COND3, and other signals to determine which mux output to pass.

### o Lab 4

- I added the SSP and USP registers to the datapath. These track the most recent value of the Supervisor Stack Pointer and User Stack Pointer, respectively, from the last time the system was in the according mode (Supervisor or User mode). This means that I needed to add signals to write to them and gate them onto the bus (LD.SSP/LD.USP, GateSSP/GateUSP). The only time we read from the SSP in the FSM is when we are reading the value SSP-2, so there is a block to decrement by 2 before being gated to the bus. The USP does not connect to the bus, since it only ever reads and writes to R6. I connected the USP load directly to the SR1 output, which may point directly at R6 based on the SR1MUX1 signal. Similarly, I added a mux at the load at the register to determine whether the register file reads a value in from the bus or the USP. This mux admittedly increases the propogation delay in register writes from the bus.
- I also added a path that bypasses the ALU to dump R6 directly on the bus. This is useful since it doesn't dump the original value of R6; rather, it dumps R6+2 or R6-2, depending on the value of SPMUX. It only gets dumped if the GateSPS signal is high. This path is useful so we can increment/decrement the current SP with dedicated hardware in the datapath in a single cycle. Similarly, it would make it easier to create future functionality for PUSH/POP instructions in LC3.
- I added a similar path from the current PC through a block that decrements by 2, and dumps PC-2 to the bus based on the GateDPC signal. This allows the interrupt/exception states to reset the PC to the problematic instruction with ease, since the PC doesn't have any elegant connection through arithmetic components in the original datapath.
- I added a PSR register to the datapath to track the value of the register as the system undergoes context switches. This required a LD.PSR signal to write a value to the PSR from the bus. Since we often need to set the most significant bit of the PSR to 0 without changing the bits, I used the LD.PSRM bit to clear bit 15 of the PSR without using the bus. The PSR may also be gated onto the bus using the GatePSR signal
- I added a VEC register that stores the most recent vector that would be necessary for servicing an Interrupt or Exception. This required a LD.VEC signal to write to this register and a mux that writes the value from either INTV or EXCV depending on the VECMUX

- signal. The value of this vector is leftshifted by 1 and added to 0x0200 to find the address of the necessary service routine, and is only gated onto the bus if GateVEC is 1. This would occur if we wanted to write that address to the MAR.
- I also added combinational logic hardware that reads from the current control signals, MAR value, and PSR value, to generate the EXCS signal that is passed into the FSM/Control box and the EXCV vector. This is used to generate exceptions.
- I added a mux before the condition codes, which changes whether the condition codes are set by logic reading from the bus, or the 3 least significant bits passed directly into the register.

# • All Control Signals Added

#### Lab 5

- LD.VA- Writes a value to VA register.
- GateVA- gates VA register onto bus.
- GatePTBR- gates the PTBR and page offset onto the bus
- JGate- gates the JSave register onto the microsequencer output for dynamic return to stock state machine.
- LD.MDRR- sets reference bit, bit 1, to 1 in the MDR
- LD.MDRM- sets modified bit to 1 in the MDR according to whether JSave is in a store instruction.

#### o Lab 4

- COND2- Required for microsequencer integration of INTS signal.
- LD.SSP- Indicates a write to SSP register.
- LD.USP- Indicates a write to USP register.
- LD.PSR- Indicates a write to PSR register.
- LD.PSRM- Clears PSR[15].
- LD.VEC- Indicates a write to VEC register.
- GateSSP- Indicates whether SSP-2 is dumped to bus.
- GateSPS- Indicates whether current stack pointer, either incremented or decremented by 2, is dumped to bus.
- GateDPC- Indicates whether decremented PC (PC-2) is dumped to bus.
- GatePSR- Indicates whether PSR register is dumped to bus.
- GateVEC- Indicates whether VEC register is dumped to bus.
- DRMUX1- If it is high, then DR must be 6.
- SR1MUX1- If high, then SR must be 6.
- RMUX- If high, then register file loads from USP. Otherwise, register file loads from bus.
- USPMUX- Determines whether current SP is incremented or decremented before being dumped to the bus.
- VECMUX- Determines whether EXCV or INTV is written to VEC register.
- CCMUX- Determines whether logic sets the condition codes, or wires to BUS[2:0].

## FSM Shorthand

- o setcc2()- denotes that the condition codes are set based on the PSR value being passed through the bus.
- o States for servicing normal instructions are not shown for simplicity.
- o [INT] indicates the next state is dependent on the INTS signal.









