beautypg.com

3 multiple interrupt servicing – NEC PD78F9488 User Manual

Page 304

background image

CHAPTER 16 INTERRUPT FUNCTIONS

304

User’s Manual U15331EJ4V1UD

Figure 16-14. Interrupt Request Acknowledgment Timing (Example: MOV A, r)

Clock

CPU

MOV A, r

Saving PSW and PC, and
jump to interrupt servicing

8 clocks

Interrupt servicing program

Interrupt

If the interrupt request has generated an interrupt request flag (xxIFx) by the time the instruction clocks under

execution, n clocks (n = 4 to 10), are n

− 1, interrupt request acknowledgment processing will start following the

completion of the instruction under execution. Figure 16-14 shows an example using the 8-bit data transfer instruction
MOV A, r. Because this instruction is executed in 4 clocks, if an interrupt request is generated between the start of
execution and the 3rd clock, interrupt request acknowledgment processing will take place following the completion of
MOV A, r.

Figure 16-15. Interrupt Request Acknowledgment Timing

(When Interrupt Request Flag Is Generated in Final Clock Under Execution)

Clock

CPU

NOP

MOV A, r

Saving PSW and PC, and
jump to interrupt servicing

Interrupt servicing
program

Interrupt

8 clocks

If the interrupt request flag (xxIFx) is generated in the final clock of the instruction, interrupt request

acknowledgment processing will begin after execution of the next instruction is complete.

Figure 16-15 shows an example whereby an interrupt request was generated in the 2nd clock of NOP (a 2-clock

instruction). In this case, the interrupt request will be processed after execution of MOV A, r, which follows NOP, is
complete.


Caution When interrupt request flag registers (IF0 to IF2), or interrupt mask flag registers (MK0 to MK2)

are being accessed, interrupt requests will be held pending.

16.4.3 Multiple interrupt servicing

Multiple interrupt servicing, in which an interrupt request is acknowledged while another interrupt request being

serviced, can be executed using the priority order. If multiple interrupts are generated at the same time, they are
serviced in the order according to the priority assigned to each interrupt request in advance (refer to Tables 16-1 and
16-2
).

This manual is related to the following products: