2 # $FreeBSD: src/Makefile.inc1,v 1.141.2.62 2003/04/06 19:54:00 dwmalone Exp $
3 # $DragonFly: src/Makefile.inc1,v 1.68 2005/05/09 17:36:59 dillon Exp $
5 # Make command line options:
6 # -DMAKE_KERBEROS5 to build Kerberos5
7 # -DNOCLEANDIR run ${MAKE} clean, instead of ${MAKE} cleandir
8 # -DNOCLEAN do not clean at all
9 # -DNOCRYPT will prevent building of crypt versions
10 # -DNOMAN do not build the manual pages
11 # -DNOPROFILE do not build profiled libraries
12 # -DNOGAMES do not go into games subdir
13 # -DNOSHARE do not go into share subdir
14 # -DNOINFO do not make or install info files
15 # -DNOLIBC_R do not build libc_r.
16 # -DNO_FORTRAN do not build g77 and related libraries.
17 # -DNO_KERNELCONFIG do not run config in ${MAKE} buildkernel
18 # -DNO_KERNELCLEAN do not run ${MAKE} clean in ${MAKE} buildkernel
19 # -DNO_KERNELDEPEND do not run ${MAKE} depend in ${MAKE} buildkernel
20 # -DNO_PORTSUPDATE do not update ports in ${MAKE} update
21 # -DNO_DOCUPDATE do not update doc in ${MAKE} update
22 # LOCAL_DIRS="list of dirs" to add additional dirs to the SUBDIR list
23 # TARGET_ARCH="arch" to crossbuild world to a different arch
25 # The intended user-driven targets are:
27 # buildworld - rebuild *everything*, including glue to help do upgrades
28 # quickworld - skip the glue and do a depend+build on the meat
29 # realquickworld - skip the glue and depend stages and just build the meat
30 # crossworld - only build the glue (particularly the cross-build environment)
31 # installworld- install everything built by "buildworld"
32 # update - convenient way to update your source tree (eg: sup/cvs)
33 # most - build user commands, no libraries or include files
34 # installmost - install user commands, no libraries or include files
36 # Standard targets (not defined here) are documented in the makefiles in
37 # /usr/share/mk. These include:
38 # obj depend all install clean cleandepend cleanobj
40 # Put initial settings here.
43 # We must do share/info early so that installation of info `dir'
44 # entries works correctly. Do it first since it is less likely to
45 # grow dependencies on include and lib than vice versa.
46 .if exists(${.CURDIR}/share/info)
50 # We must do include and lib early so that the perl *.ph generation
51 # works correctly as it uses the header files installed by this.
52 .if exists(${.CURDIR}/include)
55 .if exists(${.CURDIR}/lib)
58 # This exists simply to ensure that the obj dir hierarchy is
59 # intact for nrelease, allowing the nrelease Makefile's to
60 # reference ${.OBJDIR}.
62 .if exists(${.CURDIR}/nrelease)
66 .if exists(${.CURDIR}/bin)
69 .if exists(${.CURDIR}/games) && !defined(NOGAMES)
72 .if exists(${.CURDIR}/gnu)
75 .if exists(${.CURDIR}/kerberos5) && exists(${.CURDIR}/crypto) && \
76 !defined(NOCRYPT) && !defined(NO_OPENSSL) && defined(MAKE_KERBEROS5)
79 .if exists(${.CURDIR}/libexec)
82 .if exists(${.CURDIR}/sbin)
85 .if exists(${.CURDIR}/secure) && !defined(NOCRYPT)
88 .if exists(${.CURDIR}/share) && !defined(NOSHARE)
91 .if exists(${.CURDIR}/sys)
94 .if exists(${.CURDIR}/usr.bin)
97 .if exists(${.CURDIR}/usr.sbin)
101 # etc must be last for "distribute" to work
102 .if exists(${.CURDIR}/etc)
106 # These are last, since it is nice to at least get the base system
107 # rebuilt before you do them.
108 .if defined(LOCAL_DIRS)
109 .for _DIR in ${LOCAL_DIRS}
110 .if exists(${.CURDIR}/${_DIR}) & exists(${.CURDIR}/${_DIR}/Makefile)
116 .if defined(SUBDIR_OVERRIDE)
117 SUBDIR= ${SUBDIR_OVERRIDE}
120 .if defined(NOCLEANDIR)
121 CLEANDIR= clean cleandepend
126 SUP?= /usr/local/bin/cvsup
127 SUPFLAGS?= -g -L 2 -P -
129 SUPFLAGS+= -h ${SUPHOST}
132 # Object directory base in primary make. Note that when we rerun make
133 # from inside this file we change MAKEOBJDIRPREFIX to the appropriate
134 # subdirectory because the rest of the build system needs it that way.
135 # The original object directory base is saved in OBJTREE.
137 MAKEOBJDIRPREFIX?= /usr/obj
138 OBJTREE?= ${MAKEOBJDIRPREFIX}
140 # Used for stage installs and pathing
142 DESTDIRBASE?= ${OBJTREE}${.CURDIR}
144 TARGET_ARCH?= ${MACHINE_ARCH}
145 .if ${TARGET_ARCH} == ${MACHINE_ARCH}
148 TARGET?= ${TARGET_ARCH}
151 BUILD_ARCH!= sysctl -n hw.machine_arch
152 .if ${MACHINE_ARCH} != ${BUILD_ARCH}
153 .error To cross-build, set TARGET_ARCH.
157 # BTOOLS (Natively built) All non-cross-development tools that the
158 # main build needs. This includes things like 'mkdir' and 'rm'.
159 # We will not use the native system's exec path once we start
160 # on WORLD. (bootstrap-tools and build-tools or BTOOLS)
162 # CTOOLS (Natively built) Cross development tools which are specific
163 # to the target architecture.
165 # WORLD (Cross built) Our ultimate buildworld, using only BTOOLS and
168 # MACHINE_ARCH Architecture we are building on
169 # TARGET_ARCH Architecture we are building for
171 BTOOLSDEST= ${DESTDIRBASE}/btools_${MACHINE_ARCH}
172 CTOOLSDEST= ${DESTDIRBASE}/ctools_${MACHINE_ARCH}_${TARGET_ARCH}
173 WORLDDEST= ${DESTDIRBASE}/world_${TARGET_ARCH}
175 # The bootstrap-tools path is used by the bootstrap-tools, build-tools, and
176 # cross-tools stages to augment the existing command path to access newer
177 # versions of certain utilities such as 'patch' that the cross-tools stage
180 BTOOLSPATH= ${BTOOLSDEST}/usr/sbin:${BTOOLSDEST}/usr/bin:${BTOOLSDEST}/bin:${BTOOLSDEST}/usr/games
182 # The strict temporary command path contains all binaries required
183 # by the buildworld system after the cross-tools stage.
185 STRICTTMPPATH= ${CTOOLSDEST}/usr/sbin:${CTOOLSDEST}/usr/bin:${CTOOLSDEST}/bin:${CTOOLSDEST}/usr/games:${BTOOLSDEST}/usr/sbin:${BTOOLSDEST}/usr/bin:${BTOOLSDEST}/bin:${BTOOLSDEST}/usr/games
191 # Building a world goes through the following stages
193 # 1. bootstrap-tool stage [BMAKE]
194 # This stage is responsible for creating programs that
195 # are needed for backward compatibility reasons. They
196 # are not built as cross-tools.
197 # 2. build-tool stage [TMAKE]
198 # This stage is responsible for creating the object
199 # tree and building any tools that are needed during
201 # 3. cross-tool stage [XMAKE]
202 # This stage is responsible for creating any tools that
203 # are needed for cross-builds. A cross-compiler is one
205 # 4. world stage [WMAKE]
206 # This stage actually builds the world.
207 # 5. install stage (optional) [IMAKE]
208 # This stage installs a previously built world.
211 # bootstrap-tool stage
213 BMAKEENV= MAKEOBJDIRPREFIX=${BTOOLSDEST} \
215 DESTDIR=${BTOOLSDEST} \
216 PATH=${BTOOLSPATH}:${PATH} \
217 INSTALL="sh ${.CURDIR}/tools/install.sh"
219 BMAKE= ${BMAKEENV} ${MAKE} -f Makefile.inc1 -DBOOTSTRAPPING \
220 -DNOHTML -DNOINFO -DNOMAN -DNOPIC -DNOPROFILE -DNOSHARED \
225 TMAKEENV= MAKEOBJDIRPREFIX=${BTOOLSDEST} \
228 PATH=${BTOOLSPATH}:${PATH} \
229 INSTALL="sh ${.CURDIR}/tools/install.sh"
231 TMAKE= ${TMAKEENV} ${MAKE} -f Makefile.inc1 -DBOOTSTRAPPING \
236 # note: TOOLS_PREFIX points to the obj root holding the cross
237 # compiler binaries, while USRDATA_PREFIX points to the obj root
238 # holding the target environment (and also determines where cross-built
239 # libraries, crt*.o, and include files are installed).
241 XMAKEENV= MAKEOBJDIRPREFIX=${CTOOLSDEST} \
243 DESTDIR=${CTOOLSDEST} \
244 INSTALL="sh ${.CURDIR}/tools/install.sh" \
245 TOOLS_PREFIX=${CTOOLSDEST} \
246 USRDATA_PREFIX=${WORLDDEST} \
247 PATH=${BTOOLSPATH}:${PATH}
249 XMAKE= ${XMAKEENV} ${MAKE} -f Makefile.inc1 -DNO_FORTRAN -DNO_GDB \
252 # world stage, note the strict path and note that TOOLS_PREFIX is left
253 # unset and USRDATA_PREFIX (which defaults to TOOLS_PREFIX) is set to empty,
254 # which is primarily for the compiler so it targets / (e.g. /usr/<blah>)
255 # for both binary and library paths, even though it is being compiled to
256 # WORLDDEST. None of the programs in the world stage are ever actually
257 # executed during the buildworld/installworld.
259 CROSSENV= MAKEOBJDIRPREFIX=${WORLDDEST} \
261 MACHINE_ARCH=${TARGET_ARCH} \
263 OBJFORMAT_PATH=${CTOOLSDEST}
265 WMAKEENV= ${CROSSENV} \
266 DESTDIR=${WORLDDEST} \
267 INSTALL="sh ${.CURDIR}/tools/install.sh" \
268 PATH=${STRICTTMPPATH}
270 WMAKE= ${WMAKEENV} ${MAKE} -f Makefile.inc1
274 IMAKEENV= ${CROSSENV} \
275 PATH=${STRICTTMPPATH}
276 IMAKE= ${IMAKEENV} ${MAKE} -f Makefile.inc1
280 KMAKEENV= ${WMAKEENV}
284 # Attempt to rebuild the entire system, with reasonable chance of
285 # success, regardless of how old your existing system is.
289 @echo "--------------------------------------------------------------"
290 @echo ">>> Rebuilding the temporary build tree"
291 @echo "--------------------------------------------------------------"
292 .if !defined(NOCLEAN)
293 rm -rf ${BTOOLSDEST} ${CTOOLSDEST} ${WORLDDEST}
295 # XXX - These two can depend on any header file.
296 rm -f ${OBJTREE}${.CURDIR}/usr.bin/kdump/ioctl.c
297 rm -f ${OBJTREE}${.CURDIR}/usr.bin/truss/ioctl.c
299 mkdir -p ${DESTDIRBASE} ${BTOOLSDEST} ${CTOOLSDEST} ${WORLDDEST}
300 .for _dir in ${WORLDDEST} ${BTOOLSDEST} ${CTOOLSDEST}
301 mtree -deU -f ${.CURDIR}/etc/mtree/BSD.root.dist \
302 -p ${_dir}/ > /dev/null
303 mtree -deU -f ${.CURDIR}/etc/mtree/BSD.usr.dist \
304 -p ${_dir}/usr > /dev/null
306 mtree -deU -f ${.CURDIR}/etc/mtree/BSD.include.dist \
307 -p ${WORLDDEST}/usr/include > /dev/null
308 ln -sf ${.CURDIR}/sys ${WORLDDEST}
312 @echo "--------------------------------------------------------------"
313 @echo ">>> stage 1: bootstrap tools"
314 @echo "--------------------------------------------------------------"
315 cd ${.CURDIR}; ${BMAKE} bootstrap-tools
318 @echo "--------------------------------------------------------------"
319 @echo ">>> stage 2a: cleaning up the object tree"
320 @echo "--------------------------------------------------------------"
321 cd ${.CURDIR}; ${WMAKE} ${CLEANDIR:S/^/par-/}
324 @echo "--------------------------------------------------------------"
325 @echo ">>> stage 2b: rebuilding the object tree"
326 @echo "--------------------------------------------------------------"
327 cd ${.CURDIR}; ${WMAKE} par-obj
330 @echo "--------------------------------------------------------------"
331 @echo ">>> stage 2c: build tools"
332 @echo "--------------------------------------------------------------"
333 cd ${.CURDIR}; ${TMAKE} build-tools
336 @echo "--------------------------------------------------------------"
337 @echo ">>> stage 3: cross tools"
338 @echo "--------------------------------------------------------------"
339 cd ${.CURDIR}; ${XMAKE} cross-tools
342 @echo "--------------------------------------------------------------"
343 @echo ">>> stage 4a: populating ${WORLDDEST}/usr/include"
344 @echo "--------------------------------------------------------------"
345 cd ${.CURDIR}; ${WMAKE} SHARED=symlinks par-includes
348 @echo "--------------------------------------------------------------"
349 @echo ">>> stage 4b: building libraries"
350 @echo "--------------------------------------------------------------"
351 cd ${.CURDIR}; ${WMAKE} -DNOHTML -DNOINFO -DNOMAN -DNOFSCHG libraries
354 @echo "--------------------------------------------------------------"
355 @echo ">>> stage 4c: make dependencies"
356 @echo "--------------------------------------------------------------"
357 cd ${.CURDIR}; ${WMAKE} par-depend
360 @echo "--------------------------------------------------------------"
361 @echo ">>> stage 4d: building everything.."
362 @echo "--------------------------------------------------------------"
363 cd ${.CURDIR}; ${WMAKE} all
365 # note: buildworld no longer depends on _cleanobj because we rm -rf the
366 # entire object tree and built the bootstrap tools in a different location.
368 # buildworld - build everything from scratch
369 # quickworld - skip the bootstrap, build, and cross-build steps
370 # realquickworld - skip the bootstrap, build, crossbuild, and depend step.
372 # note: we include _obj in realquickworld to prevent accidental creation
373 # of files in /usr/src.
376 .if !defined(SUBDIR_OVERRIDE)
377 WMAKE_TGTS+= _worldtmp _bootstrap-tools
379 WMAKE_TGTS+= _obj _build-tools
380 .if !defined(SUBDIR_OVERRIDE)
381 WMAKE_TGTS+= _cross-tools
383 WMAKE_TGTS+= _includes _libraries _depend everything
385 buildworld: ${WMAKE_TGTS}
387 quickworld: _obj _includes _libraries _depend everything
389 realquickworld: _obj _includes _libraries everything
391 crossworld: _worldtmp _bootstrap-tools _obj _build-tools _cross-tools
393 .ORDER: ${WMAKE_TGTS}
398 # Checks to be sure system is ready for installworld
401 .if !defined(NO_SENDMAIL)
402 @pw usershow smmsp || (echo "You may need to run 'make preupgrade' first"; exit 1)
403 @pw groupshow smmsp || (echo "You may need to run 'make preupgrade' first"; exit 1)
405 @pw usershow _pflogd || (echo "You may need to run 'make preupgrade' first"; exit 1)
406 @pw usershow _ntp || (echo "You may need to run 'make preupgrade' first"; exit 1)
407 @pw groupshow authpf || (echo "You may need to run 'make preupgrade' first"; exit 1)
408 @pw groupshow _pflogd || (echo "You may need to run 'make preupgrade' first"; exit 1)
409 @pw groupshow _ntp || (echo "You may need to run 'make preupgrade' first"; exit 1)
410 @case `uname -r` in 1.2.0|1.2.1|1.3-*) echo "You must upgrade your kernel to at least 1.2.2 or 1.3.1 and reboot before you can safely installworld, due to a TLS bug in fork" ; exit 1;; esac
414 # Distributes everything compiled by a `buildworld'.
418 # Installs everything compiled by a 'buildworld'.
420 distributeworld installworld: installcheck
421 cd ${.CURDIR}; ${IMAKE} re${.TARGET:S/world$//}
426 # If you have a build server, you can NFS mount the source and obj directories
427 # and do a 'make reinstall' on the *client* to install new binaries from the
428 # most recent server build.
431 @echo "--------------------------------------------------------------"
432 @echo ">>> Making hierarchy"
433 @echo "--------------------------------------------------------------"
434 cd ${.CURDIR}; ${MAKE} -f Makefile.inc1 hierarchy
436 @echo "--------------------------------------------------------------"
437 @echo ">>> Installing everything.."
438 @echo "--------------------------------------------------------------"
439 cd ${.CURDIR}; ${MAKE} -f Makefile.inc1 install
440 .if !defined(NOMAN) && !defined(NO_MAKEDB_RUN)
442 @echo "--------------------------------------------------------------"
443 @echo ">>> Rebuilding man page indices"
444 @echo "--------------------------------------------------------------"
445 cd ${.CURDIR}/share/man; ${MAKE} makedb
449 @echo "--------------------------------------------------------------"
450 @echo ">>> Distributing everything.."
451 @echo "--------------------------------------------------------------"
452 cd ${.CURDIR}; ${MAKE} -f Makefile.inc1 distribute
455 # buildkernel, nativekernel, quickkernel, and installkernel
457 # Which kernels to build and/or install is specified by setting
458 # KERNCONF. If not defined a GENERIC kernel is built/installed.
459 # Only the existing (depending TARGET) config files are used
460 # for building kernels and only the first of these is designated
461 # as the one being installed.
463 # You can specify INSTALLSTRIPPED=1 if you wish the installed
464 # kernel and modules to be stripped of its debug info (required
465 # symbols are left intact). You can specify INSTALLSTRIPPEDMODULES
466 # if you only want to strip the modules of their debug info. These
467 # only apply if you have DEBUG=-g in your kernel config or make line.
469 # Note that we have to use TARGET instead of TARGET_ARCH when
470 # we're in kernel-land. Since only TARGET_ARCH is (expected) to
471 # be set to cross-build, we have to make sure TARGET is set
474 .if !defined(KERNCONF) && defined(KERNEL)
480 INSTKERNNAME?= kernel
482 KRNLSRCDIR= ${.CURDIR}/sys
483 KRNLCONFDIR= ${KRNLSRCDIR}/${TARGET}/conf
484 KRNLOBJDIR= ${OBJTREE}${KRNLSRCDIR}
485 KERNCONFDIR?= ${KRNLCONFDIR}
489 .for _kernel in ${KERNCONF}
490 .if exists(${KERNCONFDIR}/${_kernel})
491 BUILDKERNELS+= ${_kernel}
492 .if empty(INSTALLKERNEL)
493 INSTALLKERNEL= ${_kernel}
498 # kernel version numbers survive rm -rf
500 .for _kernel in ${BUILDKERNELS}
501 .if exists(${KRNLOBJDIR}/${_kernel}/version)
502 KERNEL_VERSION_${_kernel} != cat ${KRNLOBJDIR}/${_kernel}/version
509 # Builds all kernels defined by BUILDKERNELS.
512 @if [ ! -f ${WORLDDEST}/.libraries_done ]; then \
513 echo "You must buildworld before buildkernel. If you wish"; \
514 echo "to build a kernel using native tools, config it manually"; \
515 echo "or use the nativekernel target if you are in a rush"; \
520 .for _kernel in ${BUILDKERNELS}
521 @if [ ! -f ${KRNLOBJDIR}/${_kernel}/.nativekernel_run ]; then \
522 if [ ! -f ${WORLDDEST}/.libraries_done ]; then \
523 echo "The kernel was build using buildworld tools which no" ; \
524 echo "longer appear to exist, quickkernel failed!" ; \
531 .if empty(BUILDKERNELS)
532 @echo ">>> ERROR: Missing kernel configuration file(s) (${KERNCONF})."
537 .if defined(KERNWARN)
538 @echo "--------------------------------------------------------------"
539 @echo ">>> WARNING: KERNEL= setting should be changed to KERNCONF="
540 @echo "--------------------------------------------------------------"
545 # The buildkernel target rebuilds the specified kernels from scratch
546 # using the crossbuild tools generated by the last buildworld. It is
547 # the safest (but also the most time consuming) way to build a new kernel.
549 buildkernel: bk_tools bk_build_list bk_kernwarn
550 .for _kernel in ${BUILDKERNELS}
551 @echo "--------------------------------------------------------------"
552 @echo ">>> Kernel build for ${_kernel} started on `LC_ALL=C date`"
553 @echo "--------------------------------------------------------------"
554 @echo "===> ${_kernel}"
555 .if !defined(NOCLEAN) && !defined(NO_KERNELCLEAN)
556 rm -rf ${KRNLOBJDIR}/${_kernel}
558 @if [ -f ${KRNLOBJDIR}/${_kernel}/.nativekernel_run ]; then \
559 echo "YOU ARE REBUILDING WITH BUILDKERNEL, REMOVING OLD NATIVEKERNEL BUILD"; \
560 rm -rf ${KRNLOBJDIR}/${_kernel}; fi
562 mkdir -p ${KRNLOBJDIR}
563 .if !defined(NO_KERNELCONFIG)
565 PATH=${STRICTTMPPATH} \
566 config ${CONFIGARGS} -d ${KRNLOBJDIR}/${_kernel} \
567 ${KERNCONFDIR}/${_kernel}
569 .if !defined(NOCLEAN) && !defined(NO_KERNELCLEAN) && defined(KERNEL_VERSION_${_kernel})
570 echo ${KERNEL_VERSION_${_kernel}} > ${KRNLOBJDIR}/${_kernel}/version
572 touch ${KRNLOBJDIR}/${_kernel}/.buildkernel_run
573 cd ${KRNLOBJDIR}/${_kernel}; \
574 MAKESRCPATH=${KRNLSRCDIR}/dev/disk/aic7xxx/aicasm \
575 ${MAKE} -DBOOTSTRAPPING -f ${KRNLSRCDIR}/dev/disk/aic7xxx/aicasm/Makefile
576 .if !defined(NO_KERNELDEPEND)
577 cd ${KRNLOBJDIR}/${_kernel}; \
578 ${KMAKEENV} ${MAKE} KERNEL=${INSTKERNNAME} depend
580 cd ${KRNLOBJDIR}/${_kernel}; \
581 ${KMAKEENV} ${MAKE} KERNEL=${INSTKERNNAME} all
582 @echo "--------------------------------------------------------------"
583 @echo ">>> Kernel build for ${_kernel} completed on `LC_ALL=C date`"
584 @echo "--------------------------------------------------------------"
587 # The nativekernel target rebuilds the specified kernels from scratch
588 # using the systems standard compiler rather then using the crossbuild
589 # tools generated by the last buildworld. This is fairly safe if your
590 # system is reasonable up-to-date.
592 nativekernel: bk_build_list bk_kernwarn
593 .for _kernel in ${BUILDKERNELS}
594 @echo "--------------------------------------------------------------"
595 @echo ">>> Kernel build for ${_kernel} started on `LC_ALL=C date`"
596 @echo "--------------------------------------------------------------"
597 @echo "===> ${_kernel}"
598 .if !defined(NOCLEAN) && !defined(NO_KERNELCLEAN)
599 rm -rf ${KRNLOBJDIR}/${_kernel}
601 @if [ -f ${KRNLOBJDIR}/${_kernel}/.buildkernel_run ]; then \
602 echo "YOU ARE REBUILDING WITH NATIVEKERNEL, REMOVING OLD BUILDKERNEL BUILD"; \
603 rm -rf ${KRNLOBJDIR}/${_kernel}; fi
605 mkdir -p ${KRNLOBJDIR}
606 .if !defined(NO_KERNELCONFIG)
608 config ${CONFIGARGS} -d ${KRNLOBJDIR}/${_kernel} \
609 ${KERNCONFDIR}/${_kernel}
611 .if !defined(NOCLEAN) && !defined(NO_KERNELCLEAN) && defined(KERNEL_VERSION_${_kernel})
612 echo ${KERNEL_VERSION_${_kernel}} > ${KRNLOBJDIR}/${_kernel}/version
614 touch ${KRNLOBJDIR}/${_kernel}/.nativekernel_run
615 cd ${KRNLOBJDIR}/${_kernel}; \
616 MAKESRCPATH=${KRNLSRCDIR}/dev/disk/aic7xxx/aicasm \
617 ${MAKE} -DBOOTSTRAPPING -f ${KRNLSRCDIR}/dev/disk/aic7xxx/aicasm/Makefile
618 .if !defined(NO_KERNELDEPEND)
619 cd ${KRNLOBJDIR}/${_kernel}; \
620 ${MAKE} KERNEL=${INSTKERNNAME} depend
622 cd ${KRNLOBJDIR}/${_kernel}; \
623 ${MAKE} KERNEL=${INSTKERNNAME} all
624 @echo "--------------------------------------------------------------"
625 @echo ">>> Kernel build for ${_kernel} completed on `LC_ALL=C date`"
626 @echo "--------------------------------------------------------------"
629 # The quickkernel target rebuilds the specified kernels as quickly
630 # as possible. It will use the native tools or the buildworld cross tools
631 # based on whether the kernel was originally generated via buildkernel or
632 # nativekernel. Config is rerun but the object hierarchy is not rebuilt,
633 # nor is the make depend step run.
635 quickkernel: maybe_bk_tools bk_build_list bk_kernwarn
636 .for _kernel in ${BUILDKERNELS}
637 @echo "--------------------------------------------------------------"
638 @echo ">>> Kernel build for ${_kernel} started on `LC_ALL=C date`"
639 @echo "--------------------------------------------------------------"
640 @echo "===> ${_kernel}"
641 .if exists(${KRNLOBJDIR}/${_kernel}/.buildkernel_run)
642 .if !defined(NO_KERNELCONFIG)
644 PATH=${STRICTTMPPATH} \
645 config ${CONFIGARGS} -d ${KRNLOBJDIR}/${_kernel} \
646 ${KERNCONFDIR}/${_kernel}
648 cd ${KRNLOBJDIR}/${_kernel}; \
649 ${KMAKEENV} ${MAKE} KERNEL=${INSTKERNNAME} all
651 .if !defined(NO_KERNELCONFIG)
653 config ${CONFIGARGS} -d ${KRNLOBJDIR}/${_kernel} \
654 ${KERNCONFDIR}/${_kernel}
656 cd ${KRNLOBJDIR}/${_kernel}; \
657 ${MAKE} KERNEL=${INSTKERNNAME} all
659 @echo "--------------------------------------------------------------"
660 @echo ">>> Kernel build for ${_kernel} completed on `LC_ALL=C date`"
661 @echo "--------------------------------------------------------------"
667 # Install the kernel defined by INSTALLKERNEL
669 installkernel reinstallkernel:
670 .if exists(${KRNLOBJDIR}/${_kernel}/.buildkernel_run)
671 cd ${KRNLOBJDIR}/${INSTALLKERNEL}; \
672 ${CROSSENV} ${MAKE} KERNEL=${INSTKERNNAME} ${.TARGET:S/kernel$//}
674 cd ${KRNLOBJDIR}/${INSTALLKERNEL}; \
675 ${MAKE} KERNEL=${INSTKERNNAME} ${.TARGET:S/kernel$//}
681 # Update the source tree, by running sup and/or running cvs to update to the
685 .if defined(SUP_UPDATE)
686 @echo "--------------------------------------------------------------"
687 @echo ">>> Running ${SUP}"
688 @echo "--------------------------------------------------------------"
690 @${SUP} ${SUPFLAGS} ${SUPFILE}
692 .if defined(SUPFILE1)
693 @${SUP} ${SUPFLAGS} ${SUPFILE1}
695 .if defined(SUPFILE2)
696 @${SUP} ${SUPFLAGS} ${SUPFILE2}
698 .if defined(PORTSSUPFILE) && !defined(NO_PORTSUPDATE)
699 @${SUP} ${SUPFLAGS} ${PORTSSUPFILE}
701 .if defined(DOCSUPFILE) && !defined(NO_DOCUPDATE)
702 @${SUP} ${SUPFLAGS} ${DOCSUPFILE}
705 .if defined(CVS_UPDATE)
706 @echo "--------------------------------------------------------------"
707 @echo ">>> Updating ${.CURDIR} from cvs repository `cat ${.CURDIR}/CVS/Root`"
708 @echo "--------------------------------------------------------------"
710 cd ${.CURDIR}; cvs -q update -P -d
716 # Build most of the user binaries on the existing system libs and includes.
719 @echo "--------------------------------------------------------------"
720 @echo ">>> Building programs only"
721 @echo "--------------------------------------------------------------"
722 .for _dir in bin sbin libexec usr.bin usr.sbin gnu/libexec gnu/usr.bin gnu/usr.sbin
723 cd ${.CURDIR}/${_dir}; ${MAKE} DIRPRFX=${_dir}/ all
729 # Install the binaries built by the 'most' target. This does not include
730 # libraries or include files.
733 @echo "--------------------------------------------------------------"
734 @echo ">>> Installing programs only"
735 @echo "--------------------------------------------------------------"
736 .for _dir in bin sbin libexec usr.bin usr.sbin gnu/libexec gnu/usr.bin gnu/usr.sbin
737 cd ${.CURDIR}/${_dir}; ${MAKE} DIRPRFX=${_dir}/ install
741 # ------------------------------------------------------------------------
743 # From here onwards are utility targets used by the 'make world' and
744 # related targets. If your 'world' breaks, you may like to try to fix
745 # the problem and manually run the following targets to attempt to
746 # complete the build. Beware, this is *not* guaranteed to work, you
747 # need to have a pretty good grip on the current state of the system
748 # to attempt to manually finish it. If in doubt, 'make world' again.
751 # bootstrap-tools: Build all tools required to build all tools. Note that
752 # order is important in a number of cases and also note that the bootstrap
753 # and build tools stages have access to earlier binaries they themselves
756 # patch: older patch's do not have -i. This program must be built
757 # first so other bootstrap tools that need to apply patches
759 # [x]install: dependancies on various new install features
760 # rpcgen: old rpcgen used a hardwired cpp path, newer OBJFORMAT_PATH
761 # envs are not compatible with older objformat binaries.
763 .if exists(${.CURDIR}/games) && !defined(NOGAMES)
764 _strfile= games/fortune/strfile
768 ln -fs /bin/date ${BTOOLSDEST}/bin/date
769 .for _tool in ${_strfile} \
771 bin/chmod bin/cp bin/dd bin/mkdir bin/rm bin/echo bin/test \
772 bin/cat bin/ln bin/mv bin/csh bin/expr bin/sh bin/ls \
773 bin/hostname bin/kill \
774 usr.bin/yacc usr.bin/colldef usr.bin/uudecode usr.bin/xinstall \
775 usr.bin/m4 usr.bin/rpcgen usr.bin/make usr.bin/awk \
776 usr.bin/find usr.bin/lex usr.bin/sed usr.bin/uname usr.bin/touch \
777 usr.bin/mkdep usr.bin/mktemp usr.bin/lorder usr.bin/file2c \
778 usr.bin/tsort usr.bin/tr usr.bin/join usr.bin/wc usr.bin/basename \
779 usr.bin/gencat usr.bin/chflags usr.bin/expand usr.bin/paste \
780 usr.bin/mklocale usr.bin/uuencode usr.bin/compile_et usr.bin/hexdump \
781 usr.bin/vi usr.bin/cap_mkdb usr.bin/vgrind usr.bin/true usr.bin/false \
782 usr.bin/cmp usr.bin/xargs usr.bin/id usr.bin/env usr.bin/dirname \
784 usr.sbin/chown usr.sbin/mtree usr.sbin/config \
785 usr.sbin/btxld usr.sbin/pwd_mkdb usr.sbin/zic usr.sbin/makewhatis \
786 gnu/usr.bin/texinfo gnu/usr.bin/grep gnu/usr.bin/sort \
787 usr.bin/gzip usr.bin/bzip2 usr.bin/mkcsmapper usr.bin/mkesdb
788 ${ECHODIR} "===> ${_tool} (bootstrap-tools)"; \
789 cd ${.CURDIR}/${_tool}; \
790 ${MAKE} DIRPRFX=${_tool}/ obj; \
791 ${MAKE} DIRPRFX=${_tool}/ depend; \
792 ${MAKE} DIRPRFX=${_tool}/ all; \
793 ${MAKE} DIRPRFX=${_tool}/ DESTDIR=${BTOOLSDEST} install
795 touch ${BTOOLSDEST}/.bootstrap_done
797 # build-tools: Build special purpose build tools.
799 # XXX we may be able to remove or consolidate this into bootstrap-tools
800 # now that we have the native helper (.nx/.no) infrastructure.
802 .if exists(${.CURDIR}/games) && !defined(NOGAMES)
803 _games= games/adventure games/hack games/phantasia
806 .if exists(${.CURDIR}/share) && !defined(NOSHARE)
807 _share= share/syscons/scrnmaps
810 _gcc34_cross= gnu/usr.bin/cc34
811 _gcc34_tools= gnu/usr.bin/cc34/cc_prep gnu/usr.bin/cc34/cc_tools
812 _binutils= gnu/usr.bin/binutils215
814 .if !defined(NO_FORTRAN)
815 _fortran= gnu/usr.bin/cc34/f771
818 .if exists(${.CURDIR}/kerberos5) && exists(${.CURDIR}/crypto) && \
819 !defined(NOCRYPT) && defined(MAKE_KERBEROS5)
820 _libkrb5= kerberos5/bintools kerberos5/lib/libroken kerberos5/lib/libvers \
821 kerberos5/lib/libasn1 kerberos5/lib/libhdb kerberos5/lib/libsl
824 .if defined(RELEASEDIR)
825 _sysinstall= release/sysinstall
829 .for _tool in ${_gcc34_tools} ${_fortran} ${_libkrb5} ${_share} ${_sysinstall}
830 ${ECHODIR} "===> ${_tool} (build-tools)"; \
831 cd ${.CURDIR}/${_tool}; \
832 ${MAKE} DIRPRFX=${_tool}/ obj; \
833 ${MAKE} DIRPRFX=${_tool}/ depend; \
834 ${MAKE} DIRPRFX=${_tool}/ all; \
835 ${MAKE} DIRPRFX=${_tool}/ DESTDIR=${BTOOLSDEST} install
837 touch ${BTOOLSDEST}/.build_done
840 # cross-tools: Build cross-building tools
842 .if ${TARGET_ARCH} == "i386" && ${MACHINE_ARCH} != "i386"
843 _btxld= usr.sbin/btxld
847 .for _tool in ${_btxld} ${_binutils} \
848 usr.bin/objformat usr.sbin/crunch/crunchide \
850 ${ECHODIR} "===> ${_tool} (cross-tools)"; \
851 cd ${.CURDIR}/${_tool}; \
852 ${MAKE} DIRPRFX=${_tool}/ obj; \
853 ${MAKE} DIRPRFX=${_tool}/ depend; \
854 ${MAKE} DIRPRFX=${_tool}/ all; \
855 ${MAKE} DIRPRFX=${_tool}/ DESTDIR=${CTOOLSDEST} install
857 touch ${CTOOLSDEST}/.cross_done
860 # hierarchy - ensure that all the needed directories are present
863 cd ${.CURDIR}/etc; ${MAKE} distrib-dirs
866 # libraries - build all libraries, and install them under ${DESTDIR}.
868 # The list of libraries with dependents (${_prebuild_libs}) and their
869 # interdependencies (__L) are built automatically by the
870 # ${.CURDIR}/tools/make_libdeps.sh script.
872 # .makeenv does not work when bootstrapping from 4.x, so we must be sure
873 # to specify the correct CCVER or 'cc' will not exec the correct compiler.
877 HOST_CCVER=${HOST_CCVER} CCVER=gcc34 \
878 ${MAKE} -f Makefile.inc1 _startup_libs34; \
879 ${MAKE} -f Makefile.inc1 _startup_libs; \
880 ${MAKE} -f Makefile.inc1 _prebuild_libs; \
881 ${MAKE} -f Makefile.inc1 _generic_libs;
882 touch ${WORLDDEST}/.libraries_done
884 # These dependencies are not automatically generated:
886 # gnu/lib/${CCVER}/libgcc and lib/csu must be built before all
887 # shared libraries for ELF. The target for _startup_libs34 is
888 # specifically built using gcc34.
890 _startup_libs34= gnu/lib/gcc34/libgcc
891 _startup_libs= lib/csu/${MACHINE_ARCH}
892 _startup_libs+= lib/csu/common lib/libc lib/libc_rtld
894 _prebuild_libs= lib/libarchive
895 _prebuild_libs+= lib/libutil
897 _generic_libs= gnu/lib
899 .if !defined(NOCRYPT) && defined(MAKE_KERBEROS5)
900 _prebuild_libs+= kerberos5/tools
901 _prebuild_libs+= kerberos5/lib/libasn1
902 _prebuild_libs+= kerberos5/lib/libgssapi
903 _prebuild_libs+= kerberos5/lib/libkrb5
904 _prebuild_libs+= kerberos5/lib/libroken
905 _generic_libs+= kerberos5/lib
908 _prebuild_libs+= lib/libcom_err lib/libcrypt lib/libmd \
909 lib/libncurses/libncurses lib/libopie lib/libradius \
910 lib/libskey lib/libtacplus lib/libz lib/msun
912 lib/libopie__L lib/libradius__L lib/libtacplus__L: lib/libmd__L
913 lib/libskey__L: lib/libcrypt__L lib/libmd__L
917 .if !defined(NOCRYPT)
918 .if !defined(NO_OPENSSL)
919 _prebuild_libs+= secure/lib/libcrypto secure/lib/libssl
920 .if !defined(NO_OPENSSH)
921 _prebuild_libs+= secure/lib/libssh
922 secure/lib/libssh__L: secure/lib/libcrypto__L lib/libz__L
925 _generic_libs+= secure/lib
928 _generic_libs+= usr.bin/lex/lib
930 .for _lib in ${_startup_libs2} ${_startup_libs3} ${_startup_libs34} \
931 ${_startup_libs} ${_prebuild_libs} ${_generic_libs}
933 .if exists(${.CURDIR}/${_lib})
934 ${ECHODIR} "===> ${_lib}"; \
935 cd ${.CURDIR}/${_lib}; \
936 ${MAKE} DIRPRFX=${_lib}/ depend; \
937 ${MAKE} DIRPRFX=${_lib}/ all; \
938 ${MAKE} DIRPRFX=${_lib}/ install
942 _startup_libs: ${_startup_libs:S/$/__L/}
943 _startup_libs34: ${_startup_libs34:S/$/__L/}
944 _prebuild_libs: ${_prebuild_libs:S/$/__L/}
945 _generic_libs: ${_generic_libs:S/$/__L/}
947 # library targets must be ordered because there are inter-library
948 # races (e.g. generation of tconfig.h)
950 .ORDER: ${_startup_libs34:S/$/__L/}
951 .ORDER: ${_startup_libs:S/$/__L/}
952 .ORDER: ${_prebuild_libs:S/$/__L/}
953 .ORDER: ${_generic_libs:S/$/__L/}
955 .for __target in clean cleandepend cleandir obj depend includes
956 .for entry in ${SUBDIR}
957 ${entry}.${__target}__D: .PHONY
958 @if test -d ${.CURDIR}/${entry}.${MACHINE_ARCH}; then \
959 ${ECHODIR} "===> ${DIRPRFX}${entry}.${MACHINE_ARCH}"; \
960 edir=${entry}.${MACHINE_ARCH}; \
961 cd ${.CURDIR}/$${edir}; \
963 ${ECHODIR} "===> ${DIRPRFX}${entry}"; \
965 cd ${.CURDIR}/$${edir}; \
967 ${MAKE} ${__target} DIRPRFX=${DIRPRFX}$${edir}/
969 par-${__target}: ${SUBDIR:S/$/.${__target}__D/}
970 .ORDER: ${SUBDIR:S/$/.${__target}__D/}
972 .ORDER: par-clean par-cleandepend par-cleandir par-obj par-depend par-includes
974 # The wmake target is used by /usr/bin/wmake to run make in a
975 # world build environment.
978 @echo '${WMAKEENV} ${MAKE} -m ${.CURDIR}/share/mk ${WMAKE_ARGS}'
981 @echo '${WMAKEENV} /bin/sh'
984 @echo '${BMAKEENV} ${MAKE} -m ${.CURDIR}/share/mk ${BMAKE_ARGS}'
987 @echo '${BMAKEENV} /bin/sh'
990 @echo '${TMAKEENV} ${MAKE} -m ${.CURDIR}/share/mk ${TMAKE_ARGS}'
993 @echo '${TMAKEENV} /bin/sh'
995 .include <bsd.subdir.mk>