Merge tag 'qemu-macppc-20230206' of https://github.com/mcayland/qemu into staging
[qemu.git] / tests / tcg / xtensa / test_loop.S
blob0cfd8661ea0e5267916a7d5cc18cec7cafc63c80
1 #include "macros.inc"
3 test_suite loop
5 #if XCHAL_HAVE_LOOPS
7 test loop
8     movi    a2, 0
9     movi    a3, 5
10     loop    a3, 1f
11     addi    a2, a2, 1
13     assert  eqi, a2, 5
14 test_end
16 test loop0
17     movi    a2, 0
18     loop    a2, 1f
19     rsr     a2, lcount
20     assert  eqi, a2, -1
21     j       1f
23 test_end
25 test loop_jump
26     movi    a2, 0
27     movi    a3, 5
28     loop    a3, 1f
29     addi    a2, a2, 1
30     j       1f
32     assert  eqi, a2, 1
33 test_end
35 test loop_branch
36     movi    a2, 0
37     movi    a3, 5
38     loop    a3, 1f
39     addi    a2, a2, 1
40     beqi    a2, 3, 1f
42     assert  eqi, a2, 3
43 test_end
45 test loop_manual
46     movi    a2, 0
47     movi    a3, 5
48     movi    a4, 1f
49     movi    a5, 2f
50     wsr     a3, lcount
51     wsr     a4, lbeg
52     wsr     a5, lend
53     isync
54     j       1f
55 .align 4
57     addi    a2, a2, 1
59     assert  eqi, a2, 6
60 test_end
62 test loop_excm
63     movi    a2, 0
64     movi    a3, 5
65     rsr     a4, ps
66     movi    a5, 0x10
67     or      a4, a4, a5
68     wsr     a4, ps
69     isync
70     loop    a3, 1f
71     addi    a2, a2, 1
73     xor     a4, a4, a5
74     isync
75     wsr     a4, ps
76     assert  eqi, a2, 1
77 test_end
79 test lbeg_invalidation
80     movi    a2, 0
81     movi    a3, 1
82     movi    a4, 1f
83     movi    a5, 3f
84     wsr     a3, lcount
85     wsr     a4, lbeg
86     wsr     a5, lend
87     isync
88     j       1f
89 .align 4
91     addi    a2, a2, 1
92     j       2f
93 .align 4
95     addi    a2, a2, 2
96     movi    a3, 2b
97     wsr     a3, lbeg
98     isync
99     nop
101     assert  eqi, a2, 5
102 test_end
104 test lend_invalidation
105     movi    a2, 0
106     movi    a3, 5
107     movi    a4, 1f
108     movi    a5, 2f
109     wsr     a3, lcount
110     wsr     a4, lbeg
111     wsr     a5, lend
112     isync
113     j       1f
114 .align 4
116     addi    a2, a2, 1
118     beqi    a3, 3, 1f
119     assert  eqi, a2, 6
120     movi    a3, 3
121     wsr     a3, lcount
122     wsr     a4, lend
123     isync
124     j       1b
126     assert  eqi, a2, 7
127 test_end
129 test loopnez
130     movi    a2, 0
131     movi    a3, 5
132     loopnez a3, 1f
133     addi    a2, a2, 1
135     assert  eqi, a2, 5
137     movi    a2, 0
138     movi    a3, 0
139     loopnez a3, 1f
140     test_fail
142 test_end
144 test loopgtz
145     movi    a2, 0
146     movi    a3, 5
147     loopgtz a3, 1f
148     addi    a2, a2, 1
150     assert  eqi, a2, 5
152     movi    a2, 0
153     movi    a3, 0
154     loopgtz a3, 1f
155     test_fail
158     movi    a2, 0
159     movi    a3, 0x80000000
160     loopgtz a3, 1f
161     test_fail
163 test_end
165 #endif
167 test_suite_end