Makefile revision 1.191 1 1.191 christos # $NetBSD: Makefile,v 1.191 2017/05/06 18:03:24 christos Exp $
2 1.46 simonb #
3 1.46 simonb # @(#)Makefile 5.1beta 93/09/24
4 1.27 ragge #
5 1.11 jtc # ====================================================
6 1.11 jtc # Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
7 1.46 simonb #
8 1.11 jtc # Developed at SunPro, a Sun Microsystems, Inc. business.
9 1.11 jtc # Permission to use, copy, modify, and distribute this
10 1.46 simonb # software is freely granted, provided that this notice
11 1.11 jtc # is preserved.
12 1.11 jtc # ====================================================
13 1.46 simonb #
14 1.46 simonb #
15 1.11 jtc
16 1.11 jtc #
17 1.11 jtc # There are two options in making libm at fdlibm compile time:
18 1.11 jtc # _IEEE_LIBM --- IEEE libm; smaller, and somewhat faster
19 1.46 simonb # _MULTI_LIBM --- Support multi-standard at runtime by
20 1.46 simonb # imposing wrapper functions defined in
21 1.11 jtc # fdlibm.h:
22 1.11 jtc # _IEEE_MODE -- IEEE
23 1.11 jtc # _XOPEN_MODE -- X/OPEN
24 1.11 jtc # _POSIX_MODE -- POSIX/ANSI
25 1.11 jtc # _SVID3_MODE -- SVID
26 1.11 jtc #
27 1.46 simonb # Here is how to set up CPPFLAGS to create the desired libm at
28 1.11 jtc # compile time:
29 1.1 cgd #
30 1.37 lukem # CPPFLAGS = -D_IEEE_LIBM ... IEEE libm (recommended)
31 1.37 lukem # CPPFLAGS = -D_SVID3_MODE ... Multi-standard supported
32 1.46 simonb # libm with SVID as the
33 1.11 jtc # default standard
34 1.37 lukem # CPPFLAGS = -D_XOPEN_MODE ... Multi-standard supported
35 1.46 simonb # libm with XOPEN as the
36 1.11 jtc # default standard
37 1.37 lukem # CPPFLAGS = -D_POSIX_MODE ... Multi-standard supported
38 1.46 simonb # libm with POSIX as the
39 1.11 jtc # default standard
40 1.37 lukem # CPPFLAGS = ... Multi-standard supported
41 1.46 simonb # libm with IEEE as the
42 1.11 jtc # default standard
43 1.46 simonb #
44 1.11 jtc
45 1.84 christos USE_SHLIBDIR= yes
46 1.55 tv
47 1.40 perry # require this for the value of I387_LIBM from mk.conf, if set.
48 1.40 perry .include <bsd.own.mk>
49 1.54 lukem
50 1.163 matt LIBC_MACHINE_ARCH?= ${MACHINE_ARCH}
51 1.163 matt LIBC_MACHINE_CPU?= ${MACHINE_CPU}
52 1.163 matt
53 1.156 christos # compiler_rt uses typeof() and __extension__
54 1.156 christos LINTFLAGS += -g
55 1.156 christos
56 1.163 matt .if (${LIBC_MACHINE_CPU} == "aarch64")
57 1.161 matt .PATH: ${.CURDIR}/arch/aarch64
58 1.161 matt ARCH_SRCS = e_sqrt.S e_sqrtf.S s_fabsf.S
59 1.161 matt ARCH_SRCS+= s_fma.S s_fmaf.S s_fmax.S s_fmaxf.S s_fmin.S s_fminf.S
60 1.189 chs .if ${MKSOFTFLOAT} == "no"
61 1.161 matt COMMON_SRCS+= fenv.c
62 1.189 chs .endif
63 1.161 matt COMMON_SRCS+= e_sqrtl.c
64 1.161 matt COMMON_SRCS+= s_fma.c s_fmaf.c s_fmal.c
65 1.163 matt .elif (${LIBC_MACHINE_ARCH} == "alpha")
66 1.29 jtc .PATH: ${.CURDIR}/arch/alpha
67 1.63 drochner ARCH_SRCS = s_copysign.S s_copysignf.S lrint.S
68 1.178 christos COMMON_SRCS+= fenv.c
69 1.159 martin COPTS+= -mfloat-ieee -mieee-with-inexact -mfp-trap-mode=sui -mtrap-precision=i
70 1.163 matt .elif (${LIBC_MACHINE_CPU} == "arm")
71 1.165 christos .PATH.c: ${.CURDIR}/arch/arm
72 1.189 chs .if ${MKSOFTFLOAT} == "no"
73 1.189 chs COMMON_SRCS+= fenv.c
74 1.189 chs .endif
75 1.189 chs COMMON_SRCS+= s_nexttowardf.c s_nearbyint.c s_rintl.c
76 1.187 christos .for f in fenv.c lrint.S lrintf.S s_fabsf.S s_fma.S s_fmaf.S
77 1.187 christos COPTS.$f += -mfpu=vfp
78 1.187 christos .endfor
79 1.185 jakllsch COMMON_SRCS+= s_fma.c s_fmaf.c s_fmal.c
80 1.137 matt .if (${MKSOFTFLOAT} == "no")
81 1.165 christos .PATH.S: ${.CURDIR}/arch/arm
82 1.132 matt ARCH_SRCS = e_sqrt.S e_sqrtf.S lrint.S lrintf.S s_fabsf.S s_fma.S s_fmaf.S
83 1.137 matt .endif
84 1.188 scole .elif (${LIBC_MACHINE_ARCH} == "ia64")
85 1.188 scole .PATH: ${.CURDIR}/arch/ia64
86 1.188 scole COMMON_SRCS += fenv.c
87 1.168 martin .elif (${LIBC_MACHINE_ARCH} == "hppa")
88 1.168 martin .PATH.c: ${.CURDIR}/arch/hppa
89 1.189 chs COMMON_SRCS+= fenv.c s_nexttowardf.c s_nearbyint.c s_rintl.c
90 1.163 matt .elif (${LIBC_MACHINE_ARCH} == "sparc")
91 1.110 nakayama .PATH: ${.CURDIR}/arch/sparc
92 1.110 nakayama COMMON_SRCS+= fenv.c
93 1.132 matt COMMON_SRCS+= s_fma.c s_fmaf.c s_fmal.c
94 1.163 matt .elif (${LIBC_MACHINE_ARCH} == "sparc64")
95 1.102 christos .PATH: ${.CURDIR}/arch/sparc64
96 1.189 chs COMMON_SRCS+= fenv.c
97 1.189 chs COMMON_SRCS+= s_nexttowardf.c s_nearbyint.c s_rintl.c
98 1.141 martin .ifndef _COMPAT_M32_MK_
99 1.141 martin COMMON_SRCS+= s_nexttoward.c
100 1.141 martin .endif
101 1.132 matt COMMON_SRCS+= s_fma.c s_fmaf.c s_fmal.c
102 1.164 mrg .elif ((${MACHINE_ARCH} == "i386") || (${MACHINE_ARCH} == "x86_64"))
103 1.95 joerg
104 1.164 mrg # XXX consider making this LIBC_MACHINE_ARCH?
105 1.164 mrg .if (${MACHINE_ARCH} == "x86_64")
106 1.95 joerg .PATH: ${.CURDIR}/arch/x86_64
107 1.95 joerg .endif
108 1.40 perry .PATH: ${.CURDIR}/arch/i387
109 1.95 joerg
110 1.133 martin COMMON_SRCS+= fenv.c s_nexttoward.c s_nexttowardf.c \
111 1.152 martin s_nearbyint.c s_rintl.c
112 1.132 matt COMMON_SRCS+= s_fma.c s_fmaf.c s_fmal.c
113 1.130 christos
114 1.40 perry ARCH_SRCS = e_acos.S e_asin.S e_atan2.S e_exp.S e_expf.S e_fmod.S e_log.S \
115 1.68 rpaulo e_logf.S e_log10.S e_log10f.S e_log2.S e_log2f.S e_remainder.S \
116 1.68 rpaulo e_remainderf.S e_scalb.S e_scalbf.S e_sqrt.S e_sqrtf.S s_atan.S \
117 1.68 rpaulo s_atanf.S s_ceil.S s_ceilf.S s_copysign.S s_copysignf.S s_cos.S \
118 1.116 joerg s_cosf.S s_finite.S s_finitef.S s_floor.S s_floorf.S \
119 1.180 christos s_log1p.S s_log1pf.S s_logb.S s_logbf.S s_logbl.S \
120 1.115 joerg s_rint.S s_rintf.S s_scalbn.S s_scalbnf.S s_significand.S \
121 1.127 christos s_significandf.S s_sin.S s_sinf.S s_tan.S s_tanf.S lrint.S
122 1.180 christos # do not pick up the i387 asm version for the following functions;
123 1.180 christos # it is incorrect
124 1.180 christos .for f in modf ilogb ilogbl ilogbf
125 1.184 christos s_${f}.o s_${f}.pico s_${f}.po s_${f}.go s_${f}.d: s_${f}.c
126 1.180 christos .endfor
127 1.95 joerg
128 1.164 mrg .if (${MACHINE_ARCH} == "i386")
129 1.52 christos SUBDIR=arch/i387
130 1.40 perry .endif
131 1.163 matt .elif (${LIBC_MACHINE_ARCH} == "m68k")
132 1.50 is .if defined(M68060)
133 1.50 is .PATH: ${.CURDIR}/arch/m68060
134 1.50 is .include "${.CURDIR}/arch/m68060/Makefile.list"
135 1.50 is COPTS+=-m68060
136 1.51 is .PATH: ${.CURDIR}/arch/m68k
137 1.51 is ARCH_SRCS += s_ceil.S s_copysign.S s_finite.S s_floor.S s_rint.S
138 1.50 is .elif defined(M68040)
139 1.51 is .PATH: ${.CURDIR}/arch/m68k
140 1.51 is COPTS+=-m68040
141 1.51 is ARCH_SRCS = s_copysign.S s_finite.S
142 1.50 is .else
143 1.189 chs .if (${MKSOFTFLOAT} == "no")
144 1.51 is .PATH: ${.CURDIR}/arch/mc68881 ${.CURDIR}/arch/m68k
145 1.30 jtc ARCH_SRCS = e_acos.S e_asin.S e_atanh.S e_cosh.S e_exp.S e_fmod.S e_log.S \
146 1.30 jtc e_log10.S e_remainder.S e_scalb.S e_sinh.S e_sqrt.S s_atan.S \
147 1.30 jtc s_ceil.S s_copysign.S s_cos.S s_expm1.S s_finite.S s_floor.S \
148 1.30 jtc s_log1p.S s_logb.S s_rint.S s_scalbn.S s_sin.S s_tan.S s_tanh.S
149 1.174 christos COMMON_SRCS += fenv.c
150 1.65 jmmv .endif
151 1.177 martin .endif
152 1.50 is # end of m68k
153 1.163 matt .elif (${LIBC_MACHINE_ARCH} == "vax")
154 1.113 matt .PATH: ${.CURDIR}/arch/vax
155 1.71 is
156 1.169 he #NOIEEE_ARCH+= s_fmax.c s_fmaxf.c s_fmaxl.c
157 1.169 he #NOIEEE_ARCH+= n_infnan.S n_argred.S n_sqrt.S
158 1.41 ragge #ARCH_SRCS = n_atan2.S n_cabs.S n_cbrt.S n_support.S n_sincos.S n_tan.S
159 1.41 ragge # XXX - ripped out due to lack of the insn polyd in the Mariah chip,
160 1.41 ragge # and emulation code isn't written yet.
161 1.138 martin ARCH_SRCS = n_scalbn.S
162 1.122 matt WARNS?=5
163 1.166 matt .elif (${LIBC_MACHINE_CPU} == "riscv")
164 1.166 matt .PATH: ${.CURDIR}/arch/riscv
165 1.166 matt
166 1.189 chs .if ${MKSOFTFLOAT} == "no"
167 1.166 matt COMMON_SRCS += fenv.c
168 1.166 matt ARCH_SRCS = e_sqrt.S e_sqrtf.S
169 1.166 matt ARCH_SRCS += s_copysign.S s_copysignf.S
170 1.166 matt ARCH_SRCS += s_fabs.S s_fabsf.S
171 1.166 matt ARCH_SRCS += s_fma.S s_fmaf.S
172 1.166 matt ARCH_SRCS += s_fmax.S s_fmaxf.S
173 1.166 matt ARCH_SRCS += s_fmin.S s_fminf.S
174 1.166 matt .endif
175 1.172 christos .elif (${LIBC_MACHINE_ARCH} == "powerpc")
176 1.172 christos .PATH: ${.CURDIR}/arch/powerpc
177 1.189 chs .if ${MKSOFTFLOAT} == "no"
178 1.173 christos COMMON_SRCS += fenv.c
179 1.189 chs .endif
180 1.173 christos .elif (${LIBC_MACHINE_CPU} == "mips")
181 1.173 christos .PATH: ${.CURDIR}/arch/mips
182 1.189 chs .if ${MKSOFTFLOAT} == "no"
183 1.182 christos COMMON_SRCS += fenv.c
184 1.189 chs .endif
185 1.181 christos .elif (${LIBC_MACHINE_CPU} == "sh3")
186 1.181 christos .PATH: ${.CURDIR}/arch/sh3
187 1.189 chs .if ${MKSOFTFLOAT} == "no"
188 1.181 christos COMMON_SRCS += fenv.c
189 1.11 jtc .endif
190 1.189 chs .endif
191 1.59 matt
192 1.122 matt WARNS?=5
193 1.1 cgd
194 1.11 jtc .PATH: ${.CURDIR}/man
195 1.11 jtc .PATH: ${.CURDIR}/src
196 1.27 ragge .PATH: ${.CURDIR}/noieee_src
197 1.1 cgd
198 1.163 matt .if (${LIBC_MACHINE_ARCH} == "alpha")
199 1.125 matt COPTS+= -mfp-rounding-mode=d
200 1.121 njoly .endif
201 1.121 njoly
202 1.163 matt .if (${LIBC_MACHINE_ARCH} != "vax")
203 1.37 lukem CPPFLAGS+= -D_MULTI_LIBM -D_POSIX_MODE
204 1.76 mrg # XXX noieee libm is gross
205 1.76 mrg COPTS+= -fno-strict-aliasing
206 1.27 ragge .endif
207 1.37 lukem CPPFLAGS+=-DLIBM_SCCS
208 1.3 mycroft
209 1.190 chs .if (${MKSOFTFLOAT} != "no" || ${MACHINE_ARCH} == "m68000")
210 1.189 chs .PATH: ${.CURDIR}/softfloat
211 1.189 chs .include "${.CURDIR}/../libc/libcincludes.mk"
212 1.189 chs CPPFLAGS+= -I${ARCHDIR}/softfloat
213 1.189 chs COMMON_SRCS += \
214 1.189 chs feclearexcept.c \
215 1.189 chs fedisableexcept.c \
216 1.189 chs feenableexcept.c \
217 1.189 chs fegetenv.c \
218 1.189 chs fegetexcept.c \
219 1.189 chs fegetexceptflag.c \
220 1.189 chs fegetround.c \
221 1.189 chs feholdexcept.c \
222 1.189 chs feraiseexcept.c \
223 1.189 chs fesetenv.c \
224 1.189 chs fesetexceptflag.c \
225 1.189 chs fesetround.c \
226 1.189 chs fetestexcept.c \
227 1.189 chs feupdateenv.c
228 1.189 chs .endif
229 1.189 chs
230 1.11 jtc LIB= m
231 1.124 christos COMMON_SRCS+= b_exp.c b_log.c b_tgamma.c \
232 1.124 christos e_acos.c e_acosf.c e_acosh.c e_acoshf.c e_asin.c e_asinf.c \
233 1.22 jtc e_atan2.c e_atan2f.c e_atanh.c e_atanhf.c e_cosh.c e_coshf.c e_exp.c \
234 1.146 joerg e_expf.c e_fmod.c e_fmodf.c e_fmodl.c e_hypot.c e_hypotf.c \
235 1.146 joerg e_j0.c e_j0f.c \
236 1.28 jtc e_j1.c e_j1f.c e_jn.c e_jnf.c e_lgamma_r.c e_lgammaf_r.c e_log.c \
237 1.66 christos e_log2.c e_log10.c e_log10f.c e_log2f.c e_logf.c e_pow.c e_powf.c \
238 1.66 christos e_rem_pio2.c e_rem_pio2f.c e_remainder.c e_remainderf.c e_scalb.c \
239 1.152 martin e_scalbf.c e_sinh.c e_sinhf.c e_sqrt.c e_sqrtf.c e_sqrtl.c \
240 1.22 jtc k_cos.c k_cosf.c k_rem_pio2.c k_rem_pio2f.c k_sin.c k_sinf.c \
241 1.22 jtc k_standard.c k_tan.c k_tanf.c \
242 1.147 joerg ldbl_dummy.c \
243 1.150 joerg s_asinh.c s_asinhf.c s_atan.c s_atanf.c s_cbrt.c s_cbrtf.c s_cbrtl.c \
244 1.144 joerg s_ceil.c s_ceilf.c s_ceill.c s_copysign.c s_copysignf.c s_copysignl.c \
245 1.144 joerg s_cos.c s_cosf.c s_erf.c \
246 1.98 christos s_erff.c s_exp2.c s_exp2f.c s_expm1.c s_expm1f.c s_fabsf.c s_fabsl.c \
247 1.92 christos s_finite.c s_finitef.c \
248 1.144 joerg s_floor.c s_floorf.c s_floorl.c s_frexpf.c \
249 1.144 joerg s_ilogb.c s_ilogbf.c s_ilogbl.c \
250 1.135 joerg s_isinff.c s_isnanf.c s_lib_version.c s_log1p.c \
251 1.191 christos s_llrint.c s_llrintf.c s_llrintl.c \
252 1.191 christos s_llround.c s_llroundf.c s_llroundl.c \
253 1.191 christos s_lrint.c s_lrintf.c s_lrintl.c \
254 1.191 christos s_lround.c s_lroundf.c s_lroundl.c \
255 1.116 joerg s_log1pf.c s_logb.c s_logbf.c s_logbl.c \
256 1.160 joerg s_matherr.c s_modff.c s_modfl.c s_nextafter.c s_nextafterl.c \
257 1.144 joerg s_nextafterf.c s_remquo.c s_remquof.c s_rint.c s_rintf.c \
258 1.144 joerg s_round.c s_roundf.c s_roundl.c s_scalbn.c \
259 1.112 joerg s_scalbnf.c s_scalbnl.c s_signgam.c s_significand.c s_significandf.c s_sin.c \
260 1.148 joerg s_sinf.c s_tan.c s_tanf.c s_tanh.c s_tanhf.c s_tgammaf.c \
261 1.148 joerg s_trunc.c s_truncf.c s_truncl.c \
262 1.22 jtc w_acos.c w_acosf.c w_acosh.c w_acoshf.c w_asin.c w_asinf.c w_atan2.c \
263 1.78 drochner w_atan2f.c w_atanh.c w_atanhf.c w_cosh.c w_coshf.c \
264 1.146 joerg w_drem.c w_dremf.c w_exp.c w_expf.c w_fmod.c w_fmodf.c w_fmodl.c \
265 1.146 joerg w_gamma.c w_gamma_r.c w_gammaf.c w_gammaf_r.c w_hypot.c w_hypotf.c \
266 1.146 joerg w_j0.c \
267 1.22 jtc w_j0f.c w_j1.c w_j1f.c w_jn.c w_jnf.c w_lgamma.c w_lgamma_r.c \
268 1.67 christos w_lgammaf.c w_lgammaf_r.c w_log.c w_log10.c w_log10f.c w_log2.c \
269 1.67 christos w_log2f.c w_logf.c \
270 1.22 jtc w_pow.c w_powf.c w_remainder.c w_remainderf.c w_scalb.c w_scalbf.c \
271 1.150 joerg w_sinh.c w_sinhf.c w_sqrt.c w_sqrtf.c w_sqrtl.c \
272 1.191 christos s_frexp.c s_frexpl.c s_modf.c \
273 1.132 matt s_fmax.c s_fmaxf.c s_fmaxl.c \
274 1.132 matt s_fmin.c s_fminf.c s_fminl.c s_fdim.c
275 1.90 christos
276 1.78 drochner .PATH: ${.CURDIR}/compat
277 1.78 drochner COMMON_SRCS+= compat_cabs.c compat_cabsf.c
278 1.78 drochner # XXX our compatibility cabs() is different!
279 1.123 joerg COPTS.compat_cabs.c= ${${ACTIVE_CC} == "gcc":? -fno-builtin-cabs :}
280 1.123 joerg COPTS.compat_cabsf.c= ${${ACTIVE_CC} == "gcc":? -fno-builtin-cabsf :}
281 1.78 drochner
282 1.27 ragge # math routines for non-IEEE architectures.
283 1.186 christos NOIEEE_SRCS = n_asincos.c n_acosh.c n_asinh.c n_atan.c n_atanh.c n_atanhf.c \
284 1.186 christos n_cosh.c \
285 1.155 martin n_erf.c n_exp.c n_exp2.c n_exp2f.c n_exp__E.c n_expm1.c n_floor.c \
286 1.179 christos n_fmod.c n_gamma.c n_ilogb.c \
287 1.27 ragge n_lgamma.c n_j0.c n_j1.c n_jn.c n_log.c n_log10.c n_log1p.c \
288 1.155 martin n_log2.c n_log__L.c n_pow.c n_sinh.c n_tanh.c \
289 1.71 is n_sincos.c n_tan.c \
290 1.100 jakllsch n_round.c n_roundf.c n_lround.c n_lroundf.c \
291 1.100 jakllsch n_fmax.c n_fmaxf.c n_fmin.c n_fminf.c
292 1.46 simonb # n_sqrt.c n_argred.c n_infnan.c n_atan2.c n_cabs.c n_cbrt.c n_support.c
293 1.36 mikel
294 1.27 ragge
295 1.13 jtc # NetBSD's C library supplies these functions:
296 1.23 jtc #COMMON_SRCS+= s_fabs.c s_frexp.c s_isinf.c s_isnan.c s_ldexp.c s_modf.c
297 1.17 jtc
298 1.163 matt .if (${LIBC_MACHINE_ARCH} == "vax")
299 1.27 ragge SRCS= ${NOIEEE_SRCS} ${NOIEEE_ARCH}
300 1.27 ragge .else
301 1.103 christos SRCS= ${COMMON_SRCS}
302 1.50 is .endif
303 1.50 is
304 1.50 is .ifdef ARCH_ADDS
305 1.50 is SRCS+= ${ARCH_ADDS}
306 1.27 ragge .endif
307 1.17 jtc
308 1.46 simonb # Substitute common sources with any arch specific sources
309 1.33 ragge .for i in ${ARCH_SRCS} ${NOIEEE_ARCH}
310 1.62 drochner SRCS:=${SRCS:S/^${i:S/.S/.c/}/$i/}
311 1.17 jtc .endfor
312 1.17 jtc
313 1.163 matt .if (${LIBC_MACHINE_ARCH} == "vax") # XXX until POLYD is written.
314 1.43 matt .PATH: ${.CURDIR}/arch/vax
315 1.43 matt SRCS:=${SRCS} n_sqrt.S n_argred.S n_infnan.S n_atan2.S n_cabs.S n_cbrt.S \
316 1.138 martin n_support.S n_scalbn.S
317 1.41 ragge .endif
318 1.1 cgd
319 1.163 matt .if (${LIBC_MACHINE_ARCH} == "i386")
320 1.97 drochner # XXX this gets miscompiled. There should be a better fix.
321 1.97 drochner COPTS.s_tanh.c+= -O0
322 1.97 drochner .endif
323 1.97 drochner
324 1.106 jruoho MAN+= acos.3 acosh.3 asin.3 asinh.3 atan.3 atan2.3 atanh.3 \
325 1.106 jruoho ceil.3 copysign.3 cos.3 cosh.3 \
326 1.106 jruoho erf.3 exp.3 \
327 1.171 nros fabs.3 finite.3 fma.3 fmod.3 frexp.3 hypot.3 \
328 1.119 jruoho ieee_test.3 ilogb.3 isinff.3 j0.3 ldexp.3 lgamma.3 log.3 lrint.3 \
329 1.120 jruoho math.3 modf.3 nextafter.3 pow.3 \
330 1.106 jruoho remainder.3 rint.3 round.3 \
331 1.117 jruoho scalbn.3 sin.3 sinh.3 sqrt.3 \
332 1.106 jruoho tan.3 tanh.3 trunc.3 fmax.3 fdim.3
333 1.1 cgd
334 1.95 joerg # fenv.h interface
335 1.95 joerg MAN+= feclearexcept.3 feenableexcept.3 fegetenv.3 fegetround.3 fenv.3
336 1.95 joerg MLINKS+=feclearexcept.3 fegetexceptflag.3 \
337 1.95 joerg feclearexcept.3 feraiseexcept.3 \
338 1.96 wiz feclearexcept.3 fesetexceptflag.3 \
339 1.95 joerg feclearexcept.3 fetestexcept.3
340 1.95 joerg MLINKS+=feenableexcept.3 fedisableexcept.3 \
341 1.95 joerg feenableexcept.3 fegetexcept.3
342 1.95 joerg MLINKS+=fegetenv.3 feholdexcept.3 \
343 1.95 joerg fegetenv.3 fesetenv.3 \
344 1.95 joerg fegetenv.3 feupdateenv.3
345 1.95 joerg MLINKS+=fegetround.3 fesetround.3
346 1.95 joerg
347 1.47 kleink MLINKS+=acos.3 acosf.3
348 1.47 kleink MLINKS+=acosh.3 acoshf.3
349 1.47 kleink MLINKS+=asin.3 asinf.3
350 1.47 kleink MLINKS+=asinh.3 asinhf.3
351 1.47 kleink MLINKS+=atan.3 atanf.3
352 1.47 kleink MLINKS+=atan2.3 atan2f.3
353 1.47 kleink MLINKS+=atanh.3 atanhf.3
354 1.107 jruoho MLINKS+=ceil.3 ceilf.3 \
355 1.145 joerg ceil.3 ceill.3 \
356 1.107 jruoho ceil.3 floor.3 \
357 1.145 joerg ceil.3 floorf.3 \
358 1.145 joerg ceil.3 floorl.3
359 1.106 jruoho MLINKS+=copysign.3 copysignf.3 \
360 1.106 jruoho copysign.3 copysignl.3
361 1.47 kleink MLINKS+=cos.3 cosf.3
362 1.47 kleink MLINKS+=cosh.3 coshf.3
363 1.167 christos MLINKS+=erf.3 erff.3 \
364 1.167 christos erf.3 erfl.3 \
365 1.167 christos erf.3 erfc.3 \
366 1.167 christos erf.3 erfcf.3 \
367 1.167 christos erf.3 erfcl.3
368 1.98 christos MLINKS+=exp.3 expf.3 exp.3 expm1.3 exp.3 expm1f.3 \
369 1.120 jruoho exp.3 exp2.3 exp.3 exp2f.3
370 1.119 jruoho MLINKS+=log.3 logf.3 \
371 1.119 jruoho log.3 log10.3 \
372 1.119 jruoho log.3 log10f.3 \
373 1.119 jruoho log.3 log1p.3 \
374 1.119 jruoho log.3 log1pf.3 \
375 1.119 jruoho log.3 log2.3 \
376 1.119 jruoho log.3 log2f.3
377 1.120 jruoho MLINKS+=pow.3 powf.3
378 1.175 nros MLINKS+=fabs.3 fabsf.3 \
379 1.175 nros fabs.3 fabsl.3
380 1.118 jruoho MLINKS+=finite.3 finitef.3
381 1.146 joerg MLINKS+=fmod.3 fmodf.3 \
382 1.146 joerg fmod.3 fmodl.3
383 1.78 drochner MLINKS+=hypot.3 hypotf.3
384 1.116 joerg MLINKS+=ieee_test.3 logb.3 ieee_test.3 logbf.3 ieee_test.3 logbl.3
385 1.47 kleink MLINKS+=ieee_test.3 scalb.3 ieee_test.3 scalbf.3
386 1.47 kleink MLINKS+=ieee_test.3 significand.3 ieee_test.3 significandf.3
387 1.115 joerg MLINKS+=ilogb.3 ilogbf.3 ilogb.3 ilogbl.3
388 1.49 kleink MLINKS+=isinff.3 isnanf.3
389 1.47 kleink MLINKS+=j0.3 j0f.3 j0.3 j1.3 j0.3 j1f.3 j0.3 jn.3 j0.3 jnf.3 \
390 1.47 kleink j0.3 y0.3 j0.3 y0f.3 j0.3 y1.3 j0.3 y1f.3 j0.3 yn.3 j0.3 ynf.3
391 1.176 nros MLINKS+=ldexp.3 ldexpf.3 \
392 1.176 nros ldexp.3 ldexpl.3
393 1.48 kleink MLINKS+=lgamma.3 lgammaf.3 lgamma.3 lgamma_r.3 lgamma.3 lgammaf_r.3 \
394 1.48 kleink lgamma.3 gamma.3 lgamma.3 gammaf.3 lgamma.3 gamma_r.3 \
395 1.124 christos lgamma.3 gammaf_r.3 lgamma.3 tgamma.3 lgamma.3 tgammaf.3
396 1.160 joerg MLINKS+=modf.3 modff.3 \
397 1.160 joerg modf.3 modfl.3
398 1.105 jruoho MLINKS+=nextafter.3 nextafterf.3 \
399 1.105 jruoho nextafter.3 nextafterl.3 \
400 1.170 he nextafter.3 nexttoward.3 \
401 1.170 he nextafter.3 nexttowardf.3
402 1.69 wiz MLINKS+=lrint.3 lrintf.3 lrint.3 llrint.3 lrint.3 llrintf.3
403 1.106 jruoho MLINKS+=remainder.3 remainderf.3 \
404 1.106 jruoho remainder.3 remquo.3 \
405 1.106 jruoho remainder.3 remquof.3
406 1.169 he MLINKS+=rint.3 rintf.3 \
407 1.169 he rint.3 rintl.3 \
408 1.169 he rint.3 nearbyint.3 \
409 1.169 he rint.3 nearbyintf.3 \
410 1.169 he rint.3 nearbyintl.3
411 1.117 jruoho MLINKS+=scalbn.3 scalbnf.3 \
412 1.117 jruoho scalbn.3 scalbnl.3
413 1.47 kleink MLINKS+=sin.3 sinf.3
414 1.134 uebayasi MLINKS+=sin.3 sinhf.3
415 1.150 joerg MLINKS+=sqrt.3 sqrtf.3 sqrt.3 sqrtl.3 \
416 1.150 joerg sqrt.3 cbrt.3 sqrt.3 cbrtf.3 sqrt.3 cbrtl.3
417 1.47 kleink MLINKS+=tan.3 tanf.3
418 1.47 kleink MLINKS+=tanh.3 tanhf.3
419 1.145 joerg MLINKS+=round.3 roundf.3 \
420 1.145 joerg round.3 roundl.3
421 1.149 joerg MLINKS+=trunc.3 truncf.3 \
422 1.149 joerg trunc.3 truncl.3
423 1.90 christos MLINKS+=fmax.3 fmaxl.3
424 1.90 christos MLINKS+=fmax.3 fmaxf.3
425 1.90 christos MLINKS+=fmax.3 fmin.3
426 1.90 christos MLINKS+=fmax.3 fminl.3
427 1.90 christos MLINKS+=fmax.3 fminf.3
428 1.90 christos MLINKS+=fdim.3 fdiml.3
429 1.90 christos MLINKS+=fdim.3 fdimf.3
430 1.171 nros MLINKS+=fma.3 fmaf.3 \
431 1.171 nros fma.3 fmal.3
432 1.1 cgd
433 1.89 he .if (${MKCOMPLEX} != "no")
434 1.82 drochner .include "${.CURDIR}/complex/Makefile.inc"
435 1.87 gmcgarry .endif
436 1.87 gmcgarry
437 1.142 joerg COPTS.compat_cabs.c+= ${${ACTIVE_CC} == "clang":? -Wno-incompatible-library-redeclaration :}
438 1.142 joerg COPTS.compat_cabsf.c+= ${${ACTIVE_CC} == "clang":? -Wno-incompatible-library-redeclaration :}
439 1.142 joerg
440 1.154 joerg .include "${.CURDIR}/compiler_rt/Makefile.inc"
441 1.72 kleink .include "${.CURDIR}/gen/Makefile.inc"
442 1.143 joerg
443 1.1 cgd .include <bsd.lib.mk>
444 1.52 christos .include <bsd.subdir.mk>
445