2 return from exception instructions, Return from exception instructions -49, Exception vector address table -49 – Freescale Semiconductor StarCore SC140 User Manual
Page 229: Table (table 5-19) or the exte, O-ir vectors in table 5-19, Table 5-19) or, Table 5-19. bits, Table 5-19 shows the

Exception Processing
SC140 DSP Core Reference Manual
5-49
5.8.2 Return From Exception Instructions
Return from exception should be done with dedicated Return from Exception instructions (RTE, RTED, -
termed collectively “RTE-like” instructions). These instructions pop from the active stack two values: The
return PC, form which execution resumes, and SR value. The SR value sets (among other things) the
working mode of the core. The RTE-like instructions are used to automatically enable resuming the task
that was interrupted (by restoring the next PC to be executed and the SR, including the working mode). It
could also be manipulated by the RTOS to change the task that is restored.
For maximum efficiency on return from an exception, the SC140 instruction set provides a delayed return
from the exception instruction. This takes five or six cycles to execute, but allows the usage of some of
these cycles to execute instructions. Refer to
Appendix A, “SC140 DSP Core Instruction Set,”
for details
on return-from-exception usage in the RTE and RTED instructions.
The RTE/D instructions do not affect the shadow return address of subroutines, see
In this way, the interrupts interfere less with the interrupted task, allowing it to
continue and enjoy the reduced cycle count when performing an RTS, if applicable. However, if during the
ISR, the task was switched, the RAS may hold content from the previous task that may corrupt the
execution of the restored task. In such a case, the user should clear the RAS by performing, in the ISR that
switches the tasks, a dummy jump to subroutine (JSR) and return (RTS). .
Table 5-19. Exception Vector Address Table
Exception Address
Offset
Priority
(0 - highest)
Type
Description
0x00
0
TRAP
TRAP instruction
0x40
-
Reserved
0x80
1
ILLEGAL ILLEGAL
instruction,
and
illegal
instruction set
0xC0
2
DEBUG
DEBUG exception from EOnCE
0x100
3
Overflow
DALU overflow
0x140
-
Reserved
0x180
5
Auto-NMI
NMI default vector
0x1C0
6
Auto-IR
Interrupt default vector
0x200-0xFC0
5
NMI
NMI
External interrupts
External interrupts