Makefile revision 1.54
11.54Slukem# $NetBSD: Makefile,v 1.54 2001/11/05 15:22:23 lukem 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.40Sperry# require this for the value of I387_LIBM from mk.conf, if set. 461.40Sperry.include <bsd.own.mk> 471.54Slukem 481.54SlukemWARNS?=1 491.40Sperry 501.29Sjtc.if (${MACHINE_ARCH} == "alpha") 511.29Sjtc.PATH: ${.CURDIR}/arch/alpha 521.29SjtcARCH_SRCS = s_copysign.S s_copysignf.S 531.53Sfvdl.elif ((${MACHINE_ARCH} == "i386") || (${MACHINE_ARCH} == "x86_64")) 541.53Sfvdl.if (defined(I387_LIBM) || (${MACHINE_ARCH} == "x86_64")) 551.40Sperry.PATH: ${.CURDIR}/arch/i387 561.40SperryARCH_SRCS = e_acos.S e_asin.S e_atan2.S e_exp.S e_expf.S e_fmod.S e_log.S \ 571.40Sperry e_logf.S e_log10.S e_log10f.S e_remainder.S e_remainderf.S \ 581.40Sperry e_scalb.S e_scalbf.S e_sqrt.S e_sqrtf.S s_atan.S s_atanf.S \ 591.40Sperry s_ceil.S s_ceilf.S s_copysign.S s_copysignf.S s_cos.S s_cosf.S \ 601.40Sperry s_finite.S s_finitef.S s_floor.S s_floorf.S s_ilogb.S s_ilogbf.S \ 611.40Sperry s_log1p.S s_log1pf.S s_logb.S s_logbf.S s_rint.S s_rintf.S \ 621.40Sperry s_scalbn.S s_scalbnf.S s_significand.S s_significandf.S s_sin.S \ 631.40Sperry s_sinf.S s_tan.S s_tanf.S 641.52Schristos.else 651.52SchristosSUBDIR=arch/i387 661.40Sperry.endif 671.50Sis.elif (${MACHINE_ARCH} == "m68k") 681.50Sis.if defined(M68060) 691.50Sis.PATH: ${.CURDIR}/arch/m68060 701.50Sis.include "${.CURDIR}/arch/m68060/Makefile.list" 711.50SisCOPTS+=-m68060 721.51Sis.PATH: ${.CURDIR}/arch/m68k 731.51SisARCH_SRCS += s_ceil.S s_copysign.S s_finite.S s_floor.S s_rint.S 741.50Sis.elif defined(M68040) 751.51Sis.PATH: ${.CURDIR}/arch/m68k 761.51SisCOPTS+=-m68040 771.51SisARCH_SRCS = s_copysign.S s_finite.S 781.50Sis.else 791.51Sis.PATH: ${.CURDIR}/arch/mc68881 ${.CURDIR}/arch/m68k 801.30SjtcARCH_SRCS = e_acos.S e_asin.S e_atanh.S e_cosh.S e_exp.S e_fmod.S e_log.S \ 811.30Sjtc e_log10.S e_remainder.S e_scalb.S e_sinh.S e_sqrt.S s_atan.S \ 821.30Sjtc s_ceil.S s_copysign.S s_cos.S s_expm1.S s_finite.S s_floor.S \ 831.30Sjtc s_log1p.S s_logb.S s_rint.S s_scalbn.S s_sin.S s_tan.S s_tanh.S 841.50Sis.endif 851.50Sis# end of m68k 861.27Sragge.elif (${MACHINE_ARCH} == "vax") 871.41Sragge#.PATH: ${.CURDIR}/arch/vax 881.41Sragge#NOIEEE_ARCH= n_infnan.S n_argred.S n_sqrt.S 891.41Sragge#ARCH_SRCS = n_atan2.S n_cabs.S n_cbrt.S n_support.S n_sincos.S n_tan.S 901.41Sragge# XXX - ripped out due to lack of the insn polyd in the Mariah chip, 911.41Sragge# and emulation code isn't written yet. 921.11Sjtc.endif 931.1Scgd 941.11Sjtc.PATH: ${.CURDIR}/man 951.11Sjtc.PATH: ${.CURDIR}/src 961.27Sragge.PATH: ${.CURDIR}/noieee_src 971.1Scgd 981.27Sragge.if (${MACHINE_ARCH} != "vax") 991.37SlukemCPPFLAGS+= -D_MULTI_LIBM -D_POSIX_MODE 1001.27Sragge.endif 1011.37SlukemCPPFLAGS+=-DLIBM_SCCS 1021.3Smycroft 1031.11SjtcLIB= m 1041.22SjtcCOMMON_SRCS = e_acos.c e_acosf.c e_acosh.c e_acoshf.c e_asin.c e_asinf.c \ 1051.22Sjtc e_atan2.c e_atan2f.c e_atanh.c e_atanhf.c e_cosh.c e_coshf.c e_exp.c \ 1061.28Sjtc e_expf.c e_fmod.c e_fmodf.c e_hypot.c e_hypotf.c e_j0.c e_j0f.c \ 1071.28Sjtc e_j1.c e_j1f.c e_jn.c e_jnf.c e_lgamma_r.c e_lgammaf_r.c e_log.c \ 1081.28Sjtc e_log10.c e_log10f.c e_logf.c e_pow.c e_powf.c e_rem_pio2.c \ 1091.22Sjtc e_rem_pio2f.c e_remainder.c e_remainderf.c e_scalb.c e_scalbf.c \ 1101.22Sjtc e_sinh.c e_sinhf.c e_sqrt.c e_sqrtf.c \ 1111.22Sjtc k_cos.c k_cosf.c k_rem_pio2.c k_rem_pio2f.c k_sin.c k_sinf.c \ 1121.22Sjtc k_standard.c k_tan.c k_tanf.c \ 1131.22Sjtc s_asinh.c s_asinhf.c s_atan.c s_atanf.c s_cbrt.c s_cbrtf.c s_ceil.c \ 1141.36Smikel s_ceilf.c s_copysign.c s_copysignf.c s_cos.c s_cosf.c s_erf.c \ 1151.36Smikel s_erff.c s_expm1.c s_expm1f.c s_fabsf.c s_finite.c s_finitef.c \ 1161.22Sjtc s_floor.c s_floorf.c s_frexpf.c s_ilogb.c s_ilogbf.c \ 1171.23Sjtc s_isinff.c s_isnanf.c s_ldexpf.c s_lib_version.c s_log1p.c \ 1181.36Smikel s_log1pf.c s_logb.c s_logbf.c s_matherr.c s_modff.c s_nextafter.c \ 1191.36Smikel s_nextafterf.c s_rint.c s_rintf.c s_scalbn.c s_scalbnf.c \ 1201.22Sjtc s_signgam.c s_significand.c s_significandf.c s_sin.c s_sinf.c s_tan.c \ 1211.22Sjtc s_tanf.c s_tanh.c s_tanhf.c \ 1221.22Sjtc w_acos.c w_acosf.c w_acosh.c w_acoshf.c w_asin.c w_asinf.c w_atan2.c \ 1231.22Sjtc w_atan2f.c w_atanh.c w_atanhf.c w_cabs.c w_cabsf.c w_cosh.c w_coshf.c \ 1241.22Sjtc w_drem.c w_dremf.c w_exp.c w_expf.c w_fmod.c w_fmodf.c w_gamma.c \ 1251.22Sjtc w_gamma_r.c w_gammaf.c w_gammaf_r.c w_hypot.c w_hypotf.c w_j0.c \ 1261.22Sjtc w_j0f.c w_j1.c w_j1f.c w_jn.c w_jnf.c w_lgamma.c w_lgamma_r.c \ 1271.22Sjtc w_lgammaf.c w_lgammaf_r.c w_log.c w_log10.c w_log10f.c w_logf.c \ 1281.22Sjtc w_pow.c w_powf.c w_remainder.c w_remainderf.c w_scalb.c w_scalbf.c \ 1291.22Sjtc w_sinh.c w_sinhf.c w_sqrt.c w_sqrtf.c 1301.3Smycroft 1311.27Sragge# math routines for non-IEEE architectures. 1321.27SraggeNOIEEE_SRCS = n_asincos.c n_acosh.c n_asinh.c n_atan.c n_atanh.c n_cosh.c \ 1331.27Sragge n_erf.c n_exp.c n_exp__E.c n_expm1.c n_floor.c n_fmod.c n_gamma.c \ 1341.27Sragge n_lgamma.c n_j0.c n_j1.c n_jn.c n_log.c n_log10.c n_log1p.c \ 1351.41Sragge n_log__L.c n_pow.c n_sinh.c n_tanh.c \ 1361.46Ssimonb n_sincos.c n_tan.c 1371.46Ssimonb# n_sqrt.c n_argred.c n_infnan.c n_atan2.c n_cabs.c n_cbrt.c n_support.c 1381.36Smikel 1391.27Sragge 1401.13Sjtc# NetBSD's C library supplies these functions: 1411.23Sjtc#COMMON_SRCS+= s_fabs.c s_frexp.c s_isinf.c s_isnan.c s_ldexp.c s_modf.c 1421.17Sjtc 1431.27Sragge.if (${MACHINE_ARCH} == "vax") 1441.27SraggeSRCS= ${NOIEEE_SRCS} ${NOIEEE_ARCH} 1451.27Sragge.else 1461.27SraggeSRCS= ${COMMON_SRCS} 1471.50Sis.endif 1481.50Sis 1491.50Sis.ifdef ARCH_ADDS 1501.50SisSRCS+= ${ARCH_ADDS} 1511.27Sragge.endif 1521.17Sjtc 1531.46Ssimonb# Substitute common sources with any arch specific sources 1541.33Sragge.for i in ${ARCH_SRCS} ${NOIEEE_ARCH} 1551.17Sjtc SRCS:=${SRCS:S/${i:S/.S/.c/}/$i/} 1561.17Sjtc.endfor 1571.17Sjtc 1581.41Sragge.if (${MACHINE_ARCH} == "vax") # XXX until POLYD is written. 1591.43Smatt.PATH: ${.CURDIR}/arch/vax 1601.43SmattSRCS:=${SRCS} n_sqrt.S n_argred.S n_infnan.S n_atan2.S n_cabs.S n_cbrt.S \ 1611.46Ssimonb n_support.S 1621.41Sragge.endif 1631.39Scgd 1641.44She# XXX lint buts on some archs and needs stubs 1651.44SheMKLINT=no 1661.1Scgd 1671.24ScgdMAN+= acos.3 acosh.3 asin.3 asinh.3 atan.3 atan2.3 atanh.3 ceil.3 \ 1681.24Scgd cos.3 cosh.3 erf.3 exp.3 fabs.3 floor.3 fmod.3 hypot.3 ieee.3 \ 1691.49Skleink ieee_test.3 isinff.3 j0.3 lgamma.3 math.3 rint.3 sin.3 sinh.3 sqrt.3 \ 1701.24Scgd tan.3 tanh.3 1711.1Scgd 1721.47SkleinkMLINKS+=acos.3 acosf.3 1731.47SkleinkMLINKS+=acosh.3 acoshf.3 1741.47SkleinkMLINKS+=asin.3 asinf.3 1751.47SkleinkMLINKS+=asinh.3 asinhf.3 1761.47SkleinkMLINKS+=atan.3 atanf.3 1771.47SkleinkMLINKS+=atan2.3 atan2f.3 1781.47SkleinkMLINKS+=atanh.3 atanhf.3 1791.47SkleinkMLINKS+=ceil.3 ceilf.3 1801.47SkleinkMLINKS+=cos.3 cosf.3 1811.47SkleinkMLINKS+=cosh.3 coshf.3 1821.47SkleinkMLINKS+=erf.3 erff.3 erf.3 erfc.3 erf.3 erfcf.3 1831.47SkleinkMLINKS+=exp.3 expf.3 exp.3 expm1.3 exp.3 expm1f.3 exp.3 log.3 exp.3 logf.3 \ 1841.47Skleink exp.3 log10.3 exp.3 log10f.3 exp.3 log1p.3 exp.3 log1pf.3 \ 1851.47Skleink exp.3 pow.3 exp.3 powf.3 1861.47SkleinkMLINKS+=fabs.3 fabsf.3 1871.47SkleinkMLINKS+=floor.3 floorf.3 1881.47SkleinkMLINKS+=fmod.3 fmodf.3 1891.47SkleinkMLINKS+=hypot.3 hypotf.3 hypot.3 cabs.3 hypot.3 cabsf.3 1901.47SkleinkMLINKS+=ieee.3 copysign.3 ieee.3 copysignf.3 ieee.3 finite.3 ieee.3 finitef.3 \ 1911.47Skleink ieee.3 ilogb.3 ieee.3 ilogbf.3 ieee.3 nextafter.3 ieee.3 nextafterf.3 \ 1921.47Skleink ieee.3 remainder.3 ieee.3 remainderf.3 ieee.3 scalbn.3 ieee.3 scalbnf.3 1931.47SkleinkMLINKS+=ieee_test.3 logb.3 ieee_test.3 logbf.3 1941.47SkleinkMLINKS+=ieee_test.3 scalb.3 ieee_test.3 scalbf.3 1951.47SkleinkMLINKS+=ieee_test.3 significand.3 ieee_test.3 significandf.3 1961.49SkleinkMLINKS+=isinff.3 isnanf.3 1971.47SkleinkMLINKS+=j0.3 j0f.3 j0.3 j1.3 j0.3 j1f.3 j0.3 jn.3 j0.3 jnf.3 \ 1981.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 1991.48SkleinkMLINKS+=lgamma.3 lgammaf.3 lgamma.3 lgamma_r.3 lgamma.3 lgammaf_r.3 \ 2001.48Skleink lgamma.3 gamma.3 lgamma.3 gammaf.3 lgamma.3 gamma_r.3 \ 2011.48Skleink lgamma.3 gammaf_r.3 2021.47SkleinkMLINKS+=rint.3 rintf.3 2031.47SkleinkMLINKS+=sin.3 sinf.3 2041.47SkleinkMLINKS+=sinf.3 sinhf.3 2051.47SkleinkMLINKS+=sqrt.3 sqrtf.3 sqrt.3 cbrt.3 sqrt.3 cbrtf.3 2061.47SkleinkMLINKS+=tan.3 tanf.3 2071.47SkleinkMLINKS+=tanh.3 tanhf.3 2081.1Scgd 2091.1Scgd.include <bsd.lib.mk> 2101.52Schristos.include <bsd.subdir.mk> 211