Makefile revision 1.160
11.160Sjoerg#  $NetBSD: Makefile,v 1.160 2014/06/16 12:54:43 joerg Exp $
21.46Ssimonb#
31.46Ssimonb#  @(#)Makefile 5.1beta 93/09/24
41.27Sragge#
51.11Sjtc#  ====================================================
61.11Sjtc#  Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
71.46Ssimonb#
81.11Sjtc#  Developed at SunPro, a Sun Microsystems, Inc. business.
91.11Sjtc#  Permission to use, copy, modify, and distribute this
101.46Ssimonb#  software is freely granted, provided that this notice
111.11Sjtc#  is preserved.
121.11Sjtc#  ====================================================
131.46Ssimonb#
141.46Ssimonb#
151.11Sjtc
161.11Sjtc#
171.11Sjtc# There are two options in making libm at fdlibm compile time:
181.11Sjtc# 	_IEEE_LIBM 	--- IEEE libm; smaller, and somewhat faster
191.46Ssimonb#	_MULTI_LIBM	--- Support multi-standard at runtime by
201.46Ssimonb#			    imposing wrapper functions defined in
211.11Sjtc#			    fdlibm.h:
221.11Sjtc#				_IEEE_MODE 	-- IEEE
231.11Sjtc#				_XOPEN_MODE 	-- X/OPEN
241.11Sjtc#				_POSIX_MODE 	-- POSIX/ANSI
251.11Sjtc#				_SVID3_MODE 	-- SVID
261.11Sjtc#
271.46Ssimonb# Here is how to set up CPPFLAGS to create the desired libm at
281.11Sjtc# compile time:
291.1Scgd#
301.37Slukem# 	CPPFLAGS = -D_IEEE_LIBM		... IEEE libm (recommended)
311.37Slukem#	CPPFLAGS = -D_SVID3_MODE	... Multi-standard supported
321.46Ssimonb#					    libm with SVID as the
331.11Sjtc#					    default standard
341.37Slukem#	CPPFLAGS = -D_XOPEN_MODE	... Multi-standard supported
351.46Ssimonb#					    libm with XOPEN as the
361.11Sjtc#					    default standard
371.37Slukem#	CPPFLAGS = -D_POSIX_MODE	... Multi-standard supported
381.46Ssimonb#					    libm with POSIX as the
391.11Sjtc#					    default standard
401.37Slukem#	CPPFLAGS = 			... Multi-standard supported
411.46Ssimonb#					    libm with IEEE as the
421.11Sjtc#					    default standard
431.46Ssimonb#
441.11Sjtc
451.84SchristosUSE_SHLIBDIR=	yes
461.55Stv
471.40Sperry# require this for the value of I387_LIBM from mk.conf, if set.
481.40Sperry.include <bsd.own.mk>
491.54Slukem
501.156Schristos# compiler_rt uses typeof() and __extension__
511.156SchristosLINTFLAGS += -g
521.156Schristos
531.29Sjtc.if (${MACHINE_ARCH} == "alpha")
541.29Sjtc.PATH: ${.CURDIR}/arch/alpha
551.63SdrochnerARCH_SRCS = s_copysign.S s_copysignf.S lrint.S
561.159SmartinCOPTS+=	-mfloat-ieee -mieee-with-inexact -mfp-trap-mode=sui -mtrap-precision=i
571.137Smatt.elif (${MACHINE_CPU} == "arm")
581.126Smatt.PATH: ${.CURDIR}/arch/arm
591.153SskrllCOMMON_SRCS+= fenv.c s_nexttowardf.c \
601.153Sskrll	s_nearbyint.c s_rintl.c
611.152SmartinCOPTS.e_sqrtl.c += -DHAVE_FENV_H
621.137Smatt.if (${MKSOFTFLOAT} == "no")
631.132SmattARCH_SRCS = e_sqrt.S e_sqrtf.S lrint.S lrintf.S s_fabsf.S s_fma.S s_fmaf.S
641.137Smatt.else
651.137Smatt.for i in e_sqrt.o e_sqrtf.o lrint.o lrintf.o s_fabsf.o s_fma.o s_fmaf.o
661.139Schristos${i} ${i:.o=.po} ${i:.o=.pico} ${i:.o=.go} ${i:.o=.ln}: ${i:.o=.c}
671.137Smatt.endfor
681.137Smatt.endif
691.110Snakayama.elif (${MACHINE_ARCH} == "sparc")
701.110Snakayama.PATH: ${.CURDIR}/arch/sparc
711.110SnakayamaCOMMON_SRCS+= fenv.c
721.152SmartinCOPTS.e_sqrtl.c += -DHAVE_FENV_H
731.132SmattCOMMON_SRCS+= s_fma.c s_fmaf.c s_fmal.c
741.102Schristos.elif (${MACHINE_ARCH} == "sparc64")
751.102Schristos.PATH: ${.CURDIR}/arch/sparc64
761.141SmartinCOMMON_SRCS+= fenv.c s_nexttowardf.c \
771.152Smartin	s_nearbyint.c s_rintl.c
781.152SmartinCOPTS.e_sqrtl.c += -DHAVE_FENV_H
791.141Smartin.ifndef _COMPAT_M32_MK_
801.141SmartinCOMMON_SRCS+= s_nexttoward.c
811.141Smartin.endif
821.132SmattCOMMON_SRCS+= s_fma.c s_fmaf.c s_fmal.c
831.53Sfvdl.elif ((${MACHINE_ARCH} == "i386") || (${MACHINE_ARCH} == "x86_64"))
841.95Sjoerg
851.95Sjoerg.if (${MACHINE_ARCH} == "x86_64")
861.95Sjoerg.PATH: ${.CURDIR}/arch/x86_64
871.95Sjoerg.endif
881.40Sperry.PATH:	${.CURDIR}/arch/i387
891.95Sjoerg
901.133SmartinCOMMON_SRCS+= fenv.c s_nexttoward.c s_nexttowardf.c \
911.152Smartin	s_nearbyint.c s_rintl.c
921.132SmattCOMMON_SRCS+= s_fma.c s_fmaf.c s_fmal.c
931.152SmartinCOPTS.e_sqrtl.c += -DHAVE_FENV_H
941.130Schristos
951.40SperryARCH_SRCS = e_acos.S e_asin.S e_atan2.S e_exp.S e_expf.S e_fmod.S e_log.S \
961.68Srpaulo	    e_logf.S e_log10.S e_log10f.S e_log2.S e_log2f.S e_remainder.S \
971.68Srpaulo	    e_remainderf.S e_scalb.S e_scalbf.S e_sqrt.S e_sqrtf.S s_atan.S \
981.68Srpaulo	    s_atanf.S s_ceil.S s_ceilf.S s_copysign.S s_copysignf.S s_cos.S \
991.116Sjoerg	    s_cosf.S s_finite.S s_finitef.S s_floor.S s_floorf.S \
1001.116Sjoerg	    s_ilogb.S s_ilogbf.S s_ilogbl.S s_log1p.S s_log1pf.S \
1011.116Sjoerg	    s_logb.S s_logbf.S s_logbl.S \
1021.115Sjoerg	    s_rint.S s_rintf.S s_scalbn.S s_scalbnf.S s_significand.S \
1031.127Schristos	    s_significandf.S s_sin.S s_sinf.S s_tan.S s_tanf.S lrint.S 
1041.97Sdrochner# do not pick up the i387 asm version, it is incorrect
1051.97Sdrochners_modf.o s_modf.pico s_modf.po s_modf.d: s_modf.c
1061.95Sjoerg
1071.86Sad.if (${MACHINE_ARCH} == "i386")
1081.52SchristosSUBDIR=arch/i387
1091.40Sperry.endif
1101.50Sis.elif (${MACHINE_ARCH} == "m68k")
1111.50Sis.if defined(M68060)
1121.50Sis.PATH:	${.CURDIR}/arch/m68060
1131.50Sis.include "${.CURDIR}/arch/m68060/Makefile.list"
1141.50SisCOPTS+=-m68060
1151.51Sis.PATH:	${.CURDIR}/arch/m68k
1161.51SisARCH_SRCS += s_ceil.S s_copysign.S s_finite.S s_floor.S s_rint.S
1171.50Sis.elif defined(M68040)
1181.51Sis.PATH: ${.CURDIR}/arch/m68k
1191.51SisCOPTS+=-m68040
1201.51SisARCH_SRCS = s_copysign.S s_finite.S
1211.50Sis.else
1221.65Sjmmv.if (${MKSOFTFLOAT} != "yes")
1231.51Sis.PATH:	${.CURDIR}/arch/mc68881 ${.CURDIR}/arch/m68k
1241.30SjtcARCH_SRCS = e_acos.S e_asin.S e_atanh.S e_cosh.S e_exp.S e_fmod.S e_log.S \
1251.30Sjtc	    e_log10.S e_remainder.S e_scalb.S e_sinh.S e_sqrt.S s_atan.S \
1261.30Sjtc	    s_ceil.S s_copysign.S s_cos.S s_expm1.S s_finite.S s_floor.S \
1271.30Sjtc	    s_log1p.S s_logb.S s_rint.S s_scalbn.S s_sin.S s_tan.S s_tanh.S
1281.50Sis.endif
1291.65Sjmmv.endif
1301.50Sis# end of m68k
1311.27Sragge.elif (${MACHINE_ARCH} == "vax")
1321.113Smatt.PATH:	${.CURDIR}/arch/vax
1331.71Sis
1341.41Sragge#NOIEEE_ARCH= n_infnan.S n_argred.S n_sqrt.S
1351.41Sragge#ARCH_SRCS = n_atan2.S n_cabs.S n_cbrt.S n_support.S n_sincos.S n_tan.S
1361.41Sragge# XXX - ripped out due to lack of the insn polyd in the Mariah chip,
1371.41Sragge# and emulation code isn't written yet.
1381.138SmartinARCH_SRCS = n_scalbn.S
1391.122SmattWARNS?=5
1401.11Sjtc.endif
1411.59Smatt
1421.122SmattWARNS?=5
1431.1Scgd
1441.11Sjtc.PATH:	${.CURDIR}/man
1451.11Sjtc.PATH:	${.CURDIR}/src
1461.27Sragge.PATH:	${.CURDIR}/noieee_src
1471.1Scgd
1481.121Snjoly.if (${MACHINE_ARCH} == "alpha")
1491.125SmattCOPTS+= -mfp-rounding-mode=d
1501.121Snjoly.endif
1511.121Snjoly
1521.27Sragge.if (${MACHINE_ARCH} != "vax")
1531.37SlukemCPPFLAGS+= -D_MULTI_LIBM -D_POSIX_MODE
1541.76Smrg# XXX noieee libm is gross
1551.76SmrgCOPTS+=	-fno-strict-aliasing
1561.27Sragge.endif
1571.37SlukemCPPFLAGS+=-DLIBM_SCCS
1581.3Smycroft
1591.11SjtcLIB=	m
1601.124SchristosCOMMON_SRCS+= b_exp.c b_log.c b_tgamma.c \
1611.124Schristos	e_acos.c e_acosf.c e_acosh.c e_acoshf.c e_asin.c e_asinf.c \
1621.22Sjtc	e_atan2.c e_atan2f.c e_atanh.c e_atanhf.c e_cosh.c e_coshf.c e_exp.c \
1631.146Sjoerg	e_expf.c e_fmod.c e_fmodf.c e_fmodl.c e_hypot.c e_hypotf.c \
1641.146Sjoerg	e_j0.c e_j0f.c \
1651.28Sjtc	e_j1.c e_j1f.c e_jn.c e_jnf.c e_lgamma_r.c e_lgammaf_r.c e_log.c \
1661.66Schristos	e_log2.c e_log10.c e_log10f.c e_log2f.c e_logf.c e_pow.c e_powf.c \
1671.66Schristos	e_rem_pio2.c e_rem_pio2f.c e_remainder.c e_remainderf.c e_scalb.c \
1681.152Smartin	e_scalbf.c e_sinh.c e_sinhf.c e_sqrt.c e_sqrtf.c e_sqrtl.c \
1691.22Sjtc	k_cos.c k_cosf.c k_rem_pio2.c k_rem_pio2f.c k_sin.c k_sinf.c \
1701.22Sjtc	k_standard.c k_tan.c k_tanf.c \
1711.147Sjoerg	ldbl_dummy.c \
1721.150Sjoerg	s_asinh.c s_asinhf.c s_atan.c s_atanf.c s_cbrt.c s_cbrtf.c s_cbrtl.c \
1731.144Sjoerg	s_ceil.c s_ceilf.c s_ceill.c s_copysign.c s_copysignf.c s_copysignl.c \
1741.144Sjoerg	s_cos.c s_cosf.c s_erf.c \
1751.98Schristos	s_erff.c s_exp2.c s_exp2f.c s_expm1.c s_expm1f.c s_fabsf.c s_fabsl.c \
1761.92Schristos	s_finite.c s_finitef.c \
1771.144Sjoerg	s_floor.c s_floorf.c s_floorl.c s_frexpf.c \
1781.144Sjoerg	s_ilogb.c s_ilogbf.c s_ilogbl.c \
1791.135Sjoerg	s_isinff.c s_isnanf.c s_lib_version.c s_log1p.c \
1801.116Sjoerg	s_log1pf.c s_logb.c s_logbf.c s_logbl.c \
1811.160Sjoerg	s_matherr.c s_modff.c s_modfl.c s_nextafter.c s_nextafterl.c \
1821.144Sjoerg	s_nextafterf.c s_remquo.c s_remquof.c s_rint.c s_rintf.c \
1831.144Sjoerg	s_round.c s_roundf.c s_roundl.c s_scalbn.c \
1841.112Sjoerg	s_scalbnf.c s_scalbnl.c s_signgam.c s_significand.c s_significandf.c s_sin.c \
1851.148Sjoerg	s_sinf.c s_tan.c s_tanf.c s_tanh.c s_tanhf.c s_tgammaf.c \
1861.148Sjoerg	s_trunc.c s_truncf.c s_truncl.c \
1871.22Sjtc	w_acos.c w_acosf.c w_acosh.c w_acoshf.c w_asin.c w_asinf.c w_atan2.c \
1881.78Sdrochner	w_atan2f.c w_atanh.c w_atanhf.c w_cosh.c w_coshf.c \
1891.146Sjoerg	w_drem.c w_dremf.c w_exp.c w_expf.c w_fmod.c w_fmodf.c w_fmodl.c \
1901.146Sjoerg	w_gamma.c w_gamma_r.c w_gammaf.c w_gammaf_r.c w_hypot.c w_hypotf.c \
1911.146Sjoerg	w_j0.c \
1921.22Sjtc	w_j0f.c w_j1.c w_j1f.c w_jn.c w_jnf.c w_lgamma.c w_lgamma_r.c \
1931.67Schristos	w_lgammaf.c w_lgammaf_r.c w_log.c w_log10.c w_log10f.c w_log2.c \
1941.67Schristos	w_log2f.c w_logf.c \
1951.22Sjtc	w_pow.c w_powf.c w_remainder.c w_remainderf.c w_scalb.c w_scalbf.c \
1961.150Sjoerg	w_sinh.c w_sinhf.c w_sqrt.c w_sqrtf.c w_sqrtl.c \
1971.61Sdrochner	lrint.c lrintf.c llrint.c llrintf.c lround.c lroundf.c llround.c \
1981.135Sjoerg	llroundf.c s_frexp.c s_frexpl.c s_modf.c \
1991.132Smatt	s_fmax.c s_fmaxf.c s_fmaxl.c \
2001.132Smatt	s_fmin.c s_fminf.c s_fminl.c s_fdim.c
2011.90Schristos
2021.78Sdrochner.PATH:	${.CURDIR}/compat
2031.78SdrochnerCOMMON_SRCS+= compat_cabs.c compat_cabsf.c
2041.78Sdrochner# XXX our compatibility cabs() is different!
2051.123SjoergCOPTS.compat_cabs.c=	${${ACTIVE_CC} == "gcc":? -fno-builtin-cabs :}
2061.123SjoergCOPTS.compat_cabsf.c=	${${ACTIVE_CC} == "gcc":? -fno-builtin-cabsf :}
2071.78Sdrochner
2081.27Sragge# math routines for non-IEEE architectures.
2091.27SraggeNOIEEE_SRCS = n_asincos.c n_acosh.c n_asinh.c n_atan.c n_atanh.c n_cosh.c \
2101.155Smartin	n_erf.c n_exp.c n_exp2.c n_exp2f.c n_exp__E.c n_expm1.c n_floor.c \
2111.155Smartin	n_fmod.c n_gamma.c \
2121.27Sragge	n_lgamma.c n_j0.c n_j1.c n_jn.c n_log.c n_log10.c n_log1p.c \
2131.155Smartin	n_log2.c n_log__L.c n_pow.c n_sinh.c n_tanh.c \
2141.71Sis	n_sincos.c n_tan.c \
2151.100Sjakllsch	n_round.c n_roundf.c n_lround.c n_lroundf.c \
2161.100Sjakllsch	n_fmax.c n_fmaxf.c n_fmin.c n_fminf.c
2171.46Ssimonb#	n_sqrt.c n_argred.c n_infnan.c n_atan2.c n_cabs.c n_cbrt.c n_support.c
2181.36Smikel
2191.27Sragge
2201.13Sjtc# NetBSD's C library supplies these functions:
2211.23Sjtc#COMMON_SRCS+=	s_fabs.c s_frexp.c s_isinf.c s_isnan.c s_ldexp.c s_modf.c
2221.17Sjtc
2231.27Sragge.if (${MACHINE_ARCH} == "vax")
2241.27SraggeSRCS=	${NOIEEE_SRCS} ${NOIEEE_ARCH}
2251.27Sragge.else
2261.103SchristosSRCS=	${COMMON_SRCS}
2271.50Sis.endif
2281.50Sis
2291.50Sis.ifdef ARCH_ADDS
2301.50SisSRCS+= ${ARCH_ADDS}
2311.27Sragge.endif
2321.17Sjtc
2331.46Ssimonb# Substitute common sources with any arch specific sources
2341.33Sragge.for i in ${ARCH_SRCS} ${NOIEEE_ARCH}
2351.62Sdrochner    SRCS:=${SRCS:S/^${i:S/.S/.c/}/$i/}
2361.17Sjtc.endfor
2371.17Sjtc
2381.41Sragge.if (${MACHINE_ARCH} == "vax") # XXX until POLYD is written.
2391.43Smatt.PATH:	${.CURDIR}/arch/vax
2401.43SmattSRCS:=${SRCS} n_sqrt.S n_argred.S n_infnan.S n_atan2.S n_cabs.S n_cbrt.S \
2411.138Smartin	n_support.S n_scalbn.S
2421.41Sragge.endif
2431.1Scgd
2441.97Sdrochner.if (${MACHINE_ARCH} == "i386")
2451.97Sdrochner# XXX this gets miscompiled. There should be a better fix.
2461.97SdrochnerCOPTS.s_tanh.c+= -O0
2471.97Sdrochner.endif
2481.97Sdrochner
2491.106SjruohoMAN+=	acos.3 acosh.3 asin.3 asinh.3 atan.3 atan2.3 atanh.3 \
2501.106Sjruoho	ceil.3 copysign.3 cos.3 cosh.3 \
2511.106Sjruoho	erf.3 exp.3 \
2521.118Sjruoho	fabs.3 finite.3 fmod.3 frexp.3 hypot.3 \
2531.119Sjruoho	ieee_test.3 ilogb.3 isinff.3 j0.3 ldexp.3 lgamma.3 log.3 lrint.3 \
2541.120Sjruoho	math.3 modf.3 nextafter.3 pow.3 \
2551.106Sjruoho	remainder.3 rint.3 round.3 \
2561.117Sjruoho	scalbn.3 sin.3 sinh.3 sqrt.3 \
2571.106Sjruoho	tan.3 tanh.3 trunc.3 fmax.3 fdim.3
2581.1Scgd
2591.95Sjoerg# fenv.h interface
2601.95SjoergMAN+=	feclearexcept.3 feenableexcept.3 fegetenv.3 fegetround.3 fenv.3
2611.95SjoergMLINKS+=feclearexcept.3 fegetexceptflag.3	\
2621.95Sjoerg	feclearexcept.3 feraiseexcept.3		\
2631.96Swiz	feclearexcept.3 fesetexceptflag.3	\
2641.95Sjoerg	feclearexcept.3 fetestexcept.3
2651.95SjoergMLINKS+=feenableexcept.3 fedisableexcept.3	\
2661.95Sjoerg	feenableexcept.3 fegetexcept.3
2671.95SjoergMLINKS+=fegetenv.3 feholdexcept.3		\
2681.95Sjoerg	fegetenv.3 fesetenv.3			\
2691.95Sjoerg	fegetenv.3 feupdateenv.3
2701.95SjoergMLINKS+=fegetround.3 fesetround.3
2711.95Sjoerg
2721.47SkleinkMLINKS+=acos.3 acosf.3
2731.47SkleinkMLINKS+=acosh.3 acoshf.3
2741.47SkleinkMLINKS+=asin.3 asinf.3
2751.47SkleinkMLINKS+=asinh.3 asinhf.3
2761.47SkleinkMLINKS+=atan.3 atanf.3
2771.47SkleinkMLINKS+=atan2.3 atan2f.3
2781.47SkleinkMLINKS+=atanh.3 atanhf.3
2791.107SjruohoMLINKS+=ceil.3 ceilf.3 \
2801.145Sjoerg	ceil.3 ceill.3 \
2811.107Sjruoho	ceil.3 floor.3 \
2821.145Sjoerg	ceil.3 floorf.3 \
2831.145Sjoerg	ceil.3 floorl.3
2841.106SjruohoMLINKS+=copysign.3 copysignf.3 \
2851.106Sjruoho	copysign.3 copysignl.3
2861.47SkleinkMLINKS+=cos.3 cosf.3
2871.47SkleinkMLINKS+=cosh.3 coshf.3
2881.47SkleinkMLINKS+=erf.3 erff.3 erf.3 erfc.3 erf.3 erfcf.3
2891.98SchristosMLINKS+=exp.3 expf.3 exp.3 expm1.3 exp.3 expm1f.3 			\
2901.120Sjruoho	exp.3 exp2.3 exp.3 exp2f.3
2911.119SjruohoMLINKS+=log.3 logf.3 \
2921.119Sjruoho	log.3 log10.3 \
2931.119Sjruoho	log.3 log10f.3 \
2941.119Sjruoho	log.3 log1p.3 \
2951.119Sjruoho	log.3 log1pf.3 \
2961.119Sjruoho	log.3 log2.3 \
2971.119Sjruoho	log.3 log2f.3
2981.120SjruohoMLINKS+=pow.3 powf.3
2991.47SkleinkMLINKS+=fabs.3 fabsf.3
3001.118SjruohoMLINKS+=finite.3 finitef.3
3011.146SjoergMLINKS+=fmod.3 fmodf.3 \
3021.146Sjoerg	fmod.3 fmodl.3
3031.78SdrochnerMLINKS+=hypot.3 hypotf.3
3041.116SjoergMLINKS+=ieee_test.3 logb.3 ieee_test.3 logbf.3 ieee_test.3 logbl.3
3051.47SkleinkMLINKS+=ieee_test.3 scalb.3 ieee_test.3 scalbf.3
3061.47SkleinkMLINKS+=ieee_test.3 significand.3 ieee_test.3 significandf.3
3071.115SjoergMLINKS+=ilogb.3 ilogbf.3 ilogb.3 ilogbl.3
3081.49SkleinkMLINKS+=isinff.3 isnanf.3
3091.47SkleinkMLINKS+=j0.3 j0f.3 j0.3 j1.3 j0.3 j1f.3 j0.3 jn.3 j0.3 jnf.3 \
3101.47Skleink	j0.3 y0.3 j0.3 y0f.3 j0.3 y1.3 j0.3 y1f.3 j0.3 yn.3 j0.3 ynf.3
3111.48SkleinkMLINKS+=lgamma.3 lgammaf.3 lgamma.3 lgamma_r.3 lgamma.3 lgammaf_r.3 \
3121.48Skleink	lgamma.3 gamma.3 lgamma.3 gammaf.3 lgamma.3 gamma_r.3 \
3131.124Schristos	lgamma.3 gammaf_r.3 lgamma.3 tgamma.3 lgamma.3 tgammaf.3
3141.160SjoergMLINKS+=modf.3 modff.3 \
3151.160Sjoerg	modf.3 modfl.3
3161.105SjruohoMLINKS+=nextafter.3 nextafterf.3 \
3171.105Sjruoho	nextafter.3 nextafterl.3 \
3181.105Sjruoho	nextafter.3 nexttoward.3
3191.69SwizMLINKS+=lrint.3 lrintf.3 lrint.3 llrint.3 lrint.3 llrintf.3
3201.106SjruohoMLINKS+=remainder.3 remainderf.3 \
3211.106Sjruoho	remainder.3 remquo.3 \
3221.106Sjruoho	remainder.3 remquof.3
3231.47SkleinkMLINKS+=rint.3 rintf.3
3241.117SjruohoMLINKS+=scalbn.3 scalbnf.3 \
3251.117Sjruoho	scalbn.3 scalbnl.3
3261.47SkleinkMLINKS+=sin.3 sinf.3
3271.134SuebayasiMLINKS+=sin.3 sinhf.3
3281.150SjoergMLINKS+=sqrt.3 sqrtf.3 sqrt.3 sqrtl.3 \
3291.150Sjoerg	sqrt.3 cbrt.3 sqrt.3 cbrtf.3 sqrt.3 cbrtl.3
3301.47SkleinkMLINKS+=tan.3 tanf.3
3311.47SkleinkMLINKS+=tanh.3 tanhf.3
3321.145SjoergMLINKS+=round.3 roundf.3 \
3331.145Sjoerg	round.3 roundl.3
3341.149SjoergMLINKS+=trunc.3 truncf.3 \
3351.149Sjoerg	trunc.3 truncl.3
3361.90SchristosMLINKS+=fmax.3 fmaxl.3
3371.90SchristosMLINKS+=fmax.3 fmaxf.3
3381.90SchristosMLINKS+=fmax.3 fmin.3
3391.90SchristosMLINKS+=fmax.3 fminl.3
3401.90SchristosMLINKS+=fmax.3 fminf.3
3411.90SchristosMLINKS+=fdim.3 fdiml.3
3421.90SchristosMLINKS+=fdim.3 fdimf.3
3431.1Scgd
3441.89She.if (${MKCOMPLEX} != "no")
3451.82Sdrochner.include "${.CURDIR}/complex/Makefile.inc"
3461.87Sgmcgarry.endif
3471.87Sgmcgarry
3481.142SjoergCOPTS.compat_cabs.c+=	${${ACTIVE_CC} == "clang":? -Wno-incompatible-library-redeclaration :}
3491.142SjoergCOPTS.compat_cabsf.c+=	${${ACTIVE_CC} == "clang":? -Wno-incompatible-library-redeclaration :}
3501.142Sjoerg
3511.154Sjoerg.include "${.CURDIR}/compiler_rt/Makefile.inc"
3521.72Skleink.include "${.CURDIR}/gen/Makefile.inc"
3531.143Sjoerg
3541.1Scgd.include <bsd.lib.mk>
3551.52Schristos.include <bsd.subdir.mk>
356