bsd.own.mk revision 322100
1# $FreeBSD: stable/10/share/mk/bsd.own.mk 322100 2017-08-05 16:55:07Z ngie $
2#
3# The include file <bsd.own.mk> set common variables for owner,
4# group, mode, and directories. Defaults are in brackets.
5#
6#
7# +++ variables +++
8#
9# DESTDIR	Change the tree where the file gets installed. [not set]
10#
11# DISTDIR	Change the tree where the file for a distribution
12# 		gets installed (see /usr/src/release/Makefile). [not set]
13#
14# COMPRESS_CMD	Program to compress documents.
15#		Output is to stdout. [gzip -cn]
16#
17# COMPRESS_EXT	File name extension of ${COMPRESS_CMD} command. [.gz]
18#
19# BINOWN	Binary owner. [root]
20#
21# BINGRP	Binary group. [wheel]
22#
23# BINMODE	Binary mode. [555]
24#
25# NOBINMODE	Mode for non-executable files. [444]
26#
27# LIBDIR	Base path for libraries. [/usr/lib]
28#
29# LIBCOMPATDIR	Base path for compat libraries. [/usr/lib/compat]
30#
31# LIBPRIVATEDIR	Base path for private libraries. [/usr/lib/private]
32#
33# LIBDATADIR	Base path for misc. utility data files. [/usr/libdata]
34#
35# LIBEXECDIR	Base path for system daemons and utilities. [/usr/libexec]
36#
37# LINTLIBDIR	Base path for lint libraries. [/usr/libdata/lint]
38#
39# SHLIBDIR	Base path for shared libraries. [${LIBDIR}]
40#
41# LIBOWN	Library owner. [${BINOWN}]
42#
43# LIBGRP	Library group. [${BINGRP}]
44#
45# LIBMODE	Library mode. [${NOBINMODE}]
46#
47#
48# DEBUGDIR	Base path for standalone debug files. [/usr/lib/debug]
49#
50# DEBUGMODE	Mode for debug files. [${NOBINMODE}]
51#
52#
53# KMODDIR	Base path for loadable kernel modules
54#		(see kld(4)). [/boot/kernel]
55#
56# KMODOWN	Kernel and KLD owner. [${BINOWN}]
57#
58# KMODGRP	Kernel and KLD group. [${BINGRP}]
59#
60# KMODMODE	KLD mode. [${BINMODE}]
61#
62#
63# SHAREDIR	Base path for architecture-independent ascii
64#		text files. [/usr/share]
65#
66# SHAREOWN	ASCII text file owner. [root]
67#
68# SHAREGRP	ASCII text file group. [wheel]
69#
70# SHAREMODE	ASCII text file mode. [${NOBINMODE}]
71#
72#
73# CONFDIR	Base path for configuration files. [/etc]
74#
75# CONFOWN	Configuration file owner. [root]
76#
77# CONFGRP	Configuration file group. [wheel]
78#
79# CONFMODE	Configuration file mode. [644]
80#
81#
82# DOCDIR	Base path for system documentation (e.g. PSD, USD,
83#		handbook, FAQ etc.). [${SHAREDIR}/doc]
84#
85# DOCOWN	Documentation owner. [${SHAREOWN}]
86#
87# DOCGRP	Documentation group. [${SHAREGRP}]
88#
89# DOCMODE	Documentation mode. [${NOBINMODE}]
90#
91#
92# INFODIR	Base path for GNU's hypertext system
93#		called Info (see info(1)). [${SHAREDIR}/info]
94#
95# INFOOWN	Info owner. [${SHAREOWN}]
96#
97# INFOGRP	Info group. [${SHAREGRP}]
98#
99# INFOMODE	Info mode. [${NOBINMODE}]
100#
101#
102# MANDIR	Base path for manual installation. [${SHAREDIR}/man/man]
103#
104# MANOWN	Manual owner. [${SHAREOWN}]
105#
106# MANGRP	Manual group. [${SHAREGRP}]
107#
108# MANMODE	Manual mode. [${NOBINMODE}]
109#
110#
111# NLSDIR	Base path for National Language Support files
112#		installation. [${SHAREDIR}/nls]
113#
114# NLSOWN	National Language Support files owner. [${SHAREOWN}]
115#
116# NLSGRP	National Language Support files group. [${SHAREGRP}]
117#
118# NLSMODE	National Language Support files mode. [${NOBINMODE}]
119#
120# INCLUDEDIR	Base path for standard C include files [/usr/include]
121
122.if !target(__<bsd.own.mk>__)
123__<bsd.own.mk>__:
124
125.if !defined(_WITHOUT_SRCCONF)
126SRCCONF?=	/etc/src.conf
127.if exists(${SRCCONF}) || ${SRCCONF} != "/etc/src.conf"
128.include "${SRCCONF}"
129.endif
130.endif
131
132# Binaries
133BINOWN?=	root
134BINGRP?=	wheel
135BINMODE?=	555
136NOBINMODE?=	444
137
138.if defined(MODULES_WITH_WORLD)
139KMODDIR?=	/boot/modules
140.else
141KMODDIR?=	/boot/kernel
142.endif
143KMODOWN?=	${BINOWN}
144KMODGRP?=	${BINGRP}
145KMODMODE?=	${BINMODE}
146DTBDIR?=	/boot/dtb
147DTBOWN?=	root
148DTBGRP?=	wheel
149DTBMODE?=	444
150
151LIBDIR?=	/usr/lib
152LIBCOMPATDIR?=	/usr/lib/compat
153LIBPRIVATEDIR?=	/usr/lib/private
154LIBDATADIR?=	/usr/libdata
155LIBEXECDIR?=	/usr/libexec
156LINTLIBDIR?=	/usr/libdata/lint
157SHLIBDIR?=	${LIBDIR}
158LIBOWN?=	${BINOWN}
159LIBGRP?=	${BINGRP}
160LIBMODE?=	${NOBINMODE}
161
162DEBUGDIR?=	/usr/lib/debug
163DEBUGMODE?=	${NOBINMODE}
164
165
166# Share files
167SHAREDIR?=	/usr/share
168SHAREOWN?=	root
169SHAREGRP?=	wheel
170SHAREMODE?=	${NOBINMODE}
171
172CONFDIR?=	/etc
173CONFOWN?=	root
174CONFGRP?=	wheel
175CONFMODE?=	644
176
177MANDIR?=	${SHAREDIR}/man/man
178MANOWN?=	${SHAREOWN}
179MANGRP?=	${SHAREGRP}
180MANMODE?=	${NOBINMODE}
181
182DOCDIR?=	${SHAREDIR}/doc
183DOCOWN?=	${SHAREOWN}
184DOCGRP?=	${SHAREGRP}
185DOCMODE?=	${NOBINMODE}
186
187INFODIR?=	${SHAREDIR}/info
188INFOOWN?=	${SHAREOWN}
189INFOGRP?=	${SHAREGRP}
190INFOMODE?=	${NOBINMODE}
191
192NLSDIR?=	${SHAREDIR}/nls
193NLSOWN?=	${SHAREOWN}
194NLSGRP?=	${SHAREGRP}
195NLSMODE?=	${NOBINMODE}
196
197INCLUDEDIR?=	/usr/include
198
199#
200# install(1) parameters.
201#
202HRDLINK?=	-l h
203SYMLINK?=	-l s
204
205INSTALL_LINK?=		${INSTALL} ${HRDLINK}
206INSTALL_SYMLINK?=	${INSTALL} ${SYMLINK}
207
208# Common variables
209.if !defined(DEBUG_FLAGS)
210STRIP?=		-s
211.endif
212
213COMPRESS_CMD?=	gzip -cn
214COMPRESS_EXT?=	.gz
215
216# Set XZ_THREADS to 1 to disable multi-threading.
217XZ_THREADS?=	0
218
219.if !empty(XZ_THREADS)
220XZ_CMD?=	xz -T ${XZ_THREADS}
221.else
222XZ_CMD?=	xz
223.endif
224
225.if !defined(_WITHOUT_SRCCONF)
226#
227# Define MK_* variables (which are either "yes" or "no") for users
228# to set via WITH_*/WITHOUT_* in /etc/src.conf and override in the
229# make(1) environment.
230# These should be tested with `== "no"' or `!= "no"' in makefiles.
231# The NO_* variables should only be set by makefiles.
232#
233
234#
235# Supported NO_* options (if defined, MK_* will be forced to "no",
236# regardless of user's setting).
237#
238.for var in \
239    CTF \
240    DEBUG_FILES \
241    INSTALLLIB \
242    MAN \
243    PROFILE
244.if defined(NO_${var})
245.if defined(WITH_${var})
246.undef WITH_${var}
247.endif
248WITHOUT_${var}=
249.endif
250.endfor
251
252#
253# Older-style variables that enabled behaviour when set.
254#
255.if defined(YES_HESIOD)
256WITH_HESIOD=
257.endif
258
259__DEFAULT_YES_OPTIONS = \
260    ACCT \
261    ACPI \
262    AMD \
263    APM \
264    ARM_EABI \
265    ASSERT_DEBUG \
266    AT \
267    ATM \
268    AUDIT \
269    AUTHPF \
270    AUTOFS \
271    BHYVE \
272    BINUTILS \
273    BLUETOOTH \
274    BMAKE \
275    BOOT \
276    BOOTPARAMD \
277    BOOTPD \
278    BSD_CPIO \
279    BSDINSTALL \
280    BSNMP \
281    BZIP2 \
282    CALENDAR \
283    CAPSICUM \
284    CCD \
285    CDDL \
286    CPP \
287    CROSS_COMPILER \
288    CRYPT \
289    CTM \
290    CXX \
291    DIALOG \
292    DICT \
293    DYNAMICROOT \
294    ED_CRYPTO \
295    EE \
296    EXAMPLES \
297    FILE \
298    FINGER \
299    FLOPPY \
300    FMTREE \
301    FORMAT_EXTENSIONS \
302    FORTH \
303    FP_LIBC \
304    FREEBSD_UPDATE \
305    FTP \
306    GAMES \
307    GCOV \
308    GDB \
309    GNU \
310    GPIB \
311    GPIO \
312    GPL_DTC \
313    GROFF \
314    HAST \
315    HTML \
316    ICONV \
317    INET \
318    INET6 \
319    INETD \
320    INFO \
321    INSTALLLIB \
322    IPFILTER \
323    IPFW \
324    IPX \
325    ISCSI \
326    JAIL \
327    KDUMP \
328    KERBEROS \
329    KERNEL_SYMBOLS \
330    KVM \
331    LDNS \
332    LDNS_UTILS \
333    LEGACY_CONSOLE \
334    LIB32 \
335    LIBPTHREAD \
336    LIBTHR \
337    LOCALES \
338    LOCATE \
339    LPR \
340    LS_COLORS \
341    MAIL \
342    MAILWRAPPER \
343    MAKE \
344    MAN \
345    NCURSESW \
346    NDIS \
347    NETCAT \
348    NETGRAPH \
349    NIS \
350    NLS \
351    NLS_CATALOGS \
352    NMTREE \
353    NS_CACHING \
354    NTP \
355    OPENSSH \
356    OPENSSL \
357    PAM \
358    PC_SYSINSTALL \
359    PF \
360    PKGBOOTSTRAP \
361    PMC \
362    PORTSNAP \
363    PPP \
364    PROFILE \
365    QUOTAS \
366    RADIUS_SUPPORT \
367    RBOOTD \
368    RCMDS \
369    RCS \
370    RESCUE \
371    ROUTED \
372    SENDMAIL \
373    SETUID_LOGIN \
374    SHAREDOCS \
375    SOURCELESS \
376    SOURCELESS_HOST \
377    SOURCELESS_UCODE \
378    SSP \
379    SVNLITE \
380    SYMVER \
381    SYSCONS \
382    TALK \
383    TCSH \
384    TCP_WRAPPERS \
385    TELNET \
386    TEXTPROC \
387    TFTP \
388    TIMED \
389    TOOLCHAIN \
390    UNBOUND \
391    USB \
392    UTMPX \
393    VT \
394    WIRELESS \
395    WPA_SUPPLICANT_EAPOL \
396    ZFS \
397    ZONEINFO
398
399__DEFAULT_NO_OPTIONS = \
400    BSD_GREP \
401    CLANG_EXTRAS \
402    CTF \
403    DEBUG_FILES \
404    HESIOD \
405    INSTALL_AS_USER \
406    LLDB \
407    NAND \
408    OFED \
409    PKGTOOLS \
410    RPCBIND_WARMSTART_SUPPORT \
411    SHARED_TOOLCHAIN \
412    SVN \
413    TESTS \
414    USB_GADGET_EXAMPLES \
415    ZONEINFO_LEAPSECONDS_SUPPORT \
416    ZONEINFO_OLD_TIMEZONES_SUPPORT \
417
418
419#
420# Default behaviour of some options depends on the architecture.  Unfortunately
421# this means that we have to test TARGET_ARCH (the buildworld case) as well
422# as MACHINE_ARCH (the non-buildworld case).  Normally TARGET_ARCH is not
423# used at all in bsd.*.mk, but we have to make an exception here if we want
424# to allow defaults for some things like clang and fdt to vary by target
425# architecture.
426#
427.if defined(TARGET_ARCH)
428__T=${TARGET_ARCH}
429.else
430__T=${MACHINE_ARCH}
431.endif
432.if defined(TARGET)
433__TT=${TARGET}
434.else
435__TT=${MACHINE}
436.endif
437# Clang is only for x86, powerpc and little-endian arm right now, by default.
438.if ${__T} == "amd64" || ${__T} == "i386" || ${__T:Mpowerpc*}
439__DEFAULT_YES_OPTIONS+=CLANG CLANG_FULL
440.elif ${__T} == "arm" || ${__T} == "armv6"
441__DEFAULT_YES_OPTIONS+=CLANG
442# GCC is unable to build the full clang on arm, disable it by default.
443__DEFAULT_NO_OPTIONS+=CLANG_FULL
444.else
445__DEFAULT_NO_OPTIONS+=CLANG CLANG_FULL
446.endif
447# Clang the default system compiler only on little-endian arm and x86.
448.if ${__T} == "amd64" || ${__T} == "arm" || ${__T} == "armv6" || \
449    ${__T} == "i386"
450__DEFAULT_YES_OPTIONS+=CLANG_IS_CC
451# The pc98 bootloader requires gcc to build and so we must leave gcc enabled
452# for pc98 for now.
453.if ${__TT} == "pc98"
454__DEFAULT_NO_OPTIONS+=GNUCXX
455__DEFAULT_YES_OPTIONS+=GCC
456.else
457__DEFAULT_NO_OPTIONS+=GCC GNUCXX
458.endif
459.else
460# If clang is not cc, then build gcc by default
461__DEFAULT_NO_OPTIONS+=CLANG_IS_CC
462__DEFAULT_YES_OPTIONS+=GCC
463# And if g++ is c++, build the rest of the GNU C++ stack
464.if defined(WITHOUT_CXX)
465__DEFAULT_NO_OPTIONS+=GNUCXX
466.else
467__DEFAULT_YES_OPTIONS+=GNUCXX
468.endif
469.endif
470.if ${__T} == "amd64" || ${__T} == "i386" || \
471    ${__T} == "powerpc64" || ${__T} == "sparc64"
472__DEFAULT_YES_OPTIONS+=CXGBETOOL
473.else
474__DEFAULT_NO_OPTIONS+=CXGBETOOL
475.endif
476# FDT is needed only for arm, mips and powerpc
477.if ${__T:Marm*} || ${__T:Mpowerpc*} || ${__T:Mmips*}
478__DEFAULT_YES_OPTIONS+=FDT
479.else
480__DEFAULT_NO_OPTIONS+=FDT
481.endif
482# HyperV is only available for x86 and amd64.
483.if ${__T} == "amd64" || ${__T} == "i386"
484__DEFAULT_YES_OPTIONS+=HYPERV
485.else
486__DEFAULT_NO_OPTIONS+=HYPERV
487.endif
488.undef __T
489
490#
491# MK_* options which default to "yes".
492#
493.for var in ${__DEFAULT_YES_OPTIONS}
494.if !defined(MK_${var})
495.if defined(WITH_${var}) && defined(WITHOUT_${var})
496.error WITH_${var} and WITHOUT_${var} can't both be set.
497.endif
498.if defined(WITHOUT_${var})
499MK_${var}:=	no
500.else
501MK_${var}:=	yes
502.endif
503.endif	# !defined(MK_${var})
504.endfor
505.undef __DEFAULT_YES_OPTIONS
506
507#
508# MK_* options which default to "no".
509#
510.for var in ${__DEFAULT_NO_OPTIONS}
511.if !defined(MK_${var})
512.if defined(WITH_${var}) && defined(WITHOUT_${var})
513.error WITH_${var} and WITHOUT_${var} can't both be set.
514.endif
515.if defined(WITH_${var})
516MK_${var}:=	yes
517.else
518MK_${var}:=	no
519.endif
520.endif	# !defined(MK_${var})
521.endfor
522.undef __DEFAULT_NO_OPTIONS
523
524#
525# Force some options off if their dependencies are off.
526# Order is somewhat important.
527#
528.if ${MK_LIBPTHREAD} == "no"
529MK_LIBTHR:=	no
530.endif
531
532.if ${MK_LDNS} == "no"
533MK_LDNS_UTILS:=	no
534MK_UNBOUND:= no
535.endif
536
537.if ${MK_SOURCELESS} == "no"
538MK_SOURCELESS_HOST:=	no
539MK_SOURCELESS_UCODE:= no
540.endif
541
542.if ${MK_CDDL} == "no"
543MK_ZFS:=	no
544MK_CTF:=	no
545.endif
546
547.if ${MK_CRYPT} == "no"
548MK_OPENSSL:=	no
549MK_OPENSSH:=	no
550MK_KERBEROS:=	no
551.endif
552
553.if ${MK_CXX} == "no"
554MK_CLANG:=	no
555MK_GROFF:=	no
556.endif
557
558.if ${MK_DIALOG} == "no"
559MK_BSDINSTALL:=	no
560.endif
561
562.if ${MK_MAIL} == "no"
563MK_MAILWRAPPER:= no
564MK_SENDMAIL:=	no
565.endif
566
567.if ${MK_NETGRAPH} == "no"
568MK_ATM:=	no
569MK_BLUETOOTH:=	no
570.endif
571
572.if ${MK_OPENSSL} == "no"
573MK_OPENSSH:=	no
574MK_KERBEROS:=	no
575.endif
576
577.if ${MK_PF} == "no"
578MK_AUTHPF:=	no
579.endif
580
581.if ${MK_TEXTPROC} == "no"
582MK_GROFF:=	no
583.endif
584
585.if ${MK_TOOLCHAIN} == "no"
586MK_BINUTILS:=	no
587MK_CLANG:=	no
588MK_GCC:=	no
589MK_GDB:=	no
590.endif
591
592.if ${MK_ZONEINFO} == "no"
593MK_ZONEINFO_LEAPSECONDS_SUPPORT:= no
594MK_ZONEINFO_OLD_TIMEZONES_SUPPORT:= no
595.endif
596
597.if ${MK_CLANG} == "no"
598MK_CLANG_EXTRAS:= no
599MK_CLANG_FULL:= no
600.endif
601
602.if ${MK_CLANG_IS_CC} == "no"
603MK_LLDB:= no
604.endif
605
606.if defined(NO_TESTS)
607# This should be handled above along the handling of all other NO_*  options.
608# However, the above is broken when WITH_*=yes are passed to make(1) as
609# command line arguments.  See PR bin/183762.
610#
611# Because the TESTS option is new and it will default to yes, it's likely
612# that people will pass WITHOUT_TESTS=yes to make(1) directly and get a broken
613# build.  So, just in case, it's better to explicitly handle this case here.
614#
615# TODO(jmmv): Either fix make to allow us putting this override where it
616# belongs above or fix this file to cope with the make bug.
617MK_TESTS:= no
618.endif
619
620#
621# Set defaults for the MK_*_SUPPORT variables.
622#
623
624#
625# MK_* options whose default value depends on another option.
626#
627.for vv in \
628    GSSAPI/KERBEROS \
629    MAN_UTILS/MAN
630.if defined(WITH_${vv:H}) && defined(WITHOUT_${vv:H})
631.error WITH_${vv:H} and WITHOUT_${vv:H} can't both be set.
632.endif
633.if defined(WITH_${vv:H})
634MK_${vv:H}:=	yes
635.elif defined(WITHOUT_${vv:H})
636MK_${vv:H}:=	no
637.else
638MK_${vv:H}:=	${MK_${vv:T}}
639.endif
640.endfor
641
642#
643# MK_*_SUPPORT options which default to "yes" unless their corresponding
644# MK_* variable is set to "no".
645#
646.for var in \
647    BZIP2 \
648    GNU \
649    INET \
650    INET6 \
651    IPX \
652    KERBEROS \
653    KVM \
654    NETGRAPH \
655    PAM \
656    WIRELESS
657.if defined(WITH_${var}_SUPPORT) && defined(WITHOUT_${var}_SUPPORT)
658.error WITH_${var}_SUPPORT and WITHOUT_${var}_SUPPORT can't both be set.
659.endif
660.if defined(WITHOUT_${var}_SUPPORT) || ${MK_${var}} == "no"
661MK_${var}_SUPPORT:= no
662.else
663MK_${var}_SUPPORT:= yes
664.endif
665.endfor
666
667#
668# MK_* options that default to "yes" if the compiler is a C++11 compiler.
669#
670.include <bsd.compiler.mk>
671.for var in \
672    LIBCPLUSPLUS
673.if defined(WITH_${var}) && defined(WITHOUT_${var})
674.error WITH_${var} and WITHOUT_${var} can't both be set.
675.endif
676.if ${COMPILER_FEATURES:Mc++11}
677.if defined(WITHOUT_${var})
678MK_${var}:=	no
679.else
680MK_${var}:=	yes
681.endif
682.else
683.if defined(WITH_${var})
684MK_${var}:=	yes
685.else
686MK_${var}:=	no
687.endif
688.endif
689.endfor
690
691.if ${MK_CTF} != "no"
692CTFCONVERT_CMD=	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
693.elif defined(.PARSEDIR) || (defined(MAKE_VERSION) && ${MAKE_VERSION} >= 5201111300)
694CTFCONVERT_CMD=
695.else
696CTFCONVERT_CMD=	@:
697.endif 
698
699.if ${MK_INSTALL_AS_USER} != "no"
700_uid!=	id -u
701.if ${_uid} != 0
702.if !defined(USER)
703USER!=	id -un
704.endif
705_gid!=	id -gn
706.for x in BIN CONF DOC DTB INFO KMOD LIB MAN NLS SHARE
707$xOWN=	${USER}
708$xGRP=	${_gid}
709.endfor
710.endif
711.endif
712
713.endif # !_WITHOUT_SRCCONF
714
715# Pointer to the top directory into which tests are installed.  Should not be
716# overriden by Makefiles, but the user may choose to set this in src.conf(5).
717TESTSBASE?= /usr/tests
718
719.endif	# !target(__<bsd.own.mk>__)
720