summaryrefslogtreecommitdiff
path: root/tb/sim/modeswitch.S
blob: c04f8a3ef35afba158f532e2113cee599f2c8d79 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
.global reset
reset:
	mrs  r0, cpsr
	udf
	mrs  r2, cpsr
	ldr  r3, =#0x16f
	bic  r3, r2, r3
	msr  cpsr_fxc, r3
	mrs  r4, cpsr
	cmp  r0, r0
	mrs  r5, spsr
	nop
	msr  cpsr_fxc, r0 
	msr  spsr_fxc, r0
	mov  pc, lr

.global undefined
undefined:
	mrs  r1, spsr
	mrs  r13, cpsr
	movs pc, lr