aboutsummaryrefslogtreecommitdiff
path: root/share/mk/src.libnames.mk
diff options
context:
space:
mode:
Diffstat (limited to 'share/mk/src.libnames.mk')
-rw-r--r--share/mk/src.libnames.mk306
1 files changed, 235 insertions, 71 deletions
diff --git a/share/mk/src.libnames.mk b/share/mk/src.libnames.mk
index e3d5baecaa29..28c23680d2fb 100644
--- a/share/mk/src.libnames.mk
+++ b/share/mk/src.libnames.mk
@@ -7,13 +7,10 @@
.error src.libnames.mk cannot be included directly.
.endif
-.include <src.opts.mk>
+.if !target(__<src.libnames.mk>__)
+__<src.libnames.mk>__:
-.if ${.OBJDIR:S,${.CURDIR},,} != ${.OBJDIR}
-ROOTOBJDIR= ${.OBJDIR:S,${.CURDIR},,}${SRCTOP}
-.elif defined(OBJTOP) && ${.OBJDIR:M${OBJTOP}*} != ""
-ROOTOBJDIR= ${OBJTOP}
-.endif
+.include <src.opts.mk>
_PRIVATELIBS= \
atf_c \
@@ -39,7 +36,7 @@ _INTERNALLIBS= \
netbsd \
ntp \
ntpevent \
- ohash \
+ openbsd \
opts \
parse \
readline \
@@ -53,10 +50,13 @@ _INTERNALLIBS= \
_LIBRARIES= \
${_PRIVATELIBS} \
${_INTERNALLIBS} \
+ ${LOCAL_LIBRARIES} \
+ 80211 \
alias \
archive \
asn1 \
auditd \
+ avl \
begemot \
bluetooth \
bsdxml \
@@ -121,6 +121,7 @@ _LIBRARIES= \
netgraph \
ngatm \
nv \
+ nvpair \
opie \
pam \
panel \
@@ -147,32 +148,61 @@ _LIBRARIES= \
ssp_nonshared \
stdthreads \
supcplusplus \
+ sysdecode \
tacplus \
+ termcap \
termcapw \
ufs \
ugidfw \
ulog \
+ umem \
usb \
usbhid \
util \
+ uutil \
vmmapi \
wind \
wrap \
xo \
y \
ypclnt \
- z
+ z \
+ zfs_core \
+ zfs \
+ zpool \
+
+.if ${MK_OFED} != "no"
+_LIBRARIES+= \
+ cxgb4 \
+ ibcm \
+ ibcommon \
+ ibmad \
+ ibsdp \
+ ibumad \
+ ibverbs \
+ mlx4 \
+ mthca \
+ opensm \
+ osmcomp \
+ osmvendor \
+ rdmacm \
+
+.endif
+# Each library's LIBADD needs to be duplicated here for static linkage of
+# 2nd+ order consumers. Auto-generating this would be better.
+_DP_80211= sbuf bsdxml
_DP_archive= z bz2 lzma bsdxml
.if ${MK_OPENSSL} != "no"
_DP_archive+= crypto
.else
_DP_archive+= md
.endif
+_DP_sqlite3= pthread
_DP_ssl= crypto
-_DP_ssh= crypto crypt
+_DP_ssh= crypto crypt z
.if ${MK_LDNS} != "no"
-_DP_ssh+= ldns z
+_DP_ssh+= ldns
.endif
_DP_edit= ncursesw
.if ${MK_OPENSSL} != "no"
@@ -182,10 +212,11 @@ _DP_geom= bsdxml sbuf
_DP_cam= sbuf
_DP_casper= capsicum nv pjdlog
_DP_capsicum= nv
+_DP_kvm= elf
_DP_pjdlog= util
_DP_opie= md
_DP_usb= pthread
-_DP_unbound= pthread
+_DP_unbound= ssl crypto pthread
_DP_rt= pthread
.if ${MK_OPENSSL} == "no"
_DP_radius= md
@@ -203,10 +234,11 @@ _DP_proc= supcplusplus
.if ${MK_CDDL} != "no"
_DP_proc+= ctf
.endif
+_DP_proc+= elf rtld_db util
_DP_mp= crypto
_DP_memstat= kvm
_DP_magic= z
-_DP_mt= bsdxml
+_DP_mt= sbuf bsdxml
_DP_ldns= crypto
.if ${MK_OPENSSL} != "no"
_DP_fetch= ssl crypto
@@ -215,7 +247,7 @@ _DP_fetch= md
.endif
_DP_execinfo= elf
_DP_dwarf= elf
-_DP_dpv= dialog figpar util
+_DP_dpv= dialog figpar util ncursesw
_DP_dialog= ncursesw m
_DP_cuse= pthread
_DP_atf_cxx= atf_c
@@ -230,17 +262,49 @@ _DP_pam+= ssh
.if ${MK_NIS} != "no"
_DP_pam+= ypclnt
.endif
-_DP_krb5+= asn1 com_err crypt crypto hx509 roken wind heimbase heimipcc \
- pthread
+_DP_readline= ncursesw
+_DP_roken= crypt
+_DP_kadm5clnt= com_err krb5 roken
+_DP_kadm5srv= com_err hdb krb5 roken
+_DP_heimntlm= crypto com_err krb5 roken
+_DP_hx509= asn1 com_err crypto roken wind
+_DP_hdb= asn1 com_err krb5 roken sqlite3
+_DP_asn1= com_err roken
+_DP_kdc= roken hdb hx509 krb5 heimntlm asn1 crypto
+_DP_wind= com_err roken
+_DP_heimbase= pthread
+_DP_heimipcc= heimbase roken pthread
+_DP_heimipcs= heimbase roken pthread
+_DP_kafs5= asn1 krb5 roken
+_DP_krb5+= asn1 com_err crypt crypto hx509 roken wind heimbase heimipcc
_DP_gssapi_krb5+= gssapi krb5 crypto roken asn1 com_err
_DP_lzma= pthread
_DP_ucl= m
_DP_vmmapi= util
_DP_ctf= z
-_DP_proc= rtld_db util
-_DP_dtrace= rtld_db pthread
-
-# Define spacial cases
+_DP_dtrace= ctf elf proc pthread rtld_db
+_DP_xo= util
+# The libc dependencies are not strictly needed but are defined to make the
+# assert happy.
+_DP_c= compiler_rt
+.if ${MK_SSP} != "no"
+_DP_c+= ssp_nonshared
+.endif
+_DP_stdthreads= pthread
+_DP_tacplus= md
+_DP_panel= ncurses
+_DP_panelw= ncursesw
+_DP_rpcsec_gss= gssapi
+_DP_smb= kiconv
+_DP_ulog= md
+_DP_fifolog= z
+_DP_ipf= kvm
+_DP_zfs= md pthread umem util uutil m nvpair avl bsdxml geom nvpair z \
+ zfs_core
+_DP_zfs_core= nvpair
+_DP_zpool= md pthread z nvpair avl umem
+
+# Define special cases
LDADD_supcplusplus= -lsupc++
LIBATF_C= ${DESTDIR}${LIBDIR}/libprivateatf-c.a
LIBATF_CXX= ${DESTDIR}${LIBDIR}/libprivateatf-c++.a
@@ -261,7 +325,9 @@ LDADD_${_l}?= -lprivate${_l}
.else
LDADD_${_l}?= ${LDADD_${_l}_L} -l${_l}
.endif
-.if defined(_DP_${_l}) && defined(NO_SHARED) && (${NO_SHARED} != "no" && ${NO_SHARED} != "NO")
+# Add in all dependencies for static linkage.
+.if defined(_DP_${_l}) && (${_INTERNALLIBS:M${_l}} || \
+ (defined(NO_SHARED) && (${NO_SHARED} != "no" && ${NO_SHARED} != "NO")))
.for _d in ${_DP_${_l}}
DPADD_${_l}+= ${DPADD_${_d}}
LDADD_${_l}+= ${LDADD_${_d}}
@@ -269,100 +335,198 @@ LDADD_${_l}+= ${LDADD_${_d}}
.endif
.endfor
+# These are special cases where the library is broken and anything that uses
+# it needs to add more dependencies. Broken usually means that it has a
+# cyclic dependency and cannot link its own dependencies. This is bad, please
+# fix the library instead.
+# Unless the library itself is broken then the proper place to define
+# dependencies is _DP_* above.
+
+# libatf-c++ exposes libatf-c abi hence we need to explicit link to atf_c for
+# atf_cxx
DPADD_atf_cxx+= ${DPADD_atf_c}
LDADD_atf_cxx+= ${LDADD_atf_c}
-DPADD_sqlite3+= ${DPADD_pthread}
-LDADD_sqlite3+= ${LDADD_pthread}
-
-DPADD_fifolog+= ${DPADD_z}
-LDADD_fifolog+= ${LDADD_z}
-
-DPADD_ipf+= ${DPADD_kvm}
-LDADD_ipf+= ${LDADD_kvm}
-
-DPADD_mt+= ${DPADD_sbuf}
-LDADD_mt+= ${LDADD_sbuf}
-
-DPADD_dtrace+= ${DPADD_ctf} ${DPADD_elf} ${DPADD_proc}
-LDADD_dtrace+= ${LDADD_ctf} ${LDADD_elf} ${LDADD_proc}
-
-# The following depends on libraries which are using pthread
-DPADD_hdb+= ${DPADD_pthread}
-LDADD_hdb+= ${LDADD_pthread}
-DPADD_kadm5srv+= ${DPADD_pthread}
-LDADD_kadm5srv+= ${LDADD_pthread}
-DPADD_krb5+= ${DPADD_pthread}
-LDADD_krb5+= ${LDADD_pthread}
-DPADD_gssapi_krb5+= ${DPADD_pthread}
-LDADD_gssapi_krb5+= ${LDADD_pthread}
+# Detect LDADD/DPADD that should be LIBADD, before modifying LDADD here.
+_BADLDADD=
+.for _l in ${LDADD:M-l*:N-l*/*:C,^-l,,}
+.if ${_LIBRARIES:M${_l}} && !${_PRIVATELIBS:M${_l}}
+_BADLDADD+= ${_l}
+.endif
+.endfor
+.if !empty(_BADLDADD)
+.error ${.CURDIR}: These libraries should be LIBADD+=foo rather than DPADD/LDADD+=-lfoo: ${_BADLDADD}
+.endif
.for _l in ${LIBADD}
-DPADD+= ${DPADD_${_l}:Umissing-dpadd_${_l}}
+DPADD+= ${DPADD_${_l}}
LDADD+= ${LDADD_${_l}}
.endfor
-.if defined(DPADD) && ${DPADD:Mmissing-dpadd_*}
-.error Missing ${DPADD:Mmissing-dpadd_*:S/missing-dpadd_//:S/^/DPADD_/} variable add "${DPADD:Mmissing-dpadd_*:S/missing-dpadd_//}" to _LIBRARIES, _INTERNALLIBS, or _PRIVATELIBS and define "${DPADD:Mmissing-dpadd_*:S/missing-dpadd_//:S/^/LIB/:tu}".
-.endif
-
-LIBELFTCDIR= ${ROOTOBJDIR}/lib/libelftc
+# INTERNALLIB definitions.
+LIBELFTCDIR= ${OBJTOP}/lib/libelftc
LIBELFTC?= ${LIBELFTCDIR}/libelftc.a
-LIBREADLINEDIR= ${ROOTOBJDIR}/gnu/lib/libreadline/readline
+LIBREADLINEDIR= ${OBJTOP}/gnu/lib/libreadline/readline
LIBREADLINE?= ${LIBREADLINEDIR}/libreadline.a
-LIBOHASHDIR= ${ROOTOBJDIR}/lib/libohash
-LIBOHASH?= ${LIBOHASHDIR}/libohash.a
+LIBOPENBSDDIR= ${OBJTOP}/lib/libopenbsd
+LIBOPENBSD?= ${LIBOPENBSDDIR}/libopenbsd.a
-LIBSMDIR= ${ROOTOBJDIR}/lib/libsm
+LIBSMDIR= ${OBJTOP}/lib/libsm
LIBSM?= ${LIBSMDIR}/libsm.a
-LIBSMDBDIR= ${ROOTOBJDIR}/lib/libsmdb
+LIBSMDBDIR= ${OBJTOP}/lib/libsmdb
LIBSMDB?= ${LIBSMDBDIR}/libsmdb.a
-LIBSMUTILDIR= ${ROOTOBJDIR}/lib/libsmutil
+LIBSMUTILDIR= ${OBJTOP}/lib/libsmutil
LIBSMUTIL?= ${LIBSMDBDIR}/libsmutil.a
-LIBNETBSDDIR?= ${ROOTOBJDIR}/lib/libnetbsd
+LIBNETBSDDIR?= ${OBJTOP}/lib/libnetbsd
LIBNETBSD?= ${LIBNETBSDDIR}/libnetbsd.a
-LIBVERSDIR?= ${ROOTOBJDIR}/kerberos5/lib/libvers
+LIBVERSDIR?= ${OBJTOP}/kerberos5/lib/libvers
LIBVERS?= ${LIBVERSDIR}/libvers.a
-LIBSLDIR= ${ROOTOBJDIR}/kerberos5/lib/libsl
+LIBSLDIR= ${OBJTOP}/kerberos5/lib/libsl
LIBSL?= ${LIBSLDIR}/libsl.a
-LIBIPFDIR= ${ROOTOBJDIR}/sbin/ipf/libipf
+LIBIPFDIR= ${OBJTOP}/sbin/ipf/libipf
LIBIPF?= ${LIBIPFDIR}/libipf.a
-LIBTELNETDIR= ${ROOTOBJDIR}/lib/libtelnet
+LIBTELNETDIR= ${OBJTOP}/lib/libtelnet
LIBTELNET?= ${LIBTELNETDIR}/libtelnet.a
-LIBCRONDIR= ${ROOTOBJDIR}/usr.sbin/cron/lib
+LIBCRONDIR= ${OBJTOP}/usr.sbin/cron/lib
LIBCRON?= ${LIBCRONDIR}/libcron.a
-LIBNTPDIR= ${ROOTOBJDIR}/usr.sbin/ntp/libntp
+LIBNTPDIR= ${OBJTOP}/usr.sbin/ntp/libntp
LIBNTP?= ${LIBNTPDIR}/libntp.a
-LIBNTPEVENTDIR= ${ROOTOBJDIR}/usr.sbin/ntp/libntpevent
+LIBNTPEVENTDIR= ${OBJTOP}/usr.sbin/ntp/libntpevent
LIBNTPEVENT?= ${LIBNTPEVENTDIR}/libntpevent.a
-LIBOPTSDIR= ${ROOTOBJDIR}/usr.sbin/ntp/libopts
-LIBOTPS?= ${LIBOPTSDIR}/libopts.a
+LIBOPTSDIR= ${OBJTOP}/usr.sbin/ntp/libopts
+LIBOPTS?= ${LIBOPTSDIR}/libopts.a
-LIBPARSEDIR= ${ROOTOBJDIR}/usr.sbin/ntp/libparse
+LIBPARSEDIR= ${OBJTOP}/usr.sbin/ntp/libparse
LIBPARSE?= ${LIBPARSEDIR}/libparse.a
-LIBLPRDIR= ${ROOTOBJDIR}/usr.sbin/lpr/common_source
+LIBLPRDIR= ${OBJTOP}/usr.sbin/lpr/common_source
LIBLPR?= ${LIBOPTSDIR}/liblpr.a
-LIBFIFOLOGDIR= ${ROOTOBJDIR}/usr.sbin/fifolog/lib
+LIBFIFOLOGDIR= ${OBJTOP}/usr.sbin/fifolog/lib
LIBFIFOLOG?= ${LIBOPTSDIR}/libfifolog.a
-LIBBSNMPTOOLSDIR= ${ROOTOBJDIR}/usr.sbin/bsnmpd/tools/libbsnmptools
+LIBBSNMPTOOLSDIR= ${OBJTOP}/usr.sbin/bsnmpd/tools/libbsnmptools
LIBBSNMPTOOLS?= ${LIBBSNMPTOOLSDIR}/libbsnmptools.a
-LIBAMUDIR= ${ROOTOBJDIR}/usr.sbin/amd/libamu
+LIBAMUDIR= ${OBJTOP}/usr.sbin/amd/libamu
LIBAMU?= ${LIBAMUDIR}/libamu/libamu.a
+# Define a directory for each library. This is useful for adding -L in when
+# not using a --sysroot or for meta mode bootstrapping when there is no
+# Makefile.depend. These are sorted by directory.
+LIBAVLDIR= ${OBJTOP}/cddl/lib/libavl
+LIBCTFDIR= ${OBJTOP}/cddl/lib/libctf
+LIBDTRACEDIR= ${OBJTOP}/cddl/lib/libdtrace
+LIBNVPAIRDIR= ${OBJTOP}/cddl/lib/libnvpair
+LIBUMEMDIR= ${OBJTOP}/cddl/lib/libumem
+LIBUUTILDIR= ${OBJTOP}/cddl/lib/libuutil
+LIBZFSDIR= ${OBJTOP}/cddl/lib/libzfs
+LIBZFS_COREDIR= ${OBJTOP}/cddl/lib/libzfs_core
+LIBZPOOLDIR= ${OBJTOP}/cddl/lib/libzpool
+LIBCXGB4DIR= ${OBJTOP}/contrib/ofed/usr.lib/libcxgb4
+LIBIBCMDIR= ${OBJTOP}/contrib/ofed/usr.lib/libibcm
+LIBIBCOMMONDIR= ${OBJTOP}/contrib/ofed/usr.lib/libibcommon
+LIBIBMADDIR= ${OBJTOP}/contrib/ofed/usr.lib/libibmad
+LIBIBUMADDIR= ${OBJTOP}/contrib/ofed/usr.lib/libibumad
+LIBIBVERBSDIR= ${OBJTOP}/contrib/ofed/usr.lib/libibverbs
+LIBMLX4DIR= ${OBJTOP}/contrib/ofed/usr.lib/libmlx4
+LIBMTHCADIR= ${OBJTOP}/contrib/ofed/usr.lib/libmthca
+LIBOPENSMDIR= ${OBJTOP}/contrib/ofed/usr.lib/libopensm
+LIBOSMCOMPDIR= ${OBJTOP}/contrib/ofed/usr.lib/libosmcomp
+LIBOSMVENDORDIR= ${OBJTOP}/contrib/ofed/usr.lib/libosmvendor
+LIBRDMACMDIR= ${OBJTOP}/contrib/ofed/usr.lib/librdmacm
+LIBIBSDPDIR= ${OBJTOP}/contrib/ofed/usr.lib/libsdp
+LIBDIALOGDIR= ${OBJTOP}/gnu/lib/libdialog
+LIBGCOVDIR= ${OBJTOP}/gnu/lib/libgcov
+LIBGOMPDIR= ${OBJTOP}/gnu/lib/libgomp
+LIBGNUREGEXDIR= ${OBJTOP}/gnu/lib/libregex
+LIBSSPDIR= ${OBJTOP}/gnu/lib/libssp
+LIBSSP_NONSHAREDDIR= ${OBJTOP}/gnu/lib/libssp/libssp_nonshared
+LIBSUPCPLUSPLUSDIR= ${OBJTOP}/gnu/lib/libsupc++
+LIBASN1DIR= ${OBJTOP}/kerberos5/lib/libasn1
+LIBGSSAPI_KRB5DIR= ${OBJTOP}/kerberos5/lib/libgssapi_krb5
+LIBGSSAPI_NTLMDIR= ${OBJTOP}/kerberos5/lib/libgssapi_ntlm
+LIBGSSAPI_SPNEGODIR= ${OBJTOP}/kerberos5/lib/libgssapi_spnego
+LIBHDBDIR= ${OBJTOP}/kerberos5/lib/libhdb
+LIBHEIMBASEDIR= ${OBJTOP}/kerberos5/lib/libheimbase
+LIBHEIMIPCCDIR= ${OBJTOP}/kerberos5/lib/libheimipcc
+LIBHEIMIPCSDIR= ${OBJTOP}/kerberos5/lib/libheimipcs
+LIBHEIMNTLMDIR= ${OBJTOP}/kerberos5/lib/libheimntlm
+LIBHX509DIR= ${OBJTOP}/kerberos5/lib/libhx509
+LIBKADM5CLNTDIR= ${OBJTOP}/kerberos5/lib/libkadm5clnt
+LIBKADM5SRVDIR= ${OBJTOP}/kerberos5/lib/libkadm5srv
+LIBKAFS5DIR= ${OBJTOP}/kerberos5/lib/libkafs5
+LIBKDCDIR= ${OBJTOP}/kerberos5/lib/libkdc
+LIBKRB5DIR= ${OBJTOP}/kerberos5/lib/libkrb5
+LIBROKENDIR= ${OBJTOP}/kerberos5/lib/libroken
+LIBWINDDIR= ${OBJTOP}/kerberos5/lib/libwind
+LIBALIASDIR= ${OBJTOP}/lib/libalias/libalias
+LIBBLOCKSRUNTIMEDIR= ${OBJTOP}/lib/libblocksruntime
+LIBBSNMPDIR= ${OBJTOP}/lib/libbsnmp/libbsnmp
+LIBBSDXMLDIR= ${OBJTOP}/lib/libexpat
+LIBKVMDIR= ${OBJTOP}/lib/libkvm
+LIBPTHREADDIR= ${OBJTOP}/lib/libthr
+LIBMDIR= ${OBJTOP}/lib/msun
+LIBFORMDIR= ${OBJTOP}/lib/ncurses/form
+LIBFORMLIBWDIR= ${OBJTOP}/lib/ncurses/formw
+LIBMENUDIR= ${OBJTOP}/lib/ncurses/menu
+LIBMENULIBWDIR= ${OBJTOP}/lib/ncurses/menuw
+LIBNCURSESDIR= ${OBJTOP}/lib/ncurses/ncurses
+LIBNCURSESWDIR= ${OBJTOP}/lib/ncurses/ncursesw
+LIBPANELDIR= ${OBJTOP}/lib/ncurses/panel
+LIBPANELWDIR= ${OBJTOP}/lib/ncurses/panelw
+LIBCRYPTODIR= ${OBJTOP}/secure/lib/libcrypto
+LIBSSHDIR= ${OBJTOP}/secure/lib/libssh
+LIBSSLDIR= ${OBJTOP}/secure/lib/libssl
+LIBTEKENDIR= ${OBJTOP}/sys/teken/libteken
+LIBEGACYDIR= ${OBJTOP}/tools/build
+LIBLNDIR= ${OBJTOP}/usr.bin/lex/lib
+
+LIBTERMCAPDIR= ${LIBNCURSESDIR}
+LIBTERMCAPWDIR= ${LIBNCURSESWDIR}
+
+# Default other library directories to lib/libNAME.
+.for lib in ${_LIBRARIES}
+LIB${lib:tu}DIR?= ${OBJTOP}/lib/lib${lib}
+.endfor
+
+# Validate that listed LIBADD are valid.
+.for _l in ${LIBADD}
+.if empty(_LIBRARIES:M${_l})
+_BADLIBADD+= ${_l}
+.endif
+.endfor
+.if !empty(_BADLIBADD)
+.error ${.CURDIR}: Invalid LIBADD used which may need to be added to ${_this:T}: ${_BADLIBADD}
+.endif
+
+# Sanity check that libraries are defined here properly when building them.
+.if defined(LIB) && ${_LIBRARIES:M${LIB}} != ""
+.if !empty(LIBADD) && \
+ (!defined(_DP_${LIB}) || ${LIBADD:O:u} != ${_DP_${LIB}:O:u})
+.error ${.CURDIR}: Missing or incorrect _DP_${LIB} entry in ${_this:T}. Should match LIBADD for ${LIB} ('${LIBADD}' vs '${_DP_${LIB}}')
+.endif
+# Note that OBJTOP is not yet defined here but for the purpose of the check
+# it is fine as it resolves to the SRC directory.
+.if !defined(LIB${LIB:tu}DIR) || !exists(${SRCTOP}/${LIB${LIB:tu}DIR:S,^${OBJTOP}/,,})
+.error ${.CURDIR}: Missing or incorrect value for LIB${LIB:tu}DIR in ${_this:T}: ${LIB${LIB:tu}DIR:S,^${OBJTOP}/,,}
+.endif
+.if ${_INTERNALLIBS:M${LIB}} != "" && !defined(LIB${LIB:tu})
+.error ${.CURDIR}: Missing value for LIB${LIB:tu} in ${_this:T}. Likely should be: LIB${LIB:tu}?= $${LIB${LIB:tu}DIR}/lib${LIB}.a
+.endif
+.endif
+
+.endif # !target(__<src.libnames.mk>__)