polling.4: Add ix(4)
[dragonfly.git] / Makefile.inc1
index 198d336..860362c 100644 (file)
 # realquickworld - skip the glue and depend stages and just build the meat
 # crossworld  - only build the glue (particularly the cross-build environment)
 # installworld- install everything built by "buildworld"
+# backupworld - copies /bin /sbin /usr/bin /usr/sbin /usr/lib /usr/libexec
+#               to manual backup dir
+# restoreworld- installs binaries from manual backup dir to world
+# restoreworld-auto - installs binaries from auto-backup dir to world
 # most        - build user commands, no libraries or include files
 # installmost - install user commands, no libraries or include files
+# backup-clean - delete backup from manual backup dir
+# backup-auto-clean - delete backup from auto-backup dir
 #
 # Standard targets (not defined here) are documented in the makefiles in
 # /usr/share/mk.  These include:
 # Put initial settings here.
 SUBDIR=
 
+# /libexec/ld-elf.so.2 needs to be installed first
+# Otherwise, install(1) beeing a dynamically linked binary will fail
+# during the first upgrade from a static to a dynamic world
+.if exists(${.CURDIR}/libexec)
+SUBDIR+= libexec
+.endif
+
 # We must do share/info early so that installation of info `dir'
 # entries works correctly.  Do it first since it is less likely to
 # grow dependencies on include and lib than vice versa.
@@ -52,9 +65,6 @@ SUBDIR+= games
 .if exists(${.CURDIR}/gnu)
 SUBDIR+= gnu
 .endif
-.if exists(${.CURDIR}/libexec)
-SUBDIR+= libexec
-.endif
 .if exists(${.CURDIR}/sbin)
 SUBDIR+= sbin
 .endif
@@ -112,7 +122,7 @@ OBJTREE?=           ${MAKEOBJDIRPREFIX}
 
 # Used for stage installs and pathing
 #
-DESTDIRBASE?=          ${OBJTREE}${.CURDIR}
+DESTDIRBASE:=          ${OBJTREE}${.CURDIR}
 
 # Remove DESTDIR from MAKEFLAGS.  It is present in the environment
 # anyhow, and we need to be able to override it for stage installs
@@ -121,18 +131,12 @@ DESTDIRBASE?=             ${OBJTREE}${.CURDIR}
 # This section sets the tools used to build the world/kernel
 WORLD_CCVER?=          gcc47
 WORLD_LDVER?=          ld.bfd
-WORLD_BINUTILSVER?=    binutils222
+WORLD_BINUTILSVER?=    binutils224
 
-# temporary until everybody has converted to x86_64
-.if ${MACHINE_ARCH} == "amd64"
-MACHINE_ARCH=  x86_64
-.if defined(.PARSEDIR)
-.export MACHINE_ARCH
-.else
-# LEGACY MAKE - REMOVE FOR DFLY 3.6
-.makeenv MACHINE_ARCH
-.endif
-.endif
+# Set the backup parameters if they are not already defined
+#
+WORLD_BACKUP?=         /var/backups/world_backup
+AUTO_BACKUP?=          ${OBJTREE}/world_backup/${DESTDIR}
 
 TARGET_ARCH?=  ${MACHINE_ARCH}
 .if ${TARGET_ARCH} == ${MACHINE_ARCH}
