aboutsummaryrefslogtreecommitdiff
path: root/sim/testsuite/sim/frv/interrupts/illinsn.cgs
blob: 175709e5b00c0e6f4cf427820ce10fa8e1f36b08 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# FRV testcase
# mach: fr500 fr400

	.include "testutils.inc"

	start

	.global tra
tra:
	and_spr_immed	0x3fffffff,hsr0		; no caches enabled

	and_spr_immed	-4081,tbr		; clear tbr.tt
	set_gr_spr	tbr,gr7
	inc_gr_immed	0x070,gr7		; address of exception handler
	set_bctrlr_0_0  gr7
	inc_gr_immed	0x790,gr7		; address of exception handler
	set_bctrlr_0_0  gr7
	set_spr_immed	128,lcr
	set_psr_et	1
	set_spr_addr	ok0,lr

	set_gr_addr	ill1,gr7
	set_mem_immed	0x81f80000,gr7	; unknown opcode: 7E
ill1:	tira		gr0,0		; should be overridden
ill2:	nop				; also illegal, but prev has priority
bad0:	fail

	; check interrupt
ok0:	test_spr_addr	ill1,pcsr
	test_spr_immed	1,esfr1		; esr0 active
	test_spr_bits	0x3f,0,0xb,esr0
	test_spr_addr	ill1,epcr0

	pass