Interrupt priority, Vectored interrupt processing, Interrupt priority vectored interrupt processing – Zilog Z8F0130 User Manual
Page 43

eZ8
™
CPU Core
User Manual
UM012820-0810
Interrupts
39
Interrupt Priority
The Interrupt Controller prioritizes all interrupts. Refer to the Zilog Prod-
uct Specification specific to your Z8 Encore! device for information about
the Interrupt Controller.
Vectored Interrupt Processing
Each eZ8 CPU interrupt is assigned its own vector. When an interrupt
occurs, control passes to the interrupt service routine pointed to by the
interrupt’s vector location in Program Memory. The sequence of events
for a vectored interrupt is as follows:
1. Push the low byte of the Program Counter, PC[7:0], on the stack.
2. Push the high byte of the Program Counter, PC[15:8], on the stack.
3. Push the Flags Register on the stack.
4. Fetch the High Byte of the Interrupt Vector.
5. Fetch the Low Byte of the Interrupt Vector.
6. Branch to the Interrupt Service Routine specified by the Interrupt
Vector.
displays the effect of vectored interrupts on the Stack Pointer
and the contents of the stack.
provides an example of the
Program Memory during interrupt operation. In
, the Interrupt
Vector is located at address
0014h
in Program Memory. The 2-byte
Interrupt Vector, stored at Program Memory addresses
0014h
and
0015h
,
is loaded into the Program Counter. Execution of the Interrupt Service
Routine begins at Program Memory address
4567h
, as is stored in the
Interrupt Vector.
- 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