Nesting of vectored interrupts, Polled interrupt processing – Zilog Z8F0130 User Manual
Page 46

eZ8
™
CPU Core
User Manual
UM012820-0810
Interrupts
42
Nesting of Vectored Interrupts
Vectored interrupt nesting allows higher priority requests to interrupt a
lower priority request. To initiate vectored interrupt nesting, follow the
steps below, during the interrupt service routine:
1. Push the old Interrupt Control and Interrupt Enable Register
information about the stack.
2. Load the Interrupt Enable Register information with new masks to
disable lower priority interrupts.
3. Execute an EI instruction to enable the interrupts.
4. Proceed with the interrupt service routine processing.
5. After processing is complete, execute a DI instruction to disable the
interrupts.
6. Restore the Interrupt Control and Interrupt Enable Register
information from the stack.
7. Execute an IRET instruction to return from the interrupt service
routine.
Polled Interrupt Processing
Polled interrupt processing is supported by individually disabling the
interrupts to be polled. To initiate polled processing, check the interrupt
bits of interest in the Interrupt Request Register(s) using the Test Under
Mask (TM) or similar bit test instruction. If the bit is 1, perform a
software call or branch to the interrupt service routine. Write the service
routine to service the request, reset the Interrupt Request bit in the
Interrupt Request Register, and return or branch back to the main
program. An example of a polling routine follows:
TM
IRQ1, #0010000b; Test for
interrupt request in bit 5 of IRQ1
- Z8F0131 Z8F0230 Z8F0231 Z8F0430 Z8F0431 Z8F043A Z8F0830 Z8F0831 Z8F083A Z8F1232 Z8F1233 Z8F0113 Z8F011A Z8F0123 Z8F012A Z8F0213 Z8F021A Z8F0223 Z8F022A Z8F0411 Z8F0412 Z8F0413 Z8F041A Z8F0421 Z8F0422 Z8F0423 Z8F042A Z8F0811 Z8F0812 Z8F0813 Z8F081A Z8F0821 Z8F0822 Z8F0823 Z8F082A Z8F0880 Z8F1621 Z8F1622 Z8F1680 Z8F1681 Z8F1682 Z8F2421 Z8F2422 Z8F2480 Z8F3221 Z8F3222 Z8F3281 Z8F3282 Z8F4821 Z8F4822 Z8F4823 Z8F6081 Z8F6082 Z8F6421 Z8F6422 Z8F6423 Z8F6481 Z8F6482 Z8FS021A ZMOT1AHH Z8FS040B ZMOT0BHH ZMOT0BSB Z8FMC04 Z8FMC08 Z8FMC16