2 exception mode execution, 7 exception timing, Exception mode execution -53 – Freescale Semiconductor StarCore SC140 User Manual
Page 233: Exception timing -53, Exception pipeline -53, Basic exception timing -53

Exception Processing
SC140 DSP Core Reference Manual
5-53
5.8.6.2 Exception Mode Execution
An exception mode execution is performed in exactly the same way as a normal program flow. There is no
constraint on the length of an exception routine. Table 5-20 shows the flow for the pipeline changing from
normal execution to exception execution.
5.8.7 Exception Timing
When an unmasked exception is taken, the core breaks the normal execution flow and adds a cycle. The
return PC and SR are pushed onto the stack, and the core then resumes execution at the exception vector
address. After the exception request is asserted, the exact point at which the normal execution flow is
interrupted is not fixed. It is dependent on the properties of the instructions being executed in the vicinity
of the exception request as well as any core stalls that may occur in parallel. For example, a delayed
instruction and its delay slot constitute an uninterruptable sequence.
Example 5-17 describes the exception servicing for a simple case that does not include delayed
instructions or core stalls, but does include exceptions occurring near change-of-flow instructions. In this
example, the JUMP instruction represents all change-of-flow instructions in Table 5-8, excluding delayed
instructions and TRAP. It also represents the DI (disable interrupt) instruction.
Example 5-17. Basic Exception Timing
Let ES0 -> ... -> ES4 ... be a sequence of execution sets such that if ES0 is a JUMP instruction, then ES1 is
an instruction from the target address (ES0 -> ES1 -> ES2 -> ES3 -> ES4). In addition, assume that an
exception request arises on the same cycle that ES0 starts its AGU execution stage.
If (ES1 is not JUMP) and (ES2 is not JUMP):
Then
•
The execution set from the target of the exception vector is executed after ES2, and the address of
ES3 is pushed as a return address to the stack.
•
1 cycle is added, which is needed to push the return address to the stack.
Else, if (ES1 is not JUMP) and (ES2 is JUMP):
Table 5-20. Exception Pipeline
Operation
Instruction Cycle
1
2
3
4
5
6
7
8
9
10
11
12
Pre-fetch n1
n2
n3
i1
i2
Fetch n1
n2
n3
i1
i2
Decode n1
n2
push
i1
i2
Address
Generation
n1
n2
push
i1
i2
Execute n1
n2
push
i1
i2
n = normal or user execution set
i1, i2 = exception execution sets 1 and 2