Merge tag 'qemu-macppc-20230206' of https://github.com/mcayland/qemu into staging
[qemu.git] / tests / tcg / xtensa / test_sr.S
blob34441c7afff7a97595f870bda28a98681d72c010
1 #include "macros.inc"
3 test_suite sr
5 #if XCHAL_HAVE_BE
6 #define LOW__SR 0x04
7 #define HI_RSR 0x30
8 #define HI_WSR 0x31
9 #define HI_XSR 0x16
10 #else
11 #define LOW__SR 0x40
12 #define HI_RSR 0x03
13 #define HI_WSR 0x13
14 #define HI_XSR 0x61
15 #endif
17 .macro  sr_op sym, op_sym, op_byte, sr
18     .if \sym
19     \op_sym a4, \sr
20     .else
21     .byte LOW__SR, \sr, \op_byte
22     .endif
23 .endm
25 .macro  test_sr_op sym, mask, op, op_byte, sr
26     movi    a4, 0
27     .if (\mask)
28     set_vector kernel, 0
29     sr_op   \sym, \op, \op_byte, \sr
30     .else
31     set_vector kernel, 2f
33     sr_op   \sym, \op, \op_byte, \sr
34     test_fail
36     reset_ps
37     rsr     a2, exccause
38     assert  eqi, a2, 0
39     rsr     a2, epc1
40     movi    a3, 1b
41     assert  eq, a2, a3
42     .endif
43 .endm
45 .macro  test_sr_mask sr, sym, mask
46 test \sr
47     test_sr_op \sym, \mask & 1, rsr, HI_RSR, \sr
48     test_sr_op \sym, \mask & 2, wsr, HI_WSR, \sr
49     test_sr_op \sym, \mask & 4, xsr, HI_XSR, \sr
50 test_end
51 .endm
53 .macro  test_sr sr, conf
54     test_sr_mask    \sr, \conf, 7
55 .endm
57 #if XCHAL_HAVE_MAC16
58 test_sr acchi, 1
59 test_sr acclo, 1
60 #else
61 test_sr_mask /*acchi*/17, 0, 0
62 test_sr_mask /*acclo*/16, 0, 0
63 #endif
65 #if XCHAL_HAVE_S32C1I && XCHAL_HW_VERSION >= 230000
66 test_sr atomctl, 1
67 #else
68 test_sr_mask /*atomctl*/99, 0, 0
69 #endif
71 #if XCHAL_HAVE_BOOLEANS
72 test_sr br, 1
73 #else
74 test_sr_mask /*br*/4, 0, 0
75 #endif
77 test_sr_mask /*cacheattr*/98, 0, 0
79 #if XCHAL_HAVE_CCOUNT
80 test_sr ccompare0, 1
81 test_sr ccount, 1
82 #else
83 test_sr_mask /*ccompare0*/240, 0, 0
84 test_sr_mask /*ccount*/234, 0, 0
85 #endif
87 #if XCHAL_HAVE_CP
88 test_sr cpenable, 1
89 #else
90 test_sr_mask /*cpenable*/224, 0, 0
91 #endif
93 #if XCHAL_HAVE_DEBUG
94 #if XCHAL_NUM_DBREAK
95 test_sr dbreaka0, 1
96 test_sr dbreakc0, 1
97 #endif
98 test_sr_mask debugcause, 1, 1
99 #else
100 test_sr_mask /*dbreaka0*/144, 0, 0
101 test_sr_mask /*dbreakc0*/160, 0, 0
102 test_sr_mask /*debugcause*/233, 0, 0
103 #endif
105 test_sr depc, 1
107 #if XCHAL_HAVE_PTP_MMU
108 test_sr dtlbcfg, 1
109 #else
110 test_sr_mask /*dtlbcfg*/92, 0, 0
111 #endif
113 test_sr epc1, 1
115 #if XCHAL_NUM_INTLEVELS > 1
116 test_sr epc2, 1
117 test_sr eps2, 1
118 #else
119 test_sr_mask /*epc2*/178, 0, 0
120 test_sr_mask /*eps2*/194, 0, 0
121 #endif
123 test_sr exccause, 1
124 test_sr excsave1, 1
126 #if XCHAL_NUM_INTLEVELS > 1
127 test_sr excsave2, 1
128 #else
129 test_sr_mask /*excsave2*/210, 0, 0
130 #endif
132 test_sr excvaddr, 1
134 #if XCHAL_HAVE_DEBUG
135 #if XCHAL_NUM_IBREAK
136 test_sr ibreaka0, 1
137 test_sr ibreakenable, 1
138 #endif
139 test_sr icount, 1
140 test_sr icountlevel, 1
141 #else
142 test_sr_mask /*ibreaka0*/128, 0, 0
143 test_sr_mask /*ibreakenable*/96, 0, 0
144 test_sr_mask /*icount*/236, 0, 0
145 test_sr_mask /*icountlevel*/237, 0, 0
146 #endif
148 test_sr_mask /*intclear*/227, 0, 2
149 test_sr_mask /*interrupt*/226, 0, 3
150 test_sr intenable, 1
152 #if XCHAL_HAVE_PTP_MMU
153 test_sr itlbcfg, 1
154 #else
155 test_sr_mask /*itlbcfg*/91, 0, 0
156 #endif
158 #if XCHAL_HAVE_LOOPS
159 test_sr lbeg, 1
160 test_sr lcount, 1
161 test_sr lend, 1
162 #else
163 test_sr_mask /*lbeg*/0, 0, 0
164 test_sr_mask /*lcount*/2, 0, 0
165 test_sr_mask /*lend*/1, 0, 0
166 #endif
168 #if XCHAL_HAVE_ABSOLUTE_LITERALS
169 test_sr litbase, 1
170 #else
171 test_sr_mask /*litbase*/5, 0, 0
172 #endif
174 #if XCHAL_HAVE_MAC16
175 test_sr m0, 1
176 #else
177 test_sr_mask /*m0*/32, 0, 0
178 #endif
180 #if XCHAL_HW_VERSION >= 250000
181 test_sr_mask /*memctl*/97, 0, 7
182 #else
183 test_sr_mask /*memctl*/97, 0, 0
184 #endif
186 #if XCHAL_NUM_MISC_REGS
187 test_sr misc0, 1
188 #else
189 test_sr_mask /*misc0*/244, 0, 0
190 #endif
192 #if XCHAL_HAVE_PREFETCH
193 test_sr prefctl, 1
194 #else
195 test_sr_mask /*prefctl*/40, 0, 0
196 #endif
198 #if XCHAL_HAVE_PRID
199 test_sr_mask /*prid*/235, 0, 1
200 #else
201 test_sr_mask /*prid*/235, 0, 0
202 #endif
204 test_sr ps, 1
206 #if XCHAL_HAVE_PTP_MMU
207 test_sr ptevaddr, 1
208 test_sr rasid, 1
209 #else
210 test_sr_mask /*ptevaddr*/83, 0, 0
211 test_sr_mask /*rasid*/90, 0, 0
212 #endif
214 test_sr sar, 1
216 #if XCHAL_HAVE_S32C1I
217 test_sr scompare1, 1
218 #else
219 test_sr_mask /*scompare1*/12, 0, 0
220 #endif
222 #if XCHAL_HAVE_VECBASE
223 test_sr vecbase, 1
224 movi    a2, XCHAL_VECBASE_RESET_VADDR
225 wsr     a2, vecbase
226 #else
227 test_sr_mask /*vecbase*/231, 0, 0
228 #endif
230 #if XCHAL_HAVE_WINDOWED
231 test_sr windowbase, 1
232 test_sr windowstart, 1
233 #else
234 test_sr_mask /*windowbase*/72, 0, 0
235 test_sr_mask /*windowstart*/73, 0, 0
236 #endif
238 test_suite_end