@@ -211,7 +215,7 @@ BTOOLSPATH= ${BTOOLSDEST}/usr/sbin:${BTOOLSDEST}/usr/bin:${BTOOLSDEST}/bin:${BTO
 # The strict temporary command path contains all binaries required
 # by the buildworld system after the cross-tools stage.
 #
-STRICTTMPPATH= ${CTOOLSDEST}/usr/sbin:${CTOOLSDEST}/usr/bin:${CTOOLSDEST}/bin:${CTOOLSDEST}/usr/games:${BTOOLSDEST}/usr/sbin:${BTOOLSDEST}/usr/bin:${BTOOLSDEST}/bin:${BTOOLSDEST}/usr/games:/usr/pkg/bin
+STRICTTMPPATH= ${CTOOLSDEST}/usr/sbin:${CTOOLSDEST}/usr/bin:${CTOOLSDEST}/bin:${CTOOLSDEST}/usr/games:${BTOOLSDEST}/usr/sbin:${BTOOLSDEST}/usr/bin:${BTOOLSDEST}/bin:${BTOOLSDEST}/usr/games:/usr/local/bin:/usr/pkg/bin
 
 TMPDIR?=       /tmp
 TMPPID!=       echo $$$$
@@ -282,6 +286,7 @@ TMAKE=              ${TMAKEENV} make -f Makefile.inc1 -DBOOTSTRAPPING \
 XMAKEENV=      MAKEOBJDIRPREFIX=${CTOOLSDEST} \
                OBJTREE=${OBJTREE} \
                DESTDIR=${CTOOLSDEST} \
+               _SHLIBDIRPREFIX=${CTOOLSDEST} \
                INSTALL="sh ${.CURDIR}/tools/install.sh" \
                TOOLS_PREFIX=${CTOOLSDEST} \
                USRDATA_PREFIX=${WORLDDEST} \
@@ -311,6 +316,7 @@ CROSSENV=   MAKEOBJDIRPREFIX=${WORLDDEST} \
 
 WMAKEENV=      ${CROSSENV} \
                DESTDIR=${WORLDDEST} \
+               _SHLIBDIRPREFIX=${WORLDDEST} \
                INSTALL="sh ${.CURDIR}/tools/install.sh" \
                M4=${BTOOLSDEST}/usr/bin/m4 \
                PATH=${STRICTTMPPATH}
@@ -446,6 +452,7 @@ crossworld: _worldtmp _bootstrap-tools _obj _build-tools _cross-tools
 .ORDER: ${WMAKE_TGTS}
 .ORDER: _obj _includes
 .ORDER: _mtreetmp _obj
+.ORDER: installcheck backupworld-auto
 
 #
 # installcheck
@@ -463,14 +470,23 @@ installcheck:
 .if !defined(DESTDIR) || ${DESTDIR} == "" || ${DESTDIR} == "/"
        @case `uname -r` in 1.2*|1.3-*|1.3.*|1.4.*|1.5.0-*|1.5.1-*|1.5.2-*|1.5.3-*) echo "You must upgrade your kernel to at least 1.5.4 and reboot before you can safely installworld, due to libc/system call ABI changes" ; /usr/bin/false ; esac
 .endif
+
 #
 # installworld
 #
+# Backs up the current world if ${AUTO_BACKUP} is writable.
 # Installs everything compiled by a 'buildworld'.
-#
+
 installworld: installcheck
