## **UT69R000 Interrupt Architecture**

The following outlines an instruction sequence that protects un-interruptible code segments from external interrupts. Figure 1 depicts a main program that accesses two service routines and numerous interrupt service routines. During execution of the main program and service routine # 2 all interrupts are un-masked and enabled. Execution of service routine #1 requires masking and disabling of external interrupts to prevent interruption.

Service
Routine #2

Main
Body of
Program

Interrupt
Service
Routine(s)

Figure 1. Program Code Block Diagram

The UT69R000 requires execution of following sequences of instructions prior to calling a routine that requires protection from interrupts.

 $\begin{array}{ll} \text{MOV R}_D,0000 \\ \text{OTR R}_D,\text{MK} & ; \text{clear mask register} \\ \text{NOP} \\ \text{NOP} \\ \text{CALL R}_D,\text{SRV\_RTNE2}; \text{ branch to protected service routine} \end{array}$ 

Immediately following the call instruction (i.e., branch to protected service routine), execute OTR R0, DSBL instruction to disable interrupts. The combination of masking and disabling prevents any latent interrupt vectors from within the protected service routine. After execution of the protected service routine, restore the mask register (OTR R<sub>D</sub>,MK), pop return value in R<sub>D</sub> (POP

1/96 Page 1 of 2

 $R_D$ ,  $R_S$ ), enable interrupts (OTR  $R_D$ , ENBL), and execute a branch back to main program (CALL  $R_D$ ,  $R_S$ ).

 $MOV R_D, XXXX_{16}$ 

 $\begin{array}{ll} \text{OTR } R_D, \text{MK} & ; \text{ re-store mask register} \\ \text{POP } R_D, R_S & ; \text{ establish return value} \\ \text{OTR } R_D, \text{ENBL} & ; \text{ enable interrupts} \end{array}$ 

CALL R<sub>D</sub>, MAIN; branch to protected service routine

1/96 Page 2 of 2