#!/bin/bash # Copyright 2008, 2009, 2010, 2011, 2012, 2013, 2015, 2017, 2018, 2020, 2021, 2022, 2023, 2024, 2025 Patrick J. Volkerding, Sebeka, MN, USA # All rights reserved. # # Redistribution and use of this script, with or without modification, is # permitted provided that the following conditions are met: # # 1. Redistributions of this script must retain the above copyright # notice, this list of conditions and the following disclaimer. # # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED # WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF # MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO # EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; # OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, # WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR # OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # Slackware build script for util-linux cd $(dirname $0) ; CWD=$(pwd) PKGNAM=util-linux VERSION=${VERSION:-$(echo util-linux*.tar.xz | cut -d - -f 3 | rev | cut -f 3- -d . | rev)} BUILD=${BUILD:-1} ADJTIMEXVERS=1.29 SETSERIALVERS=2.17 ZIPTOOLVERS=1.4.0 NUMJOBS=${NUMJOBS:-" -j$(expr $(nproc) + 1) "} # Automatically determine the architecture we're building on: if [ -z "$ARCH" ]; then case "$( uname -m )" in i?86) export ARCH=i686 ;; arm*) export ARCH=arm ;; # Unless $ARCH is already set, use uname -m for all other archs: *) export ARCH=$( uname -m ) ;; esac fi # If the variable PRINT_PACKAGE_NAME is set, then this script will report what # the name of the created package would be, and then exit. This information # could be useful to other scripts. if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then echo "$PKGNAM-$VERSION-$ARCH-$BUILD.txz" exit 0 fi if [ "$ARCH" = "i686" ]; then SLKCFLAGS="-O2 -march=pentium4 -mtune=generic" LIBDIRSUFFIX="" elif [ "$ARCH" = "x86_64" ]; then SLKCFLAGS="-O2 -march=x86-64 -mtune=generic -fPIC" LIBDIRSUFFIX="64" else SLKCFLAGS="-O2" LIBDIRSUFFIX="" fi TMP=${TMP:-/tmp} PKG=$TMP/package-util-linux rm -rf $PKG mkdir -p $TMP $PKG cd $TMP || exit 1 rm -rf util-linux-$VERSION tar xvf $CWD/util-linux-$VERSION.tar.xz || exit 1 cd util-linux-$VERSION || exit 1 chown -R root.root . find . \ \( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \ -exec chmod 755 {} \+ -o \ \( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \ -exec chmod 644 {} \+ # Choose correct options depending on whether PAM is installed: if [ -L /lib${LIBDIRSUFFIX}/libpam.so.? ]; then LOGIN_OPTIONS="" # By default, don't use the util-linux version of /bin/su: SHIP_SU=${SHIP_SU:-NO} # Add /etc/pam.d config files: rm -rf $PKG/etc/pam.d mkdir -p $PKG/etc/pam.d for file in $CWD/pam.d/* ; do cp -a ${file} $PKG/etc/pam.d/ done # In case someone is using the '-h' option to /bin/login, we will require # another copy of /etc/pam.d/login called /etc/pam.d/remote. Make this copy # if it doesn't exist already: if [ ! -r $PKG/etc/pam.d/remote ]; then cp -a $PKG/etc/pam.d/login $PKG/etc/pam.d/remote fi if [ "$SHIP_SU" = "YES" ]; then # Add su default file to ensure using ENV_SUPATH with 'su': mkdir -p $PKG/etc/default cp -a $CWD/su.default $PKG/etc/default/su.new chown root:root $PKG/etc/default/su.new chmod 644 $PKG/etc/default/su.new # Add su /etc/pam.d files: cp -a $CWD/pam.d-su/* $PKG/etc/pam.d/ fi # Ensure correct perms/ownership on files in /etc/pam.d/: chown root:root $PKG/etc/pam.d/* chmod 644 $PKG/etc/pam.d/* # Don't clobber existing config files: find $PKG/etc/pam.d -type f -exec mv {} {}.new \; else # Don't use the util-linux version of /bin/su. # It can't be built without PAM anyway. SHIP_SU=NO LOGIN_OPTIONS="--disable-login" fi # Put any PAM modules in the proper directory: sed -i "s|securelib_execdir='\${libdir}/security'|securelib_execdir='/lib${LIBDIRSUFFIX}/security'|g" configure # Changing the fdisk -l output (this was done prior to util-linux-ng) broke # our installation scripts, so we have changed the name of partition type # 83 back to "Linux swap": zcat $CWD/util-linux.fdisk-no-solaris.diff.gz | patch -p1 --verbose || exit 1 # Revert to the behavior of earlier versions of fdisk which did not list the # /dev/ram* devices in 'fdisk -l' output: zcat $CWD/util-linux.do.not.list.ram.devices.diff.gz | patch -p1 --verbose || exit 1 CFLAGS="$SLKCFLAGS" \ ./configure \ --prefix=/usr \ --libdir=/usr/lib${LIBDIRSUFFIX} \ --sysconfdir=/etc \ --localstatedir=/var \ --mandir=/usr/man \ --infodir=/usr/info \ --docdir=/usr/doc/util-linux-$VERSION \ --disable-static \ --enable-agetty \ --enable-fdformat \ --enable-kill \ --disable-last \ --enable-line \ --enable-mesg \ --enable-partx \ --enable-pg \ --disable-raw \ --enable-rename \ $LOGIN_OPTIONS \ --enable-schedutils \ --enable-wall \ --enable-write \ --enable-use-tty-group \ --enable-libblkid \ --enable-libmount \ --disable-libmount-mountfd-support \ --enable-libuuid \ --disable-uuidd \ --with-python=3 \ --build=$ARCH-slackware-linux || exit 1 make $NUMJOBS || make || exit 1 make install $NUMJOBS DESTDIR=$PKG || exit 1 # These need to be setuid root to work properly (only built for PAM): if [ -r $PKG/usr/bin/chfn ]; then chmod 4711 $PKG/usr/bin/chfn fi if [ -r $PKG/usr/bin/chsh ]; then chmod 4711 $PKG/usr/bin/chsh fi # Remove all overlap with the shadow package, since --disable-login doesn't quite do that: rm $PKG/sbin/nologin $PKG/usr/man/man8/nologin.8 $PKG/sbin/sulogin $PKG/usr/man/man8/sulogin.8 # If we aren't shipping su, remove the files: if [ "$SHIP_SU" = "NO" ]; then rm -f $PKG/bin/su rm -f $PKG/usr/man/man1/su.1 rm -f $PKG/usr/share/bash-completion/completions/runuser rm -f $PKG/usr/share/bash-completion/completions/su fi # Move the libblkid, libfdisk, libmount, libsmartcols, and # libuuid libraries to /lib${LIBSUFFIX}: mkdir -p $PKG/lib${LIBDIRSUFFIX} ( cd $PKG/usr/lib${LIBDIRSUFFIX} mv libblkid.so.1* $PKG/lib${LIBDIRSUFFIX} mv libfdisk.so.1* $PKG/lib${LIBDIRSUFFIX} mv libmount.so.1* $PKG/lib${LIBDIRSUFFIX} mv libsmartcols.so.1* $PKG/lib${LIBDIRSUFFIX} mv libuuid.so.1* $PKG/lib${LIBDIRSUFFIX} rm -f libblkid.so libfdisk.so libmount.so libsmartcols.so libuuid.so ln -sf ../../lib${LIBDIRSUFFIX}/libblkid.so.1 libblkid.so ln -sf ../../lib${LIBDIRSUFFIX}/libfdisk.so.1 libfdisk.so ln -sf ../../lib${LIBDIRSUFFIX}/libmount.so.1 libmount.so ln -sf ../../lib${LIBDIRSUFFIX}/libsmartcols.so.1 libsmartcols.so ln -sf ../../lib${LIBDIRSUFFIX}/libuuid.so.1 libuuid.so ) # Moving things around that have been in the same place # for 15 years is, IMHO, not a wise idea AT ALL. # If this had to be moved, some place out of /usr might # have shown a grain of insight... if [ -r $PKG/usr/sbin/fdformat ]; then mkdir -p $PKG/usr/bin mv $PKG/usr/sbin/fdformat $PKG/usr/bin/fdformat # Now since stuff will start looking in this new place, # we have no choice but to link these: ( cd $PKG/usr/sbin ln -sf ../bin/fdformat . ) fi # Add the rc.setterm init script to set default terminal attributes: mkdir -p $PKG/etc/rc.d cp -a $CWD/rc.setterm $PKG/etc/rc.d/rc.setterm.new chown root:root $PKG/etc/rc.d/rc.setterm.new chmod 755 $PKG/etc/rc.d/rc.setterm.new # ddate.{1,c} taken from https://github.com/bo0ts/ddate: cp -a $CWD/ddate.? . cc -O -o ddate ddate.c cp -a ddate $PKG/usr/bin cat ddate.1 > $PKG/usr/man/man1/ddate.1 chown root:root $PKG/usr/bin/ddate # Build ziptool (install as jaztool to avoid conflict with libzip): cd $TMP || exit 1 rm -rf ziptool-$ZIPTOOLVERS tar xvf $CWD/ziptool-$ZIPTOOLVERS.tar.xz || exit 1 cd ziptool-$ZIPTOOLVERS || exit 1 zcat $CWD/ziptool-fix_build.patch.gz | patch -p1 || exit 1 mkdir scsi cat $CWD/scsi_ioctl.h > scsi/scsi_ioctl.h chown -R root:root . make || exit 1 strip ziptool cat ziptool > $PKG/sbin/jaztool chmod 0755 $PKG/sbin/jaztool mkdir -p $PKG/usr/doc/ziptool-$ZIPTOOLVERS cp -a README $PKG/usr/doc/ziptool-$ZIPTOOLVERS chmod 644 $PKG/usr/doc/ziptool-$ZIPTOOLVERS/* cat ziptool.1.gz > $PKG/usr/man/man1/jaztool.1.gz # Build bsdstrings cd $TMP || exit 1 rm -rf bsdstrings tar xvf $CWD/bsdstrings.tar.gz || exit 1 cd bsdstrings || exit 1 zcat $CWD/bsdstrings-util-linux_overflow.diff.gz | patch -p1 --verbose || exit 1 zcat $CWD/bsdstrings.gcc14.diff.gz | patch -p1 --verbose || exit 1 make || exit 1 strip strings cat strings > $PKG/usr/bin/strings-BSD chmod 0755 $PKG/usr/bin/strings-BSD cat strings.1 | gzip -9c > $PKG/usr/man/man1/strings-BSD.1.gz # Build adjtimex cd $TMP || exit 1 rm -rf adjtimex-$ADJTIMEXVERS tar xvf $CWD/adjtimex_${ADJTIMEXVERS}.orig.tar.gz || exit 1 cd adjtimex-$ADJTIMEXVERS || exit 1 chown -R root:root . zcat $CWD/adjtimex_1.29-2.2.diff.gz | patch -p1 || exit 1 CFLAGS=-O2 ./configure --prefix=/usr || exit 1 make || exit 1 strip adjtimex cat adjtimex > $PKG/sbin/adjtimex chmod 0755 $PKG/sbin/adjtimex cat adjtimex.8 | gzip -9c > $PKG/usr/man/man8/adjtimex.8.gz mkdir -p $PKG/usr/doc/adjtimex-$ADJTIMEXVERS cp -a COPYING COPYRIGHT README README.ru adjtimex.lsm \ $PKG/usr/doc/adjtimex-$ADJTIMEXVERS # Build setserial cd $TMP || exit 1 rm -rf setserial-$SETSERIALVERS tar xvf $CWD/setserial-$SETSERIALVERS.tar.gz || exit 1 cd setserial-$SETSERIALVERS || exit 1 chown -R root:root . zcat $CWD/setserial-rc.serial.diff.gz | patch -E -p1 --verbose || exit 1 zcat $CWD/setserial-undef_TIOCGHAYESESP.diff.gz | patch -E -p1 --verbose || exit 1 # The original config.{guess,sub} do not work on x86_64 cp -p /usr/share/libtool/build-aux/config.{guess,sub} . CFLAGS="$SLKCFLAGS -Wno-error=implicit-int -Wno-error=implicit-function-declaration" \ ./configure --prefix=/usr || exit 1 make || exit 1 strip setserial cat setserial > $PKG/sbin/setserial chmod 0755 $PKG/sbin/setserial mkdir -p $PKG/etc/rc.d cat rc.serial > $PKG/etc/rc.d/rc.serial.new cat serial.conf > $PKG/etc/serial.conf.new cat setserial.8 | gzip -9c > $PKG/usr/man/man8/setserial.8.gz # Build seedrng, a utility for seeding the kernel random number generator: cc -O2 -std=gnu99 $CWD/seedrng.c -o $PKG/usr/sbin/seedrng zcat $CWD/seedrng.8.gz > $PKG/usr/man/man8/seedrng.8 # These have always traditionally been available before /usr # might be mounted: ( cd $PKG/usr/bin mv getopt setterm $PKG/bin cd $PKG/usr/bin ln -s ../../bin/getopt . ln -s ../../bin/setterm . ) cd $TMP/util-linux-$VERSION # Go back home :) # Now let's add some important symlinks :) ( cd $PKG/sbin ln -s ../bin/mount . ln -s ../bin/umount . #ln -s ziptool jaztool ln -s hwclock clock cd $PKG/usr/sbin ln -s ../../sbin/cfdisk . ln -s ../../sbin/ctrlaltdel . ln -s ../../sbin/sfdisk . cd $PKG/usr/bin ln -s ../sbin/readprofile . # tunelp was removed by upstream: #ln -s ../sbin/tunelp . ln -s ../../bin/more . cd $PKG/usr/man/man1 #ln -s ziptool.1 jaztool.1 cd $PKG/usr/man/man8 ln -s hwclock.8 clock.8 ) find $PKG | xargs file | grep -e "executable" -e "shared object" \ | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null # Don't ship .la files: rm -f $PKG/{,usr/}lib${LIBDIRSUFFIX}/*.la # Compress and if needed symlink the man pages: if [ -d $PKG/usr/man ]; then ( cd $PKG/usr/man for manpagedir in $(find . -type d -name "man*") ; do ( cd $manpagedir for eachpage in $( find . -type l -maxdepth 1) ; do ln -s $( readlink $eachpage ).gz $eachpage.gz rm $eachpage done gzip -9 *.? ) done ) fi # Compress info page and remove dir file rm $PKG/usr/info/dir gzip -9 $PKG/usr/info/* mkdir -p $PKG/usr/doc/util-linux-$VERSION cp -a AUTHORS COPYING* DEPRECATED NEWS README* \ Documentation/releases/v${VERSION}-ReleaseNotes \ Documentation/licenses/* Documentation/{TODO,*.txt} \ $PKG/usr/doc/util-linux-$VERSION mkdir $PKG/install cat $CWD/slack-desc > $PKG/install/slack-desc zcat $CWD/doinst.sh.gz > $PKG/install/doinst.sh cd $PKG /sbin/makepkg -l y -c n $TMP/util-linux-$VERSION-$ARCH-$BUILD.txz