+       -@mkdir -p ${AUTO_BACKUP} > /dev/null 2>&1
+       @cd ${.CURDIR}; \
+           (touch ${AUTO_BACKUP}/.updating > /dev/null 2>&1 && \
+            ${IMAKE} backupworld-auto) || \
+           echo "Cannot write to ${AUTO_BACKUP} - world not backed up"
+
        cd ${.CURDIR}; ${IMAKE} re${.TARGET:S/world$//}
        ${INSTALL} -o root -g wheel -m 644 ${.CURDIR}/Makefile_upgrade.inc ${DESTDIR}/etc/upgrade/
+       mkinitrd -b ${DESTDIR}/boot
 
 #
 # reinstall
@@ -804,7 +820,8 @@ BSTRAPDIRS2= \
        usr.sbin/chown usr.sbin/mtree usr.sbin/config \
        usr.sbin/btxld usr.sbin/zic usr.sbin/makewhatis \
        gnu/usr.bin/texinfo gnu/usr.bin/grep usr.bin/sort \
-       usr.bin/gzip usr.bin/bzip2 usr.bin/mkcsmapper usr.bin/mkesdb
+       usr.bin/gzip usr.bin/bzip2 usr.bin/mkcsmapper usr.bin/mkesdb \
+       usr.bin/crunch
 
 bootstrap-tools: bootstrap-tools-before bootstrap-tools-targets1 bootstrap-tools-targets2
        touch ${BTOOLSDEST}/.bootstrap_done
@@ -876,7 +893,9 @@ btools-${_tool}!
 _btxld=        usr.sbin/btxld
 .endif
 
-CTOOLSDIRS= ${_btxld} ${_binutils} usr.bin/objformat ${_gcc_common_cross} \
+CTOOLSDIRS= ${_btxld} ${_binutils} \
+               usr.bin/objformat usr.bin/crunch/crunchide \
+               ${_gcc_common_cross} \
                ${_gcc44_cross} ${_gcc47_cross} ${_custom_cross}
 
 cross-tools: cross-tools-targets
@@ -949,10 +968,7 @@ _prebuild_libs+=   lib/libutil
 _generic_libs= gnu/lib
 
 _prebuild_libs+= lib/libcom_err lib/libcrypt lib/libmd \
-               lib/libncurses/libncurses lib/libopie lib/libradius \
-               lib/libsbuf lib/libtacplus lib/libm \
-               lib/libpam lib/libypclnt lib/lib${THREAD_LIB} \
-               lib/libpthread lib/libprop lib/libdevattr
+               lib/libncurses/libncurses lib/libopie
 
 lib/libopie__L lib/libradius__L lib/libtacplus__L: lib/libmd__L
 
@@ -969,6 +985,10 @@ secure/lib/libssh__L: secure/lib/libcrypto__L lib/libz__L
 _generic_libs+=        secure/lib
 .endif
 
+_prebuild_libs+= lib/libradius lib/libsbuf lib/libtacplus lib/libm \
+               lib/libpam lib/libypclnt lib/lib${THREAD_LIB} \
+               lib/libpthread lib/libprop lib/libdevattr
+
 _generic_libs+=        usr.bin/flex/lib
 
 .for _lib in ${_startup_libs44} ${_startup_libs47} \
@@ -1044,21 +1064,68 @@ xmake:
 xmakeenv:
        @echo '${XMAKEENV} /bin/sh'
 
+backupworld: backup-clean
+       @mkdir -p ${WORLD_BACKUP}
+.if (exists(${DESTDIR}/sbin) && exists(${DESTDIR}/bin) && \
+     exists(${DESTDIR}/usr/sbin) && exists(${DESTDIR}/usr/bin) && \
+     exists(${DESTDIR}/usr/lib) && exists(${DESTDIR}/usr/libexec))
+       tar -czf ${WORLD_BACKUP}/binaries.tar.gz -C ${DESTDIR}/ \
+               --options gzip:compression-level=1 \
+               sbin bin usr/sbin usr/bin usr/lib usr/libexec
+.endif
+
+backupworld-auto:
+.if !defined(NO_BACKUP)
+       rm -f ${AUTO_BACKUP}/binaries.tar.gz
+       @mkdir -p ${AUTO_BACKUP}
+.if (exists(${DESTDIR}/sbin) && exists(${DESTDIR}/bin) && \
+     exists(${DESTDIR}/usr/sbin) && exists(${DESTDIR}/usr/bin) && \
+     exists(${DESTDIR}/usr/lib) && exists(${DESTDIR}/usr/libexec))
+       tar -czf ${AUTO_BACKUP}/binaries.tar.gz -C ${DESTDIR}/ \
+               --options gzip:compression-level=1 \
+               sbin bin usr/sbin usr/bin usr/lib usr/libexec
+.endif
+.endif
+
+backup-auto-clean:
+       rm -f ${AUTO_BACKUP}/binaries.tar.gz
+
+backup-clean:
+       rm -f ${WORLD_BACKUP}/binaries.tar.gz
+
+restoreworld:
+.if !exists(${WORLD_BACKUP}/binaries.tar.gz)
+       @echo "There does not seem to be a valid archive present."
+.else
+       @echo "Restoring system binaries from manual backup archive..."
+       @chflags -R noschg ${DESTDIR}/sbin ${DESTDIR}/bin \
+               ${DESTDIR}/usr/sbin ${DESTDIR}/usr/bin \
+               ${DESTDIR}/usr/lib ${DESTDIR}/usr/libexec
+       tar -xzf ${WORLD_BACKUP}/binaries.tar.gz -C ${DESTDIR}/
+.endif
+
+restoreworld-auto:
+.if !exists(${AUTO_BACKUP}/binaries.tar.gz)
+       @echo "There does not seem to be a valid archive present."
+.else
+       @echo "Restoring system binaries from auto-backup archive..."
+       @chflags -R noschg ${DESTDIR}/sbin ${DESTDIR}/bin \
+               ${DESTDIR}/usr/sbin ${DESTDIR}/usr/bin \
+               ${DESTDIR}/usr/lib ${DESTDIR}/usr/libexec
+       tar -xzf ${AUTO_BACKUP}/binaries.tar.gz -C ${DESTDIR}/
+.endif
+
 # Take advantage of bmake error response
 #
 MAKE_PRINT_VAR_ON_ERROR= \
        .CURDIR \
        .OBJDIR \
-       .MAKE \
-       MAKE_VERSION \
        LD_LIBRARY_PATH \
        MACHINE_ARCH \
        MACHINE \
        MAKEFILE \
        .TARGETS \
        .ERROR_TARGET \
-       .ERROR_META_FILE \
-       .MAKE.LEVEL \
-       .MAKE.MODE
+       .MAKE.LEVEL
 
 .include <bsd.subdir.mk>