Skip to content

Commit 95c6236

Browse files
committed
[hexagon] Remove aliases w/o leading __
These hexagon builtins incorrectly created aliases in the global namespace which can (and in at least one case, did) conflict with symbols defined by other programs. This should address the issue reported as rust-lang/rust#129823: Compiling compiler_builtins v0.1.123 Compiling core v0.0.0 (/home/ben/.rustup/toolchains/nightly-x86_64-unknown-linux-gnu/lib/rustlib/src/rust/library/core) Compiling rustc-std-workspace-core v1.99.0 (/home/ben/.rustup/toolchains/nightly-x86_64-unknown-linux-gnu/lib/rustlib/src/rust/library/rustc-std-workspace-core) Compiling byteorder v1.5.0 Compiling zerocopy v0.7.34 error: symbol 'fma' is already defined error: could not compile `compiler_builtins` (lib) due to 1 previous error Also: some of the symbols defined were not just aliases, so those are now qualified with `__hexagon_`. The compiler does not yet emit calls to these particular ones, but if/when it does, it can use the new names.
1 parent 43185fa commit 95c6236

File tree

4 files changed

+24
-32
lines changed

4 files changed

+24
-32
lines changed

src/hexagon/dffma.s

-2
Original file line numberDiff line numberDiff line change
@@ -3,8 +3,6 @@
33
.type __hexagon_fmadf4,@function
44
.global __hexagon_fmadf5
55
.type __hexagon_fmadf5,@function
6-
.global fma
7-
.type fma,@function
86
.global __qdsp_fmadf5 ; .set __qdsp_fmadf5, __hexagon_fmadf5
97
.p2align 5
108
__hexagon_fmadf4:

src/hexagon/dfminmax.s

-6
Original file line numberDiff line numberDiff line change
@@ -1,17 +1,12 @@
11
.text
22
.global __hexagon_mindf3
33
.global __hexagon_maxdf3
4-
.global fmin
5-
.type fmin,@function
6-
.global fmax
7-
.type fmax,@function
84
.type __hexagon_mindf3,@function
95
.type __hexagon_maxdf3,@function
106
.global __qdsp_mindf3 ; .set __qdsp_mindf3, __hexagon_mindf3
117
.global __qdsp_maxdf3 ; .set __qdsp_maxdf3, __hexagon_maxdf3
128
.p2align 5
139
__hexagon_mindf3:
14-
fmin:
1510
{
1611
p0 = dfclass(r1:0,#0x10)
1712
p1 = dfcmp.gt(r1:0,r3:2)
@@ -31,7 +26,6 @@ fmin:
3126
.size __hexagon_mindf3,.-__hexagon_mindf3
3227
.falign
3328
__hexagon_maxdf3:
34-
fmax:
3529
{
3630
p0 = dfclass(r1:0,#0x10)
3731
p1 = dfcmp.gt(r3:2,r1:0)

src/hexagon/fastmath2_dlib_asm.s

+15-15
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
.text
2-
.global fast2_dadd_asm
3-
.type fast2_dadd_asm, @function
4-
fast2_dadd_asm:
2+
.global __hexagon_fast2_dadd_asm
3+
.type __hexagon_fast2_dadd_asm, @function
4+
__hexagon_fast2_dadd_asm:
55
.falign
66
{
77
R7:6 = VABSDIFFH(R1:0, R3:2)
@@ -49,9 +49,9 @@ fast2_dadd_asm:
4949
jumpr r31
5050
}
5151
.text
52-
.global fast2_dsub_asm
53-
.type fast2_dsub_asm, @function
54-
fast2_dsub_asm:
52+
.global __hexagon_fast2_dsub_asm
53+
.type __hexagon_fast2_dsub_asm, @function
54+
__hexagon_fast2_dsub_asm:
5555
.falign
5656
{
5757
R7:6 = VABSDIFFH(R1:0, R3:2)
@@ -99,9 +99,9 @@ fast2_dsub_asm:
9999
jumpr r31
100100
}
101101
.text
102-
.global fast2_dmpy_asm
103-
.type fast2_dmpy_asm, @function
104-
fast2_dmpy_asm:
102+
.global __hexagon_fast2_dmpy_asm
103+
.type __hexagon_fast2_dmpy_asm, @function
104+
__hexagon_fast2_dmpy_asm:
105105
.falign
106106
{
107107
R13= lsr(R2, #16)
@@ -167,9 +167,9 @@ fast2_dmpy_asm:
167167
jumpr r31
168168
}
169169
.text
170-
.global fast2_qd2f_asm
171-
.type fast2_qd2f_asm, @function
172-
fast2_qd2f_asm:
170+
.global __hexagon_fast2_qd2f_asm
171+
.type __hexagon_fast2_qd2f_asm, @function
172+
__hexagon_fast2_qd2f_asm:
173173
.falign
174174
{
175175
R3 = abs(R1):sat
@@ -225,9 +225,9 @@ fast2_qd2f_asm:
225225
jumpr r31
226226
}
227227
.text
228-
.global fast2_f2qd_asm
229-
.type fast2_f2qd_asm, @function
230-
fast2_f2qd_asm:
228+
.global __hexagon_fast2_f2qd_asm
229+
.type __hexagon_fast2_f2qd_asm, @function
230+
__hexagon_fast2_f2qd_asm:
231231

232232

233233

src/hexagon/fastmath2_ldlib_asm.s

+9-9
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
.text
2-
.global fast2_ldadd_asm
3-
.type fast2_ldadd_asm, @function
4-
fast2_ldadd_asm:
2+
.global __hexagon_fast2ldadd_asm
3+
.type __hexagon_fast2ldadd_asm, @function
4+
__hexagon_fast2ldadd_asm:
55
.falign
66
{
77
R4 = memw(r29+#8)
@@ -54,9 +54,9 @@ fast2_ldadd_asm:
5454
jumpr r31
5555
}
5656
.text
57-
.global fast2_ldsub_asm
58-
.type fast2_ldsub_asm, @function
59-
fast2_ldsub_asm:
57+
.global __hexagon_fast2ldsub_asm
58+
.type __hexagon_fast2ldsub_asm, @function
59+
__hexagon_fast2ldsub_asm:
6060
.falign
6161
{
6262
R4 = memw(r29+#8)
@@ -109,9 +109,9 @@ fast2_ldsub_asm:
109109
jumpr r31
110110
}
111111
.text
112-
.global fast2_ldmpy_asm
113-
.type fast2_ldmpy_asm, @function
114-
fast2_ldmpy_asm:
112+
.global __hexagon_fast2ldmpy_asm
113+
.type __hexagon_fast2ldmpy_asm, @function
114+
__hexagon_fast2ldmpy_asm:
115115
.falign
116116
{
117117
R15:14 = memd(r29+#0)

0 commit comments

Comments
 (0)