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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
author: Thiemo Seufer <ths@debian.org>
Fix compilation for Linux MIPS-I code.
--- a/src/corelib/arch/mips/qatomic32.s
+++ b/src/corelib/arch/mips/qatomic32.s
@@ -7,10 +7,12 @@
.ent q_atomic_test_and_set_int
.set mips2
q_atomic_test_and_set_int:
+ .set mips2
1: ll $8,0($4)
bne $8,$5,2f
move $2,$6
sc $2,0($4)
+ .set mips0
beqz $2,1b
nop
jr $31
@@ -24,6 +26,7 @@ q_atomic_test_and_set_int:
.ent q_atomic_test_and_set_acquire_int
.set mips2
q_atomic_test_and_set_acquire_int:
+ .set mips2
1: ll $8,0($4)
bne $8,$5,2f
move $2,$6
@@ -33,6 +36,7 @@ q_atomic_test_and_set_acquire_int:
jr $31
nop
2: sync
+ .set mips0
jr $31
move $2,$0
.set mips0
@@ -42,11 +46,13 @@ q_atomic_test_and_set_acquire_int:
.ent q_atomic_test_and_set_release_int
.set mips2
q_atomic_test_and_set_release_int:
+ .set mips2
sync
1: ll $8,0($4)
bne $8,$5,2f
move $2,$6
sc $2,0($4)
+ .set mips0
beqz $2,1b
nop
jr $31
@@ -60,10 +66,12 @@ q_atomic_test_and_set_release_int:
.ent q_atomic_test_and_set_ptr
.set mips2
q_atomic_test_and_set_ptr:
+ .set mips2
1: ll $8,0($4)
bne $8,$5,2f
move $2,$6
sc $2,0($4)
+ .set mips0
beqz $2,1b
nop
jr $31
@@ -77,6 +85,7 @@ q_atomic_test_and_set_ptr:
.ent q_atomic_test_and_set_acquire_ptr
.set mips2
q_atomic_test_and_set_acquire_ptr:
+ .set mips2
1: ll $8,0($4)
bne $8,$5,2f
move $2,$6
@@ -86,6 +95,7 @@ q_atomic_test_and_set_acquire_ptr:
jr $31
nop
2: sync
+ .set mips0
jr $31
move $2,$0
.set mips0
@@ -95,11 +105,13 @@ q_atomic_test_and_set_acquire_ptr:
.ent q_atomic_test_and_set_release_ptr
.set mips2
q_atomic_test_and_set_release_ptr:
+ .set mips2
sync
1: ll $8,0($4)
bne $8,$5,2f
move $2,$6
sc $2,0($4)
+ .set mips0
beqz $2,1b
nop
jr $31
|