
Instruction Cycle Operations
ARM7TDMI Data Sheet
ARM DDI 0029E
10-12
O
b and w are byte and word as defined in
·
Table 9-2: MAS[1:0] signal encoding
on
page 9-5.
Note
Data swap cannot be executed in THUMB state.
10.12Software Interrupt and Exception Entry
Exceptions (and software interrupts) force the PC to a particular value and refill the
instruction pipeline from there. During the first cycle the forced address is constructed,
and a mode change may take place. The return address is moved to R14 and the
CPSR to SPSR_svc.
During the second cycle the return address is modified to facilitate return, though this
modification is less useful than in the case of branch with link.
The third cycle is required only to complete the refilling of the instruction pipeline. The
cycle timings are shown below in
·
Table 10-14: Software Interrupt instruction cycle
operations
.
C
represents the current mode-dependent value.
T
represents the current state-dependent value
pc
for software interrupts is the address of the SWI instruction.
for exceptions is the address of the instruction following the last one
to be executed before entering the exception.
for prefetch aborts is the address of the aborting instruction.
for data aborts is the address of the instruction following the one
which attempted the aborted data transfer.
Xn
is the appropriate trap address.
3
Rn
b/w
1
Rm
1
0
1
1
4
pc+12
2
0
-
0
1
1
0
pc+12
Cycle Address
MAS[1:0]
nRW
Data
nMREQ SEQ
nOPC
nTRANS
Mode
TBIT
1
pc+2L
i
0
(pc+2L)
0
0
0
C
old mode
T
2
Xn
2
0
(Xn)
0
1
0
1
exception mode
0
3
Xn+4
2
0
(Xn+4)
0
1
0
1
exception mode
0
Xn+8
Table 10-14: Software Interrupt instruction cycle operations
Cycle
Address
MAS[1:0]
nRW
Data
nMREQ
SEQ
nOPC
LOCK
Table 10-13: Data Swap instruction cycle operations