



# Fig. 3.8 ISR (Solution)



| Interrupt-service routine                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ILOC:                                                                                                                                                                                                                                                                                                                                                                                                                                      | Subtract<br>Store<br>Store<br>Load<br>LoadByte<br>StoreByte<br>Add<br>Store<br>LoadByte<br>And<br>Branch_if [R2]=0<br>StoreByte<br>Move<br>Branch_if [R3]≠[R2]<br>Move<br>Store<br>Clear<br>StoreByte<br>Load<br>Load<br>Add<br>Return-from-interrupt  |
| ECHO:                                                                                                                                                                                                                                                                                                                                                                                                                                      | R2, 4(SP)<br>R3, (SP)<br>R2, PNTR<br>R3, KBD_DATA<br>R3, (R2)<br>R2, R2, #1<br>R2, PNTR<br>R2, DISP_STATUS<br>R2, R2, #4<br>ECHO<br>R3, DISP_DATA<br>R2, #CR<br>RTRN<br>R2, #1<br>R2, EOL<br>R2<br>R2, KBD_CONT<br>R3, (SP)<br>R2, 4(SP)<br>SP, SP, #8 |
| RTRN:                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                        |
| <p>6. From specification, KBD read is done by interrupts while DISP is done by polling within KBD ISR</p> <p>6. Why do we wait-loop to echo, while there is no wait in getting the Keyboard input?</p> <p>8. Comment on the difference in saving/restoring registers in ISR vs Call Subroutine?</p> <p>8. In subroutine, registers are saved using PUSH, while in interrupt, registers are saved using SP+offset, after SP is adjusted</p> |                                                                                                                                                                                                                                                        |
| <p>4. Where is the Frame Pointer?</p> <p>4. No FP used in interrupts</p> <p>5. Why the PTR is incremented by only one address location?</p> <p>5. Each keystroke is an ASCII so only need 1 byte</p> <p>7. Why DI at keyboard interface, and not in PS or IENABLE registers?</p> <p>7. If DI in PS or IENABLE or both, then an interrupt may still be generated from KBD; DI at the KBD local level prevents all 3 interrupt signals</p>   |                                                                                                                                                                                                                                                        |