]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - share/mk/src.opts.mk
Update svn-1.9.7 to 1.10.0.
[FreeBSD/FreeBSD.git] / share / mk / src.opts.mk
1 # $FreeBSD$
2 #
3 # Option file for FreeBSD /usr/src builds.
4 #
5 # Users define WITH_FOO and WITHOUT_FOO on the command line or in /etc/src.conf
6 # and /etc/make.conf files. These translate in the build system to MK_FOO={yes,no}
7 # with sensible (usually) defaults.
8 #
9 # Makefiles must include bsd.opts.mk after defining specific MK_FOO options that
10 # are applicable for that Makefile (typically there are none, but sometimes there
11 # are exceptions). Recursive makes usually add MK_FOO=no for options that they wish
12 # to omit from that make.
13 #
14 # Makefiles must include bsd.mkopt.mk before they test the value of any MK_FOO
15 # variable.
16 #
17 # Makefiles may also assume that this file is included by src.opts.mk should it
18 # need variables defined there prior to the end of the Makefile where
19 # bsd.{subdir,lib.bin}.mk is traditionally included.
20 #
21 # The old-style YES_FOO and NO_FOO are being phased out. No new instances of them
22 # should be added. Old instances should be removed since they were just to
23 # bridge the gap between FreeBSD 4 and FreeBSD 5.
24 #
25 # Makefiles should never test WITH_FOO or WITHOUT_FOO directly (although an
26 # exception is made for _WITHOUT_SRCONF which turns off this mechanism
27 # completely inside bsd.*.mk files).
28 #
29
30 .if !target(__<src.opts.mk>__)
31 __<src.opts.mk>__:
32
33 .include <bsd.own.mk>
34
35 #
36 # Define MK_* variables (which are either "yes" or "no") for users
37 # to set via WITH_*/WITHOUT_* in /etc/src.conf and override in the
38 # make(1) environment.
39 # These should be tested with `== "no"' or `!= "no"' in makefiles.
40 # The NO_* variables should only be set by makefiles for variables
41 # that haven't been converted over.
42 #
43
44 # These options are used by the src builds. Those listed in
45 # __DEFAULT_YES_OPTIONS default to 'yes' and will build unless turned
46 # off.  __DEFAULT_NO_OPTIONS will default to 'no' and won't build
47 # unless turned on. Any options listed in 'BROKEN_OPTIONS' will be
48 # hard-wired to 'no'.  "Broken" here means not working or
49 # not-appropriate and/or not supported. It doesn't imply something is
50 # wrong with the code. There's not a single good word for this, so
51 # BROKEN was selected as the least imperfect one considered at the
52 # time. Options are added to BROKEN_OPTIONS list on a per-arch basis.
53 # At this time, there's no provision for mutually incompatible options.
54
55 __DEFAULT_YES_OPTIONS = \
56     ACCT \
57     ACPI \
58     AMD \
59     APM \
60     AT \
61     ATM \
62     AUDIT \
63     AUTHPF \
64     AUTOFS \
65     BHYVE \
66     BINUTILS \
67     BINUTILS_BOOTSTRAP \
68     BLACKLIST \
69     BLUETOOTH \
70     BOOT \
71     BOOTPARAMD \
72     BOOTPD \
73     BSD_CPIO \
74     BSDINSTALL \
75     BSNMP \
76     BZIP2 \
77     CALENDAR \
78     CAPSICUM \
79     CASPER \
80     CCD \
81     CDDL \
82     CPP \
83     CROSS_COMPILER \
84     CRYPT \
85     CTM \
86     CUSE \
87     CXX \
88     DIALOG \
89     DICT \
90     DMAGENT \
91     DYNAMICROOT \
92     ED_CRYPTO \
93     EE \
94     EFI \
95     ELFTOOLCHAIN_BOOTSTRAP \
96     EXAMPLES \
97     FDT \
98     FILE \
99     FINGER \
100     FLOPPY \
101     FMTREE \
102     FORTH \
103     FP_LIBC \
104     FREEBSD_UPDATE \
105     FTP \
106     GAMES \
107     GCOV \
108     GDB \
109     GNU_DIFF \
110     GNU_GREP \
111     GPIO \
112     HAST \
113     HTML \
114     HYPERV \
115     ICONV \
116     INET \
117     INET6 \
118     INETD \
119     IPFILTER \
120     IPFW \
121     ISCSI \
122     JAIL \
123     KDUMP \
124     KVM \
125     LDNS \
126     LDNS_UTILS \
127     LEGACY_CONSOLE \
128     LIB32 \
129     LIBPTHREAD \
130     LIBTHR \
131     LLVM_COV \
132     LOADER_GELI \
133     LOADER_OFW \
134     LOADER_UBOOT \
135     LOCALES \
136     LOCATE \
137     LPR \
138     LS_COLORS \
139     LZMA_SUPPORT \
140     MAIL \
141     MAILWRAPPER \
142     MAKE \
143     NDIS \
144     NETCAT \
145     NETGRAPH \
146     NLS_CATALOGS \
147     NS_CACHING \
148     NTP \
149     OPENSSL \
150     PAM \
151     PC_SYSINSTALL \
152     PF \
153     PKGBOOTSTRAP \
154     PMC \
155     PORTSNAP \
156     PPP \
157     QUOTAS \
158     RADIUS_SUPPORT \
159     RBOOTD \
160     RESCUE \
161     ROUTED \
162     SENDMAIL \
163     SETUID_LOGIN \
164     SHAREDOCS \
165     SOURCELESS \
166     SOURCELESS_HOST \
167     SOURCELESS_UCODE \
168     SVNLITE \
169     SYSCONS \
170     SYSTEM_COMPILER \
171     TALK \
172     TCP_WRAPPERS \
173     TCSH \
174     TELNET \
175     TEXTPROC \
176     TFTP \
177     TIMED \
178     UNBOUND \
179     USB \
180     UTMPX \
181     VI \
182     VT \
183     WIRELESS \
184     WPA_SUPPLICANT_EAPOL \
185     ZFS \
186     ZONEINFO
187
188 __DEFAULT_NO_OPTIONS = \
189     BSD_GREP \
190     CLANG_EXTRAS \
191     DTRACE_TESTS \
192     GNU_GREP_COMPAT \
193     HESIOD \
194     LIBSOFT \
195     LOADER_FIREWIRE \
196     LOADER_FORCE_LE \
197     LOADER_LUA \
198     NAND \
199     OFED \
200     OPENLDAP \
201     REPRODUCIBLE_BUILD \
202     RPCBIND_WARMSTART_SUPPORT \
203     SHARED_TOOLCHAIN \
204     SORT_THREADS \
205     SVN \
206     ZONEINFO_LEAPSECONDS_SUPPORT \
207     ZONEINFO_OLD_TIMEZONES_SUPPORT \
208
209
210 #
211 # Default behaviour of some options depends on the architecture.  Unfortunately
212 # this means that we have to test TARGET_ARCH (the buildworld case) as well
213 # as MACHINE_ARCH (the non-buildworld case).  Normally TARGET_ARCH is not
214 # used at all in bsd.*.mk, but we have to make an exception here if we want
215 # to allow defaults for some things like clang to vary by target architecture.
216 # Additional, per-target behavior should be rarely added only after much
217 # gnashing of teeth and grinding of gears.
218 #
219 .if defined(TARGET_ARCH)
220 __T=${TARGET_ARCH}
221 .else
222 __T=${MACHINE_ARCH}
223 .endif
224 .if defined(TARGET)
225 __TT=${TARGET}
226 .else
227 __TT=${MACHINE}
228 .endif
229
230 .include <bsd.compiler.mk>
231 # If the compiler is not C++11 capable, disable Clang and use GCC instead.
232 # This means that architectures that have GCC 4.2 as default can not
233 # build Clang without using an external compiler.
234
235 .if ${COMPILER_FEATURES:Mc++11} && (${__T} == "aarch64" || \
236     ${__T} == "amd64" || ${__TT} == "arm" || ${__T} == "i386")
237 # Clang is enabled, and will be installed as the default /usr/bin/cc.
238 __DEFAULT_YES_OPTIONS+=CLANG CLANG_BOOTSTRAP CLANG_FULL CLANG_IS_CC LLD
239 __DEFAULT_NO_OPTIONS+=GCC GCC_BOOTSTRAP GNUCXX GPL_DTC
240 .elif ${COMPILER_FEATURES:Mc++11} && ${__T:Mriscv*} == "" && ${__T} != "sparc64"
241 # If an external compiler that supports C++11 is used as ${CC} and Clang
242 # supports the target, then Clang is enabled but GCC is installed as the
243 # default /usr/bin/cc.
244 __DEFAULT_YES_OPTIONS+=CLANG CLANG_FULL GCC GCC_BOOTSTRAP GNUCXX GPL_DTC LLD
245 __DEFAULT_NO_OPTIONS+=CLANG_BOOTSTRAP CLANG_IS_CC
246 .else
247 # Everything else disables Clang, and uses GCC instead.
248 __DEFAULT_YES_OPTIONS+=GCC GCC_BOOTSTRAP GNUCXX GPL_DTC
249 __DEFAULT_NO_OPTIONS+=CLANG CLANG_BOOTSTRAP CLANG_FULL CLANG_IS_CC LLD
250 .endif
251 # In-tree binutils/gcc are older versions without modern architecture support.
252 .if ${__T} == "aarch64" || ${__T:Mriscv*} != ""
253 BROKEN_OPTIONS+=BINUTILS BINUTILS_BOOTSTRAP GCC GCC_BOOTSTRAP GDB
254 .endif
255 .if ${__T:Mriscv*} != ""
256 BROKEN_OPTIONS+=PROFILE # "sorry, unimplemented: profiler support for RISC-V"
257 BROKEN_OPTIONS+=TESTS   # "undefined reference to `_Unwind_Resume'"
258 BROKEN_OPTIONS+=CXX     # "libcxxrt.so: undefined reference to `_Unwind_Resume_or_Rethrow'"
259 .endif
260 .if ${__T} == "aarch64" || ${__T} == "amd64" || ${__T} == "i386" || \
261     ${__T:Mriscv*} != "" || ${__TT} == "mips"
262 __DEFAULT_YES_OPTIONS+=LLVM_LIBUNWIND
263 .else
264 __DEFAULT_NO_OPTIONS+=LLVM_LIBUNWIND
265 .endif
266 .if ${__T} == "aarch64"
267 __DEFAULT_YES_OPTIONS+=LLD_BOOTSTRAP LLD_IS_LD
268 .elif ${__T} == "amd64"
269 __DEFAULT_YES_OPTIONS+=LLD_BOOTSTRAP
270 __DEFAULT_NO_OPTIONS+=LLD_IS_LD
271 .else
272 __DEFAULT_NO_OPTIONS+=LLD_BOOTSTRAP LLD_IS_LD
273 .endif
274 .if ${__T} == "aarch64" || ${__T} == "amd64" || ${__T} == "i386"
275 __DEFAULT_YES_OPTIONS+=LLDB
276 .else
277 __DEFAULT_NO_OPTIONS+=LLDB
278 .endif
279 # LLVM lacks support for FreeBSD 64-bit atomic operations for ARMv4/ARMv5
280 .if ${__T} == "arm" || ${__T} == "armeb"
281 BROKEN_OPTIONS+=LLDB
282 .endif
283 # GDB in base is generally less functional than GDB in ports.  Ports GDB
284 # does not yet contain kernel support for arm, and sparc64 kernel support
285 # has not been tested.
286 .if ${__T:Marm*} != "" || ${__T} == "sparc64"
287 __DEFAULT_NO_OPTIONS+=GDB_LIBEXEC
288 .else
289 __DEFAULT_YES_OPTIONS+=GDB_LIBEXEC
290 .endif
291 # Only doing soft float API stuff on armv6 and armv7
292 .if ${__T} != "armv6" && ${__T} != "armv7"
293 BROKEN_OPTIONS+=LIBSOFT
294 .endif
295 .if ${__T:Mmips*}
296 BROKEN_OPTIONS+=SSP
297 .endif
298 # EFI doesn't exist on mips, powerpc, sparc or riscv.
299 .if ${__T:Mmips*} || ${__T:Mpowerpc*} || ${__T:Msparc64} || ${__T:Mriscv*}
300 BROKEN_OPTIONS+=EFI
301 .endif
302 # GELI isn't supported on !x86
303 .if ${__T} != "i386" && ${__T} != "amd64"
304 BROKEN_OPTIONS+=LOADER_GELI
305 .endif
306 # OFW is only for powerpc and sparc64, exclude others
307 .if ${__T:Mpowerpc*} == "" && ${__T:Msparc64} == ""
308 BROKEN_OPTIONS+=LOADER_OFW
309 .endif
310 # UBOOT is only for arm, mips and powerpc, exclude others
311 .if ${__T:Marm*} == "" && ${__T:Mmips*} == "" && ${__T:Mpowerpc*} == ""
312 BROKEN_OPTIONS+=LOADER_UBOOT
313 .endif
314
315 .if ${__T:Mmips64*}
316 # profiling won't work on MIPS64 because there is only assembly for o32
317 BROKEN_OPTIONS+=PROFILE
318 .endif
319 .if ${__T} == "aarch64" || ${__T} == "amd64" || ${__T} == "i386" || \
320     ${__T} == "powerpc64" || ${__T} == "sparc64"
321 __DEFAULT_YES_OPTIONS+=CXGBETOOL
322 __DEFAULT_YES_OPTIONS+=MLX5TOOL
323 .else
324 __DEFAULT_NO_OPTIONS+=CXGBETOOL
325 __DEFAULT_NO_OPTIONS+=MLX5TOOL
326 .endif
327
328 .include <bsd.mkopt.mk>
329
330 #
331 # MK_* options that default to "yes" if the compiler is a C++11 compiler.
332 #
333 .for var in \
334     LIBCPLUSPLUS
335 .if !defined(MK_${var})
336 .if ${COMPILER_FEATURES:Mc++11}
337 .if defined(WITHOUT_${var})
338 MK_${var}:=     no
339 .else
340 MK_${var}:=     yes
341 .endif
342 .else
343 .if defined(WITH_${var})
344 MK_${var}:=     yes
345 .else
346 MK_${var}:=     no
347 .endif
348 .endif
349 .endif
350 .endfor
351
352 #
353 # Force some options off if their dependencies are off.
354 # Order is somewhat important.
355 #
356 .if !${COMPILER_FEATURES:Mc++11}
357 MK_LLVM_LIBUNWIND:=     no
358 .endif
359
360 .if ${MK_BINUTILS} == "no"
361 MK_GDB:=        no
362 .endif
363
364 .if ${MK_CAPSICUM} == "no"
365 MK_CASPER:=     no
366 .endif
367
368 .if ${MK_LIBPTHREAD} == "no"
369 MK_LIBTHR:=     no
370 .endif
371
372 .if ${MK_LDNS} == "no"
373 MK_LDNS_UTILS:= no
374 MK_UNBOUND:= no
375 .endif
376
377 .if ${MK_SOURCELESS} == "no"
378 MK_SOURCELESS_HOST:=    no
379 MK_SOURCELESS_UCODE:= no
380 .endif
381
382 .if ${MK_CDDL} == "no"
383 MK_ZFS:=        no
384 MK_CTF:=        no
385 .endif
386
387 .if ${MK_CRYPT} == "no"
388 MK_OPENSSL:=    no
389 MK_OPENSSH:=    no
390 MK_KERBEROS:=   no
391 .endif
392
393 .if ${MK_CXX} == "no"
394 MK_CLANG:=      no
395 MK_GNUCXX:=     no
396 MK_TESTS:=      no
397 .endif
398
399 .if ${MK_DIALOG} == "no"
400 MK_BSDINSTALL:= no
401 .endif
402
403 .if ${MK_MAIL} == "no"
404 MK_MAILWRAPPER:= no
405 MK_SENDMAIL:=   no
406 MK_DMAGENT:=    no
407 .endif
408
409 .if ${MK_NETGRAPH} == "no"
410 MK_ATM:=        no
411 MK_BLUETOOTH:=  no
412 .endif
413
414 .if ${MK_NLS} == "no"
415 MK_NLS_CATALOGS:= no
416 .endif
417
418 .if ${MK_OPENSSL} == "no"
419 MK_OPENSSH:=    no
420 MK_KERBEROS:=   no
421 .endif
422
423 .if ${MK_PF} == "no"
424 MK_AUTHPF:=     no
425 .endif
426
427 .if ${MK_TESTS} == "no"
428 MK_DTRACE_TESTS:= no
429 .endif
430
431 .if ${MK_ZONEINFO} == "no"
432 MK_ZONEINFO_LEAPSECONDS_SUPPORT:= no
433 MK_ZONEINFO_OLD_TIMEZONES_SUPPORT:= no
434 .endif
435
436 .if ${MK_CROSS_COMPILER} == "no"
437 MK_BINUTILS_BOOTSTRAP:= no
438 MK_CLANG_BOOTSTRAP:= no
439 MK_ELFTOOLCHAIN_BOOTSTRAP:= no
440 MK_GCC_BOOTSTRAP:= no
441 MK_LLD_BOOTSTRAP:= no
442 .endif
443
444 .if ${MK_TOOLCHAIN} == "no"
445 MK_BINUTILS:=   no
446 MK_CLANG:=      no
447 MK_GCC:=        no
448 MK_GDB:=        no
449 MK_INCLUDES:=   no
450 MK_LLD:=        no
451 MK_LLDB:=       no
452 .endif
453
454 .if ${MK_CLANG} == "no"
455 MK_CLANG_EXTRAS:= no
456 MK_CLANG_FULL:= no
457 MK_LLVM_COV:= no
458 .endif
459
460 #
461 # MK_* options whose default value depends on another option.
462 #
463 .for vv in \
464     GSSAPI/KERBEROS \
465     MAN_UTILS/MAN
466 .if defined(WITH_${vv:H})
467 MK_${vv:H}:=    yes
468 .elif defined(WITHOUT_${vv:H})
469 MK_${vv:H}:=    no
470 .else
471 MK_${vv:H}:=    ${MK_${vv:T}}
472 .endif
473 .endfor
474
475 #
476 # Set defaults for the MK_*_SUPPORT variables.
477 #
478
479 #
480 # MK_*_SUPPORT options which default to "yes" unless their corresponding
481 # MK_* variable is set to "no".
482 #
483 .for var in \
484     BLACKLIST \
485     BZIP2 \
486     INET \
487     INET6 \
488     KERBEROS \
489     KVM \
490     NETGRAPH \
491     PAM \
492     TESTS \
493     WIRELESS
494 .if defined(WITHOUT_${var}_SUPPORT) || ${MK_${var}} == "no"
495 MK_${var}_SUPPORT:= no
496 .else
497 MK_${var}_SUPPORT:= yes
498 .endif
499 .endfor
500
501 .if !${COMPILER_FEATURES:Mc++11}
502 MK_LLDB:=       no
503 .endif
504
505 # gcc 4.8 and newer supports libc++, so suppress gnuc++ in that case.
506 # while in theory we could build it with that, we don't want to do
507 # that since it creates too much confusion for too little gain.
508 # XXX: This is incomplete and needs X_COMPILER_TYPE/VERSION checks too
509 #      to prevent Makefile.inc1 from bootstrapping unneeded dependencies
510 #      and to support 'make delete-old' when supplying an external toolchain.
511 .if ${COMPILER_TYPE} == "gcc" && ${COMPILER_VERSION} >= 40800
512 MK_GNUCXX:=no
513 MK_GCC:=no
514 .endif
515
516 .endif #  !target(__<src.opts.mk>__)