Add fr450 support.
[deliverable/binutils-gdb.git] / sim / testsuite / sim / frv / interrupts / regalign.cgs
CommitLineData
4a306116
DB
1# frv testcase to generate interrupts for bad register alignment
2# mach: frv
3 .include "testutils.inc"
4
5 start
6
7 .global align
8align:
9 and_spr_immed -4081,tbr ; clear tbr.tt
10 set_gr_spr tbr,gr17
11 inc_gr_immed 0x080,gr17 ; address of exception handler
12 set_bctrlr_0_0 gr17
13 inc_gr_immed 0x050,gr17 ; address of exception handler
14 set_bctrlr_0_0 gr17
15 set_spr_immed 128,lcr
16 set_spr_addr ok1,lr
17 set_psr_et 1
18
5ca353c3
DB
19 ; Make the the register number odd at bad[1-4], bad9 and bada.
20 ; We can't simply code an odd register number because the assembler
21 ; will catch the error.
22 set_gr_mem bad1,gr10
23 or_gr_immed 0x02000000,gr10
24 set_mem_gr gr10,bad1
25 set_gr_addr bad1,gr10
26 flush_data_cache gr10
27 set_gr_mem bad2,gr10
28 or_gr_immed 0x02000000,gr10
29 set_mem_gr gr10,bad2
30 set_gr_addr bad2,gr10
31 flush_data_cache gr10
32 set_gr_mem bad3,gr10
33 or_gr_immed 0x02000000,gr10
34 set_mem_gr gr10,bad3
35 set_gr_addr bad3,gr10
36 flush_data_cache gr10
37 set_gr_mem bad4,gr10
38 or_gr_immed 0x02000000,gr10
39 set_mem_gr gr10,bad4
40 set_gr_addr bad4,gr10
41 flush_data_cache gr10
42 set_gr_mem bad9,gr10
43 or_gr_immed 0x02000000,gr10
44 set_mem_gr gr10,bad9
45 set_gr_addr bad9,gr10
46 flush_data_cache gr10
47 set_gr_mem bada,gr10
48 or_gr_immed 0x02000000,gr10
49 set_mem_gr gr10,bada
50 set_gr_addr bada,gr10
51 flush_data_cache gr10
52
4a306116
DB
53 set_gr_immed 4,gr20 ; PC increment
54 set_gr_immed 0,gr15
55 inc_gr_immed -12,sp ; for memory alignment
56
57 set_gr_addr bad1,gr17
5ca353c3 58bad1: stdi gr0,@(sp,0) ; misaligned reg
4a306116
DB
59 test_gr_immed 1,gr15
60
61 set_gr_addr bad2,gr17
5ca353c3 62bad2: lddi @(sp,0),gr8 ; misaligned reg
4a306116
DB
63 test_gr_immed 2,gr15
64
65 set_gr_addr bad3,gr17
5ca353c3 66bad3: stdc cpr0,@(sp,gr0) ; misaligned reg
4a306116
DB
67 test_gr_immed 3,gr15
68
69 set_gr_addr bad4,gr17
5ca353c3 70bad4: lddc @(sp,gr0),cpr8 ; misaligned reg
4a306116
DB
71 test_gr_immed 4,gr15
72
73 set_gr_addr bad5,gr17
74bad5: stqi gr2,@(sp,0) ; misaligned reg
75 test_gr_immed 5,gr15
76
77 set_gr_addr bad6,gr17
78bad6: ldqi @(sp,0),gr10 ; misaligned reg
79 test_gr_immed 6,gr15
80
81 set_gr_addr bad7,gr17
82bad7: stqc cpr2,@(sp,gr0) ; misaligned reg
83 test_gr_immed 7,gr15
84
85 set_gr_addr bad8,gr17
86bad8: ldqc @(sp,gr0),cpr10 ; misaligned reg
87 test_gr_immed 8,gr15
88
89 set_gr_immed 0,gr20 ; PC increment
90 set_gr_addr bad9,gr17
5ca353c3 91bad9: stdfi fr0,@(sp,0) ; misaligned reg
4a306116
DB
92 test_gr_immed 9,gr15
93
94 set_gr_addr bada,gr17
5ca353c3 95bada: lddfi @(sp,0),fr8 ; misaligned reg
4a306116
DB
96 test_gr_immed 10,gr15
97
98 set_gr_addr badb,gr17
99badb: stqfi fr2,@(sp,0) ; misaligned reg
100 test_gr_immed 11,gr15
101
102 set_gr_addr badc,gr17
103badc: ldqfi @(sp,0),fr10 ; misaligned reg
104 test_gr_immed 12,gr15
105
106 pass
107
108; exception handler
109ok1:
110 cmpi gr20,0,icc0
111 beq icc0,0,float
112
113 ; check register_exception
114 test_spr_immed 0x1,esfr1 ; esr0 is active
115 test_spr_gr epcr0,gr17
116 test_spr_bits 0x0001,0,0x1,esr0 ; esr0 is valid
117 test_spr_bits 0x003e,1,0xc,esr0 ; esr0.ec is set
118 test_spr_bits 0x00c0,6,0x1,esr0 ; esr0.rec is set
119 test_spr_bits 0x0800,11,0x0,esr0 ; esr0.eav is not set
120 movsg pcsr,gr60
121 add gr60,gr20,gr60
122 movgs gr60,pcsr
123 bra ret
124float:
125 ; check fp_exception
126 test_spr_immed 0,esfr1 ; no esr's active
127ret:
128 inc_gr_immed 1,gr15
129 rett 0
130 fail
This page took 0.058258 seconds and 4 git commands to generate.