xref: /freebsd/lib/libcompiler_rt/Makefile.inc (revision 3dd5524264095ed8612c28908e13f80668eff2f9)
1# $FreeBSD$
2
3CRTARCH=	${MACHINE_CPUARCH:C/amd64/x86_64/}
4
5CRTSRC=		${SRCTOP}/contrib/llvm-project/compiler-rt/lib/builtins
6
7.PATH:		${CRTSRC}/${CRTARCH}
8.PATH:		${CRTSRC}
9
10SRCF+=		absvdi2
11SRCF+=		absvsi2
12SRCF+=		absvti2
13SRCF+=		addvdi3
14SRCF+=		addvsi3
15SRCF+=		addvti3
16SRCF+=		apple_versioning
17SRCF+=		ashldi3
18SRCF+=		ashlti3
19SRCF+=		ashrdi3
20SRCF+=		ashrti3
21SRCF+=		bswapdi2
22SRCF+=		bswapsi2
23SRCF+=		clear_cache
24SRCF+=		clzdi2
25SRCF+=		clzsi2
26SRCF+=		clzti2
27SRCF+=		cmpdi2
28SRCF+=		cmpti2
29SRCF+=		ctzdi2
30SRCF+=		ctzsi2
31SRCF+=		ctzti2
32SRCF+=		divdc3
33SRCF+=		divdi3
34SRCF+=		divmoddi4
35SRCF+=		divmodsi4
36SRCF+=		divmodti4
37SRCF+=		divsc3
38SRCF+=		divsi3
39SRCF+=		divtc3
40SRCF+=		divti3
41SRCF+=		divxc3
42SRCF+=		enable_execute_stack
43SRCF+=		eprintf
44SRCF+=		extendhfsf2
45SRCF+=		ffsdi2
46SRCF+=		ffssi2
47SRCF+=		ffsti2
48SRCF+=		fixdfdi
49SRCF+=		fixdfti
50SRCF+=		fixsfdi
51SRCF+=		fixsfti
52SRCF+=		fixunsdfdi
53SRCF+=		fixunsdfsi
54SRCF+=		fixunsdfti
55SRCF+=		fixunssfdi
56SRCF+=		fixunssfsi
57SRCF+=		fixunssfti
58SRCF+=		fixunsxfdi
59SRCF+=		fixunsxfsi
60SRCF+=		fixunsxfti
61SRCF+=		fixxfdi
62SRCF+=		fixxfti
63SRCF+=		floatditf
64SRCF+=		floattidf
65SRCF+=		floattisf
66SRCF+=		floattixf
67SRCF+=		floatunditf
68SRCF+=		floatunsidf
69SRCF+=		floatunsisf
70SRCF+=		floatuntidf
71SRCF+=		floatuntisf
72SRCF+=		floatuntixf
73SRCF+=		int_util
74SRCF+=		lshrdi3
75SRCF+=		lshrti3
76SRCF+=		moddi3
77SRCF+=		modsi3
78SRCF+=		modti3
79SRCF+=		muldc3
80SRCF+=		muldi3
81SRCF+=		mulodi4
82SRCF+=		mulosi4
83SRCF+=		muloti4
84SRCF+=		mulsc3
85SRCF+=		multc3
86SRCF+=		multi3
87SRCF+=		mulvdi3
88SRCF+=		mulvsi3
89SRCF+=		mulvti3
90SRCF+=		mulxc3
91SRCF+=		negdf2
92SRCF+=		negdi2
93SRCF+=		negsf2
94SRCF+=		negti2
95SRCF+=		negvdi2
96SRCF+=		negvsi2
97SRCF+=		negvti2
98SRCF+=		paritydi2
99SRCF+=		paritysi2
100SRCF+=		parityti2
101SRCF+=		popcountdi2
102SRCF+=		popcountsi2
103SRCF+=		popcountti2
104SRCF+=		powidf2
105SRCF+=		powisf2
106SRCF+=		powitf2
107SRCF+=		powixf2
108SRCF+=		subvdi3
109SRCF+=		subvsi3
110SRCF+=		subvti3
111SRCF+=		trampoline_setup
112SRCF+=		truncdfhf2
113SRCF+=		truncsfhf2
114SRCF+=		ucmpdi2
115SRCF+=		ucmpti2
116SRCF+=		udivdi3
117SRCF+=		udivmoddi4
118SRCF+=		udivmodsi4
119SRCF+=		udivmodti4
120SRCF+=		udivsi3
121SRCF+=		udivti3
122SRCF+=		umoddi3
123SRCF+=		umodsi3
124SRCF+=		umodti3
125
126# Enable compiler-rt's atomic implementation only for clang, as it uses clang
127# specific builtins, and gcc packages usually come with their own libatomic.
128# Exclude arm which has its own implementations of atomic functions, below.
129.if "${COMPILER_TYPE}" == "clang" && ${MACHINE_CPUARCH} != "arm"
130SRCF+=		atomic
131.endif
132
133# Avoid using SSE2 instructions on i386, if unsupported.
134.if ${MACHINE_CPUARCH} == "i386" && empty(MACHINE_CPU:Msse2)
135SRCS+=		floatdidf.c
136SRCS+=		floatdisf.c
137SRCS+=		floatdixf.c
138SRCS+=		floatundidf.c
139SRCS+=		floatundisf.c
140SRCS+=		floatundixf.c
141.else
142SRCF+=		floatdidf
143SRCF+=		floatdisf
144SRCF+=		floatdixf
145SRCF+=		floatundidf
146SRCF+=		floatundisf
147SRCF+=		floatundixf
148.endif
149
150# __cpu_model support, only used on aarch64 and x86
151.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
152    ${MACHINE_CPUARCH} == "i386"
153SRCF+=		cpu_model
154.endif
155
156# The fp_mode implementation for amd64 and i386 is shared, while other
157# architectures use the regular approach.
158.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386"
159SRCS+=		i386/fp_mode.c
160.else
161SRCF+=		fp_mode
162.endif
163
164#
165# 128-bit quad precision long double support,
166# only used on some architectures.
167#
168.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "riscv"
169SRCF+=		addtf3
170SRCF+=		comparetf2
171SRCF+=		divtf3
172SRCF+=		extenddftf2
173SRCF+=		extendhftf2
174SRCF+=		extendsftf2
175SRCF+=		fixtfdi
176SRCF+=		fixtfsi
177SRCF+=		fixtfti
178SRCF+=		fixunstfdi
179SRCF+=		fixunstfsi
180SRCF+=		fixunstfti
181SRCF+=		floatsitf
182SRCF+=		floattitf
183SRCF+=		floatunsitf
184SRCF+=		floatuntitf
185SRCF+=		multf3
186SRCF+=		subtf3
187SRCF+=		trunctfdf2
188SRCF+=		trunctfhf2
189SRCF+=		trunctfsf2
190.endif
191
192# These are already shipped by libc.a on some architectures.
193.if ${MACHINE_CPUARCH} != "arm" && ${MACHINE_CPUARCH} != "mips" && \
194    ${MACHINE_CPUARCH} != "riscv"
195SRCF+=		adddf3
196SRCF+=		addsf3
197SRCF+=		divdf3
198SRCF+=		divsf3
199SRCF+=		extendsfdf2
200SRCF+=		fixdfsi
201SRCF+=		fixsfsi
202SRCF+=		floatsidf
203SRCF+=		floatsisf
204SRCF+=		muldf3
205SRCF+=		mulsf3
206SRCF+=		subdf3
207SRCF+=		subsf3
208SRCF+=		truncdfsf2
209.endif
210
211.if ${MACHINE_CPUARCH} != "arm" && ${MACHINE_CPUARCH} != "mips"
212SRCF+=		comparedf2
213SRCF+=		comparesf2
214.endif
215
216# FreeBSD-specific atomic intrinsics.
217.if ${MACHINE_CPUARCH} == "arm"
218.PATH:		${SRCTOP}/sys/arm/arm
219
220SRCF+=		stdatomic
221CFLAGS+=	-DEMIT_SYNC_ATOMICS
222.elif ${MACHINE_CPUARCH} == "mips"
223.PATH:		${SRCTOP}/sys/mips/mips
224
225SRCF+=		stdatomic
226.endif
227
228.for file in ${SRCF}
229.if ${MACHINE_CPUARCH} == "arm" && (!defined(CPUTYPE) || ${CPUTYPE:M*soft*} == "") \
230    && exists(${CRTSRC}/${CRTARCH}/${file}vfp.S)
231SRCS+=		${file}vfp.S
232. elif exists(${CRTSRC}/${CRTARCH}/${file}.S)
233SRCS+=		${file}.S
234. else
235SRCS+=		${file}.c
236. endif
237.endfor
238
239.if ${MACHINE_CPUARCH} == "arm"
240SRCS+=		aeabi_div0.c
241SRCS+=		aeabi_idivmod.S
242SRCS+=		aeabi_ldivmod.S
243SRCS+=		aeabi_memcmp.S
244SRCS+=		aeabi_memcpy.S
245SRCS+=		aeabi_memmove.S
246SRCS+=		aeabi_memset.S
247SRCS+=		aeabi_uidivmod.S
248SRCS+=		aeabi_uldivmod.S
249SRCS+=		switch16.S
250SRCS+=		switch32.S
251SRCS+=		switch8.S
252SRCS+=		switchu8.S
253SRCS+=		sync_synchronize.S
254.endif
255
256.if ${MACHINE_ARCH:Mriscv*sf}
257CFLAGS+=	-D__SOFT_FP__
258.endif
259