
295
CHAPTER 16 INTERRUPT FUNCTION
User
’
s Manual U15017EJ2V0UD
16.13 Cautions
(1) The in-service priority register (ISPR) is read-only. Writing to this register may result in malfunction.
(2) The watchdog timer mode register (WDM) can only be written to with a dedicated instruction (MOV WDM, #byte).
(3) The RETI instruction must not be used to return from a software interrupt caused by a BRK instruction.
Use the RETB instruction.
(4) The RETCS instruction must not be used to return from a software interrupt caused by a BRKCS instruction.
Use the RETCSB instruction.
(5) When a maskable interrupt is acknowledged by vectored interrupt, the RETI instruction must be used to return
from the interrupt. Subsequent interrupt related operations will not be performed normally if a different instruction
is used.
(6) The RETCS instruction must be used to return from a context switching interrupt. Subsequent interrupt related
operations will not be performed normally if a different instruction is used.
(7) Macro service requests are acknowledged and serviced even during execution of a non-maskable interrupt
service program. If you do not want macro service processing to be performed during a non-maskable interrupt
service program, you should manipulate the interrupt mask register in the non-maskable interrupt service program
to prevent macro service generation.
(8) The RETI instruction must be used to return from a non-maskable interrupt. Subsequent interrupt acknowledgment
will not be performed normally if a different instruction is used. If you restart a program from the initial state after
a no-maskable interrupt acknowledgement, refer to
16.12 Restoring Interrupt Function to Initial State
.
(9) Non-maskable interrupts are always acknowledged, except during non-maskable interrupt service program
execution (except when a high priority non-maskable interrupt request is generated during execution of a low-
priority non-maskable interrupt service program) and for a certain period after execution of the special instructions
shown in
16.9
. Therefore, a non-maskable interrupt will be acknowledged even when the stack pointer (SP) value
is undefined, in particular after reset release, etc. In this case, depending on the value of the SP, it may happen
that the program counter (PC) and program status word (PSW) are written to the address of a write-inhibited
special function register (SFR) (refer to
Table 3-6
in
3.8 Special Function Registers (SFRs)
, and the CPU
becomes deadlocked, or an unexpected signal output from a pin, or PC and PSW are written to an address is
which RAM is not mounted, with the result that the return from the non-maskable interrupt service program is
not performed normally and a software inadvertently loops.
Therefore, the program following RESET release must be as follows.
CSEG
AT 0
DW
STRT
CSEG
BASE
STRT:
LOCATION 0FH; or LOCATION 0H
MOVG
SP, #imm24