Radix cross Linux

The main Radix cross Linux repository contains the build scripts of packages, which have the most complete and common functionality for desktop machines

452 Commits   2 Branches   1 Tag
Index: Makefile
===================================================================
--- Makefile	(nonexistent)
+++ Makefile	(revision 5)
@@ -0,0 +1,535 @@
+
+COMPONENT_TARGETS  = $(HARDWARE_INTEL_PC32)
+COMPONENT_TARGETS += $(HARDWARE_INTEL_PC64)
+COMPONENT_TARGETS += $(HARDWARE_EBOX_3350DX2)
+COMPONENT_TARGETS += $(HARDWARE_CB1X)
+COMPONENT_TARGETS += $(HARDWARE_CB2X)
+COMPONENT_TARGETS += $(HARDWARE_CB3X)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP2E)
+COMPONENT_TARGETS += $(HARDWARE_NANOPI_NEO)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PL2)
+COMPONENT_TARGETS += $(HARDWARE_WECHIP_TX6)
+COMPONENT_TARGETS += $(HARDWARE_FFRK3288)
+COMPONENT_TARGETS += $(HARDWARE_POIN2)
+COMPONENT_TARGETS += $(HARDWARE_RK3328_CC)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_EDGE)
+COMPONENT_TARGETS += $(HARDWARE_LEEZ_P710)
+COMPONENT_TARGETS += $(HARDWARE_M201)
+COMPONENT_TARGETS += $(HARDWARE_MXV)
+COMPONENT_TARGETS += $(HARDWARE_P201)
+COMPONENT_TARGETS += $(HARDWARE_NEXBOX_A95X)
+COMPONENT_TARGETS += $(HARDWARE_ODROID_C2)
+COMPONENT_TARGETS += $(HARDWARE_P212)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM)
+COMPONENT_TARGETS += $(HARDWARE_Q201)
+COMPONENT_TARGETS += $(HARDWARE_ENYBOX_X2)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM2)
+COMPONENT_TARGETS += $(HARDWARE_NIT6Q)
+COMPONENT_TARGETS += $(HARDWARE_OKMX6DL_C)
+COMPONENT_TARGETS += $(HARDWARE_OKMX6Q_C)
+COMPONENT_TARGETS += $(HARDWARE_BONE_BLACK)
+COMPONENT_TARGETS += $(HARDWARE_OMAP5UEVM)
+COMPONENT_TARGETS += $(HARDWARE_DRA7XXEVM)
+COMPONENT_TARGETS += $(HARDWARE_CI20)
+COMPONENT_TARGETS += $(HARDWARE_BAIKAL_T1)
+COMPONENT_TARGETS += $(HARDWARE_BAIKAL_M1)
+COMPONENT_TARGETS += $(HARDWARE_S824L)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN)
+COMPONENT_TARGETS += $(HARDWARE_S824L_LSB)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN_LSB)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2_LSB)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2_LSB)
+COMPONENT_TARGETS += $(HARDWARE_SIFIVE_U740)
+
+
+NEED_ABS_PATH      = true
+COMPONENT_IS_3PP   = true
+
+
+include ../../../build-system/constants.mk
+
+
+SOURCE_REQUIRES    = sources/packages/a/util-linux
+SOURCE_REQUIRES   += sources/packages/a/adjtimex
+SOURCE_REQUIRES   += sources/packages/a/bsdstrings
+SOURCE_REQUIRES   += sources/packages/n/net-tools
+SOURCE_REQUIRES   += sources/packages/a/setserial
+SOURCE_REQUIRES   += sources/packages/a/ziptool
+
+
+REQUIRES           = libs/libcap-ng/0.8.2
+REQUIRES          += secure/pam/1.5.1
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version             = 2.38.1
+tar_xz_archive      = $(SRC_PACKAGE_PATH)/packages/a/util-linux/util-linux-$(version).tar.xz
+SRC_ARCHIVE         = $(tar_xz_archive)
+SRC_DIR             = $(TARGET_BUILD_DIR)/util-linux-$(version)
+src_dir_name        = util-linux-$(version)
+src_done            = $(TARGET_BUILD_DIR)/.source-done
+
+adjtimex_version    = 1.29
+adjtimex_archive    = $(SRC_PACKAGE_PATH)/packages/a/adjtimex/adjtimex-$(adjtimex_version).tar.xz
+ADJTIMEX_SRC_DIR    = $(TARGET_BUILD_DIR)/adjtimex-$(adjtimex_version)
+adjtimex_src_done   = $(TARGET_BUILD_DIR)/.adjtimex-source-done
+
+bsdstrings_archive  = $(SRC_PACKAGE_PATH)/packages/a/bsdstrings/bsdstrings.tar.gz
+BSDSTRINGS_SRC_DIR  = $(TARGET_BUILD_DIR)/bsdstrings
+bsdstrings_src_done = $(TARGET_BUILD_DIR)/.bsdstrings-source-done
+
+nettools_version    = 1.60-20210110
+nettools_archive    = $(SRC_PACKAGE_PATH)/packages/n/net-tools/net-tools-$(nettools_version).tar.bz2
+NETTOOLS_SRC_DIR    = $(TARGET_BUILD_DIR)/net-tools-$(nettools_version)
+nettools_src_done   = $(TARGET_BUILD_DIR)/.nettools-source-done
+
+setserial_version   = 2.17
+setserial_archive   = $(SRC_PACKAGE_PATH)/packages/a/setserial/setserial-$(setserial_version).tar.gz
+SETSERIAL_SRC_DIR   = $(TARGET_BUILD_DIR)/setserial-$(setserial_version)
+setserial_src_done  = $(TARGET_BUILD_DIR)/.setserial-source-done
+
+ziptool_version     = 1.4.0
+ziptool_archive     = $(SRC_PACKAGE_PATH)/packages/a/ziptool/ziptool-$(ziptool_version).tar.xz
+ZIPTOOL_SRC_DIR     = $(TARGET_BUILD_DIR)/ziptool-$(ziptool_version)
+ziptool_src_done    = $(TARGET_BUILD_DIR)/.ziptool-source-done
+
+PATCHES = PATCHES
+
+build_dir           = $(TARGET_BUILD_DIR)/build
+build_target        = $(TARGET_BUILD_DIR)/.build_done
+install_target      = $(TARGET_BUILD_DIR)/.install_done
+
+
+####### Targets
+
+PKG_GROUP = app
+
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+UTILLINUX_PKG_NAME                = util-linux
+UTILLINUX_PKG_VERSION             = 2.38.1
+UTILLINUX_PKG_ARCH                = $(PKGARCH)
+UTILLINUX_PKG_DISTRO_NAME         = $(DISTRO_NAME)
+UTILLINUX_PKG_DISTRO_VERSION      = $(DISTRO_VERSION)
+UTILLINUX_PKG_GROUP               = $(PKG_GROUP)
+###                                |---handy-ruler-------------------------------|
+UTILLINUX_PKG_SHORT_DESCRIPTION   = huge collection of essential utilities
+UTILLINUX_PKG_URL                 = $(BUG_URL)
+UTILLINUX_PKG_LICENSE             = GPLv2
+UTILLINUX_PKG_DESCRIPTION_FILE    = $(TARGET_BUILD_DIR)/$(UTILLINUX_PKG_NAME)-pkg-description
+UTILLINUX_PKG_DESCRIPTION_FILE_IN = $(UTILLINUX_PKG_NAME)-pkg-description.in
+UTILLINUX_PKG_INSTALL_SCRIPT      = $(UTILLINUX_PKG_NAME)-pkg-install.sh
+
+UTILLINUX_PKG    = $(CURDIR)/$(TARGET_BUILD_DIR)/$(UTILLINUX_PKG_NAME)-package
+
+pkg_basename     = $(UTILLINUX_PKG_NAME)-$(UTILLINUX_PKG_VERSION)-$(UTILLINUX_PKG_ARCH)-$(UTILLINUX_PKG_DISTRO_NAME)-$(UTILLINUX_PKG_DISTRO_VERSION)
+
+pkg_archive      = $(TARGET_BUILD_DIR)/$(PKG_GROUP)/$(pkg_basename).$(pkg_arch_suffix)
+pkg_certificate  = $(call cert-name,$(pkg_archive))
+pkg_signature    = $(call sign-name,$(pkg_archive))
+pkg_description  = $(call desc-name,$(pkg_archive))
+products         = $(call pkg-files,$(pkg_archive))
+
+BUILD_TARGETS    = $(build_target)
+BUILD_TARGETS   += $(install_target)
+
+PRODUCT_TARGETS  = $(products)
+
+ROOTFS_TARGETS   = $(pkg_archive)
+
+
+include ../../../build-system/core.mk
+
+
+env_sysroot = DESTDIR=$(UTILLINUX_PKG)
+
+
+extra_configure_switches  = --libdir=/lib$(LIBSUFFIX)
+extra_configure_switches += --docdir=/usr/share/doc/$(src_dir_name)
+extra_configure_switches += --infodir=/usr/share/info
+extra_configure_switches += --mandir=/usr/share/man
+extra_configure_switches += --disable-dependency-tracking
+extra_configure_switches += --sysconfdir=/etc
+extra_configure_switches += --localstatedir=/var
+extra_configure_switches += --with-ncursesw
+extra_configure_switches += --with-readline
+
+extra_configure_switches += --with-python=3
+
+extra_configure_switches += --enable-agetty
+extra_configure_switches += --enable-cramfs
+extra_configure_switches += --enable-fdformat
+extra_configure_switches += --enable-kill
+extra_configure_switches += --disable-last
+extra_configure_switches += --enable-libmount-support-mtab
+extra_configure_switches += --enable-line
+extra_configure_switches += --enable-mesg
+extra_configure_switches += --enable-partx
+extra_configure_switches += --enable-pg
+extra_configure_switches += --disable-raw
+extra_configure_switches += --enable-rename
+
+extra_configure_switches += --disable-nologin
+extra_configure_switches += --disable-sulogin
+extra_configure_switches += --disable-su
+
+extra_configure_switches += --enable-schedutils
+
+extra_configure_switches += --enable-wall
+extra_configure_switches += --enable-write
+extra_configure_switches += --enable-use-tty-group
+extra_configure_switches += --enable-makeinstall-chown=no
+
+extra_configure_switches += --enable-libblkid
+extra_configure_switches += --enable-libmount
+extra_configure_switches += --enable-libuuid
+extra_configure_switches += --disable-uuidd
+
+extra_configure_switches += --without-systemd
+extra_configure_switches += --without-systemdsystemunitdir
+
+ifneq ($(__ENABLE_STATIC__),yes)
+extra_configure_switches += --disable-static
+endif
+
+extra_configure_switches += NCURSESW6_CONFIG='$(TARGET_DEST_DIR)/usr/bin/ncursesw6-config'
+
+
+ziptool_environment     = CFLAGS="-isystem $(TARGET_DEST_DIR)/usr/include $(ARCH_FLAGS) $(OPTIMIZATION_FLAGS) -Wall"
+bsdstrings_environment  = CFLAGS="-isystem $(TARGET_DEST_DIR)/usr/include $(ARCH_FLAGS) $(OPTIMIZATION_FLAGS)"
+nettools_environment    = CFLAGS="-isystem $(TARGET_DEST_DIR)/usr/include $(ARCH_FLAGS) $(OPTIMIZATION_FLAGS) -Wall"
+
+
+PYTHON_VERSION      = 3.10
+
+python_environment  = PYTHON_VERSION=$(PYTHON_VERSION)
+python_environment += am_cv_python_pythondir=/usr/lib$(LIBSUFFIX)/python$(PYTHON_VERSION)/site-packages
+python_environment += am_cv_python_pyexecdir=/usr/lib$(LIBSUFFIX)/python$(PYTHON_VERSION)/site-packages
+
+
+TARGET_BIN_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX)
+
+
+####### Dependencies
+
+$(adjtimex_src_done): $(adjtimex_archive)
+	@echo "Expanding $(adjtimex_archive)"
+	@tar xJf $(adjtimex_archive) -C $(TARGET_BUILD_DIR)
+	@touch $@
+
+$(bsdstrings_src_done): $(bsdstrings_archive)
+	@echo "Expanding $(bsdstrings_archive)"
+	@tar xzf $(bsdstrings_archive) -C $(TARGET_BUILD_DIR)
+	@touch $@
+
+$(nettools_src_done): $(nettools_archive)
+	@echo "Expanding $(nettools_archive)"
+	@tar xjf $(nettools_archive) -C $(TARGET_BUILD_DIR)
+	@touch $@
+
+$(setserial_src_done): $(setserial_archive)
+	@echo "Expanding $(setserial_archive)"
+	@tar xzf $(setserial_archive) -C $(TARGET_BUILD_DIR)
+	@touch $@
+
+$(ziptool_src_done): $(ziptool_archive)
+	@echo "Expanding $(ziptool_archive)"
+	@tar xJf $(ziptool_archive) -C $(TARGET_BUILD_DIR)
+	@touch $@
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP) $(adjtimex_src_done) $(bsdstrings_src_done) $(nettools_src_done) $(setserial_src_done) $(ziptool_src_done)
+	$(UNPACK_SRC_ARCHIVE)
+	$(APPLY_PATCHES)
+	@( cd $(SRC_DIR) ; ./autogen.sh )
+	@touch $@
+
+$(build_target): $(src_done)
+	@mkdir -p $(build_dir)
+	@cd $(build_dir) && \
+	  $(BUILD_ENVIRONMENT) $(python_environment) ../$(src_dir_name)/configure \
+	  --prefix=/usr               \
+	  --build=$(BUILD)            \
+	  --host=$(TARGET)            \
+	  $(extra_configure_switches)
+	@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE) $(util_linux_environment)
+	@cd $(ZIPTOOL_SRC_DIR) && $(BUILD_ENVIRONMENT) $(ziptool_environment) $(MAKE)
+	@cd $(BSDSTRINGS_SRC_DIR) && $(BUILD_ENVIRONMENT) $(bsdstrings_environment) $(MAKE)
+	@cd $(NETTOOLS_SRC_DIR) && $(BUILD_ENVIRONMENT) $(nettools_environment) $(MAKE) hostname
+	@cd $(ADJTIMEX_SRC_DIR) && \
+	    $(BUILD_ENVIRONMENT) ./configure --prefix=/usr --build=$(BUILD) --host=$(TARGET)
+	@cd $(ADJTIMEX_SRC_DIR) && $(BUILD_ENVIRONMENT) $(MAKE)
+	@cd $(SETSERIAL_SRC_DIR) && \
+	    $(BUILD_ENVIRONMENT) ./configure --prefix=/usr --build=$(BUILD) --host=$(TARGET)
+	@cd $(SETSERIAL_SRC_DIR) && $(BUILD_ENVIRONMENT) $(MAKE)
+	@touch $@
+
+$(install_target): $(build_target)
+	@mkdir -p $(UTILLINUX_PKG)
+	@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 install $(env_sysroot)
+	@( cd $(UTILLINUX_PKG)/usr/lib$(LIBSUFFIX) ; \
+	   ln -sf ../../lib$(LIBSUFFIX)/lib*.so.1.* . ; \
+	   ln -sf libblkid.so.1.*     libblkid.so.1     ; \
+	   ln -sf libfdisk.so.1.*     libfdisk.so.1     ; \
+	   ln -sf libmount.so.1.*     libmount.so.1     ; \
+	   ln -sf libsmartcols.so.1.* libsmartcols.so.1 ; \
+	   ln -sf libuuid.so.1.*      libuuid.so.1      ; \
+	   rm -f lib*.so ; \
+	   ln -sf libblkid.so.1     libblkid.so     ; \
+	   ln -sf libfdisk.so.1     libfdisk.so     ; \
+	   ln -sf libmount.so.1     libmount.so     ; \
+	   ln -sf libsmartcols.so.1 libsmartcols.so ; \
+	   ln -sf libuuid.so.1      libuuid.so      ; \
+	 )
+	@if [ -r $(UTILLINUX_PKG)/usr/sbin/fdformat ] ; then \
+	   mkdir -p $(UTILLINUX_PKG)/usr/bin ; \
+	   mv $(UTILLINUX_PKG)/usr/sbin/fdformat $(UTILLINUX_PKG)/usr/bin/fdformat ; \
+	   ( cd $(UTILLINUX_PKG)/usr/sbin ; ln -sf ../bin/fdformat . ) ; \
+	 fi
+	@if [ -r $(UTILLINUX_PKG)/usr/bin/setterm ] ; then \
+	   mkdir -p $(UTILLINUX_PKG)/bin ; \
+	   mv $(UTILLINUX_PKG)/usr/bin/setterm $(UTILLINUX_PKG)/bin/setterm ; \
+	   ( cd $(UTILLINUX_PKG)/usr/bin ; ln -sf ../../bin/setterm . ) ; \
+	 fi
+	@if [ -r $(UTILLINUX_PKG)/usr/bin/getopt ] ; then \
+	   mkdir -p $(UTILLINUX_PKG)/bin ; \
+	   mv $(UTILLINUX_PKG)/usr/bin/getopt $(UTILLINUX_PKG)/bin/getopt ; \
+	   ( cd $(UTILLINUX_PKG)/usr/bin ; ln -sf ../../bin/getopt . ) ; \
+	 fi
+	# ======= Install ziptool-$(ziptool_version) =======
+	@mkdir -p $(UTILLINUX_PKG)/sbin
+	@cat $(ZIPTOOL_SRC_DIR)/ziptool > $(UTILLINUX_PKG)/sbin/jaztool
+	@chmod 0755 $(UTILLINUX_PKG)/sbin/jaztool
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/man/man1
+	@zcat $(ZIPTOOL_SRC_DIR)/ziptool.1.gz > $(UTILLINUX_PKG)/usr/share/man/man1/jaztool.1
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/doc/ziptool-$(ziptool_version)
+	@cp -a $(ZIPTOOL_SRC_DIR)/README $(UTILLINUX_PKG)/usr/share/doc/ziptool-$(ziptool_version)
+	@chmod 0644 $(UTILLINUX_PKG)/usr/share/doc/ziptool-$(ziptool_version)/README
+	# ======= Install bsdstrings =======
+	@mkdir -p $(UTILLINUX_PKG)/usr/bin
+	@cat $(BSDSTRINGS_SRC_DIR)/strings > $(UTILLINUX_PKG)/usr/bin/strings-BSD
+	@chmod 0755 $(UTILLINUX_PKG)/usr/bin/strings-BSD
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/man/man1
+	@cat $(BSDSTRINGS_SRC_DIR)/strings.1 > $(UTILLINUX_PKG)/usr/share/man/man1/strings-BSD.1
+	# ======= Install net-tools-$(nettools_version)/hostname =======
+	@mkdir -p $(UTILLINUX_PKG)/bin
+	@cat $(NETTOOLS_SRC_DIR)/hostname > $(UTILLINUX_PKG)/bin/hostname
+	@chmod 0755 $(UTILLINUX_PKG)/bin/hostname
+	@( cd $(UTILLINUX_PKG)/bin ; \
+	   ln -sf hostname dnsdomainname ; \
+	   ln -sf hostname nisdomainname ; \
+	   ln -sf hostname ypdomainname  ; \
+	   ln -sf hostname domainname    ; \
+	 )
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/man/man1
+	@( cd $(NETTOOLS_SRC_DIR)/man/en_US ; \
+	   for page in hostname.1 dnsdomainname.1 \
+	               nisdomainname.1 ypdomainname.1 domainname.1 ; do \
+	     cp -a $$page $(UTILLINUX_PKG)/usr/share/man/man1 ; \
+	   done \
+	 )
+	# ======= Install adjtimex-$(adjtimex_version) =======
+	@mkdir -p $(UTILLINUX_PKG)/sbin
+	@cat $(ADJTIMEX_SRC_DIR)/adjtimex > $(UTILLINUX_PKG)/sbin/adjtimex
+	@chmod 0755 $(UTILLINUX_PKG)/sbin/adjtimex
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/man/man8
+	@cat $(ADJTIMEX_SRC_DIR)/adjtimex.8 > $(UTILLINUX_PKG)/usr/share/man/man8/adjtimex.8
+	@mkdir -p $(UTILLINUX_PKG)/usr/doc/adjtimex-$(adjtimex_version)
+	@( cd $(ADJTIMEX_SRC_DIR) ; \
+	   cp -a COPYING COPYRIGHT $(UTILLINUX_PKG)/usr/doc/adjtimex-$(adjtimex_version) ; \
+	 )
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/doc/adjtimex-$(adjtimex_version)
+	@( cd $(ADJTIMEX_SRC_DIR) ; \
+	   iconv -f KOI8-R -t UTF-8 README.ru > README.utf8.ru ; \
+	 )
+	@( cd $(ADJTIMEX_SRC_DIR) ; \
+	   cp -a COPYING COPYRIGHT README README.utf8.ru $(UTILLINUX_PKG)/usr/share/doc/adjtimex-$(adjtimex_version) ; \
+	 )
+	@( cd $(ADJTIMEX_SRC_DIR) ; \
+	   if [ -r ChangeLog ]; then \
+	     DOCSDIR=`echo $(UTILLINUX_PKG)/usr/share/doc/adjtimex-$(adjtimex_version)` ; \
+	     cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
+	     touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
+	   fi \
+	 )
+	# ======= Install setserial-$(setserial_version) =======
+	@mkdir -p $(UTILLINUX_PKG)/sbin
+	@mkdir -p $(UTILLINUX_PKG)/var/lock/subsys
+	@cat $(SETSERIAL_SRC_DIR)/setserial > $(UTILLINUX_PKG)/sbin/setserial
+	@chmod 0755 $(UTILLINUX_PKG)/sbin/setserial
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/man/man8
+	@cat $(SETSERIAL_SRC_DIR)/setserial.8 > $(UTILLINUX_PKG)/usr/share/man/man8/setserial.8
+	@mkdir -p $(UTILLINUX_PKG)/etc/rc.d
+	@( cd $(SETSERIAL_SRC_DIR) ; \
+	   cat rc.serial > $(UTILLINUX_PKG)/etc/rc.d/rc.serial.new ; \
+	   cat serial.conf > $(UTILLINUX_PKG)/etc/serial.conf.new ; \
+	 )
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/doc/setserial-$(setserial_version)
+	@( cd $(SETSERIAL_SRC_DIR) ; \
+	   cp -a README Documentation/byterunner-setup $(UTILLINUX_PKG)/usr/share/doc/setserial-$(setserial_version) ; \
+	 )
+	# ======= Install etc/rc.d/rc.setterm =======
+	@cat $(CURDIR)/etc/rc.d/rc.setterm > $(UTILLINUX_PKG)/etc/rc.d/rc.setterm.new
+	# ======= Install PAM scripts =======
+	@mkdir -p $(UTILLINUX_PKG)/etc/pam.d
+	@for file in $(CURDIR)/etc/pam.d/* ; do \
+	   cp -a $$file $(UTILLINUX_PKG)/etc/pam.d/ ; \
+	 done
+	@mkdir -p $(UTILLINUX_PKG)/etc/default
+	@cat $(CURDIR)/etc/default/su > $(UTILLINUX_PKG)/etc/default/su.new
+	@chmod 644 $(UTILLINUX_PKG)/etc/default/su.new
+	@find $(UTILLINUX_PKG)/etc/pam.d -type f -exec mv {} {}.new \;
+	# ======= Setup important symlinks =======
+	@( cd $(UTILLINUX_PKG)/sbin ; \
+	   ln -s ../bin/mount . ; \
+	   ln -s ../bin/umount . ; \
+	   ln -s hwclock clock ; \
+	   cd $(UTILLINUX_PKG)/usr/sbin ; \
+	   ln -s ../../sbin/cfdisk . ; \
+	   ln -s ../../sbin/ctrlaltdel . ; \
+	   ln -s ../../sbin/sfdisk . ; \
+	   cd $(UTILLINUX_PKG)/usr/bin ; \
+	   ln -s ../sbin/readprofile . ; \
+	   ln -s ../../bin/more . ; \
+	   cd $(UTILLINUX_PKG)/usr/share/man/man8 ; \
+	   ln -s hwclock.8 clock.8 ; \
+	 )
+	# ======= Install Documentation =======
+	@( cd $(UTILLINUX_PKG)/usr/share/man/man1 ; \
+	   for file in *.1 ; do                                \
+	     ln=`head -n 1 $$file` ;                           \
+	     if [ "`echo $$ln | grep '^\.so '`" != "" ] ; then \
+	       origin=`echo $$ln | cut -f 2 -d ' '` ;          \
+	       origin=`basename $$origin` ;                    \
+	       rm -f $$file ;                                  \
+	       ln -sf $$origin $$file ;                        \
+	     fi ;                                              \
+	   done ;                                              \
+	 )
+	@( cd $(UTILLINUX_PKG)/usr/share/man/man3 ; \
+	   for file in *.3 ; do                                \
+	     ln=`head -n 1 $$file` ;                           \
+	     if [ "`echo $$ln | grep '^\.so '`" != "" ] ; then \
+	       origin=`echo $$ln | cut -f 2 -d ' '` ;          \
+	       origin=`basename $$origin` ;                    \
+	       rm -f $$file ;                                  \
+	       ln -sf $$origin $$file ;                        \
+	     fi ;                                              \
+	   done ;                                              \
+	 )
+	@( cd $(UTILLINUX_PKG)/usr/share/man/man8 ; \
+	   for file in *.8 ; do                                \
+	     ln=`head -n 1 $$file` ;                           \
+	     if [ "`echo $$ln | grep '^\.so '`" != "" ] ; then \
+	       origin=`echo $$ln | cut -f 2 -d ' '` ;          \
+	       origin=`basename $$origin` ;                    \
+	       rm -f $$file ;                                  \
+	       ln -sf $$origin $$file ;                        \
+	     fi ;                                              \
+	   done ;                                              \
+	 )
+	@if [ -d $(UTILLINUX_PKG)/usr/share/man ]; then \
+	  ( cd $(UTILLINUX_PKG)/usr/share/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
+	@mkdir -p $(UTILLINUX_PKG)/usr/doc/$(src_dir_name)
+	@cp -a $(SRC_DIR)/AUTHORS $(SRC_DIR)/COPYING $(SRC_DIR)/README.licensing \
+	       $(UTILLINUX_PKG)/usr/doc/$(src_dir_name)
+	@mkdir -p $(UTILLINUX_PKG)/usr/share/doc/$(src_dir_name)
+	@( cd $(SRC_DIR) ; \
+	   cp -ar AUTHORS COPYING NEWS README* \
+	          Documentation/licenses/* Documentation/example.files \
+	          $(UTILLINUX_PKG)/usr/share/doc/$(src_dir_name) \
+	 )
+	@( cd $(SRC_DIR) ; \
+	   if [ -r ChangeLog ]; then \
+	     DOCSDIR=`echo $(UTILLINUX_PKG)/usr/share/doc/$(src_dir_name)` ; \
+	     cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
+	     touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
+	   fi \
+	 )
+	# ======= remove toolchain path from target libtool *.la files =======
+	@( cd $(UTILLINUX_PKG)/usr/lib$(LIBSUFFIX) ; \
+	   sed -i "s,$(TARGET_DEST_DIR),,g" libblkid.la libfdisk.la libmount.la libsmartcols.la libuuid.la \
+	 )
+	@( cd $(UTILLINUX_PKG)/usr/lib$(LIBSUFFIX)/python$(PYTHON_VERSION)/site-packages/libmount ; \
+	   sed -i "s,$(TARGET_DEST_DIR),,g" pylibmount.la \
+	 )
+	# ======= Install the same to $(TARGET_DEST_DIR) =======
+	$(call install-into-devenv, $(UTILLINUX_PKG))
+	# ======= tune libtool *.la search path to the target destination for development =======
+	@( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX) ; \
+	   sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" libblkid.la libfdisk.la libmount.la libsmartcols.la libuuid.la ; \
+	   sed -i "s,L/lib,L$(TARGET_DEST_DIR)/lib,g" libblkid.la libfdisk.la libmount.la libsmartcols.la libuuid.la \
+	 )
+	@( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/python$(PYTHON_VERSION)/site-packages/libmount ; \
+	   sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" pylibmount.la ; \
+	   sed -i "s,L/lib,L$(TARGET_DEST_DIR)/lib,g" pylibmount.la \
+	 )
+	# ======= tune pkg-config *.pc search path to the target destination for development =======
+	@( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/pkgconfig ; \
+	   sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" blkid.pc fdisk.pc mount.pc smartcols.pc uuid.pc \
+	 )
+	# ======= Strip binaries =======
+	@( cd $(UTILLINUX_PKG) ; \
+	   find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+	   find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+	 )
+ifeq ($(__ENABLE_STATIC__),yes)
+	@( cd $(UTILLINUX_PKG) ; \
+	   find . | xargs file | grep "current ar archive" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+	 )
+endif
+ifneq ($(PATCHELF),)
+	# ======= Set RPATH/RUNPATH for target binaries =======
+	@( cd $(UTILLINUX_PKG) ; \
+	   for file in `find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
+	     rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
+	     if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
+	       $(PATCHELF) --set-rpath $(TARGET_BIN_RPATH) $$file 1> /dev/null 2> /dev/null ; \
+	     fi ; \
+	   done ; \
+	 )
+endif
+	@touch $@
+
+$(UTILLINUX_PKG_DESCRIPTION_FILE): $(UTILLINUX_PKG_DESCRIPTION_FILE_IN)
+	@cat $< | $(SED) -e "s/@VERSION@/$(version)/g" > $@
+
+$(pkg_certificate) : $(pkg_archive) ;
+$(pkg_signature)   : $(pkg_archive) ;
+$(pkg_description) : $(pkg_archive) ;
+
+$(pkg_archive): $(install_target) $(UTILLINUX_PKG_DESCRIPTION_FILE) $(UTILLINUX_PKG_INSTALL_SCRIPT)
+	@cp $(UTILLINUX_PKG_DESCRIPTION_FILE) $(UTILLINUX_PKG)/.DESCRIPTION
+	@cp $(UTILLINUX_PKG_INSTALL_SCRIPT) $(UTILLINUX_PKG)/.INSTALL
+	@$(BUILD_PKG_REQUIRES) $(UTILLINUX_PKG)/.REQUIRES
+	@echo "pkgname=$(UTILLINUX_PKG_NAME)"                            >  $(UTILLINUX_PKG)/.PKGINFO ; \
+	 echo "pkgver=$(UTILLINUX_PKG_VERSION)"                          >> $(UTILLINUX_PKG)/.PKGINFO ; \
+	 echo "arch=$(UTILLINUX_PKG_ARCH)"                               >> $(UTILLINUX_PKG)/.PKGINFO ; \
+	 echo "distroname=$(UTILLINUX_PKG_DISTRO_NAME)"                  >> $(UTILLINUX_PKG)/.PKGINFO ; \
+	 echo "distrover=$(UTILLINUX_PKG_DISTRO_VERSION)"                >> $(UTILLINUX_PKG)/.PKGINFO ; \
+	 echo "group=$(UTILLINUX_PKG_GROUP)"                             >> $(UTILLINUX_PKG)/.PKGINFO ; \
+	 echo "short_description=\"$(UTILLINUX_PKG_SHORT_DESCRIPTION)\"" >> $(UTILLINUX_PKG)/.PKGINFO ; \
+	 echo "url=$(UTILLINUX_PKG_URL)"                                 >> $(UTILLINUX_PKG)/.PKGINFO ; \
+	 echo "license=$(UTILLINUX_PKG_LICENSE)"                         >> $(UTILLINUX_PKG)/.PKGINFO
+	@$(PSEUDO) sh -c "cd $(UTILLINUX_PKG)  && \
+	                  chown -R root:root . && \
+	                  chgrp   5 usr/bin/wall  && \
+	                  chmod g+s usr/bin/wall  && \
+	                  chgrp   5 usr/bin/write && \
+	                  chmod g+s usr/bin/write && \
+	                  $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: PATCHES
===================================================================
--- PATCHES	(nonexistent)
+++ PATCHES	(revision 5)
@@ -0,0 +1,10 @@
+
+../../../sources/packages/a/util-linux/patches/util-linux-2.38.1-fdisk-no-solaris.patch -p0
+../../../sources/packages/a/util-linux/patches/util-linux-2.38.1-nolist-ramdevs.patch   -p0
+
+../../../sources/packages/a/adjtimex/patches/adjtimex-1.29.patch                        -p0
+../../../sources/packages/a/bsdstrings/patches/bsdstrings-make.patch                    -p0
+../../../sources/packages/a/bsdstrings/patches/bsdstrings-overflow.patch                -p0
+../../../sources/packages/n/net-tools/patches/net-tools-1.60-20210110.patch             -p0
+../../../sources/packages/a/setserial/patches/setserial-2.17.patch                      -p0
+../../../sources/packages/a/ziptool/patches/ziptool-1.4.0.patch                         -p0
Index: etc/default/su
===================================================================
--- etc/default/su	(nonexistent)
+++ etc/default/su	(revision 5)
@@ -0,0 +1,3 @@
+# Ensure that ENV_SUPATH from /etc/login.defs is used for the $PATH when
+# 'su' is used. Otherwise /sbin paths will be missing unless 'su -' is used.
+ALWAYS_SET_PATH yes
Index: etc/default
===================================================================
--- etc/default	(nonexistent)
+++ etc/default	(revision 5)

Property changes on: etc/default
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,73 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~
Index: etc/pam.d/chfn
===================================================================
--- etc/pam.d/chfn	(nonexistent)
+++ etc/pam.d/chfn	(revision 5)
@@ -0,0 +1,6 @@
+#%PAM-1.0
+auth       sufficient   pam_rootok.so
+auth       include      system-auth
+account    include      system-auth
+password   include      system-auth
+session    include      system-auth
Index: etc/pam.d/chsh
===================================================================
--- etc/pam.d/chsh	(nonexistent)
+++ etc/pam.d/chsh	(revision 5)
@@ -0,0 +1,6 @@
+#%PAM-1.0
+auth       sufficient   pam_rootok.so
+auth       include      system-auth
+account    include      system-auth
+password   include      system-auth
+session    include      system-auth
Index: etc/pam.d/login
===================================================================
--- etc/pam.d/login	(nonexistent)
+++ etc/pam.d/login	(revision 5)
@@ -0,0 +1,20 @@
+#%PAM-1.0
+auth            required        pam_securetty.so
+# When using pam_faillock, print a message to the user if the account is
+# locked. This lets the user know what is going on, but it also potentially
+# gives additional information to attackers:
+#auth            requisite       pam_faillock.so preauth
+auth            include         system-auth
+# To set a limit on failed authentications, the pam_faillock module
+# can be enabled. See pam_faillock(8) for more information.
+#auth            [default=die]   pam_faillock.so authfail
+#auth            sufficient      pam_faillock.so authsucc
+auth            include         postlogin
+account         required        pam_nologin.so
+account         include         system-auth
+password        include         system-auth
+session         include         system-auth
+session         include         postlogin
+session         required        pam_loginuid.so
+-session        optional        pam_ck_connector.so nox11
+-session        optional        pam_elogind.so
Index: etc/pam.d/runuser
===================================================================
--- etc/pam.d/runuser	(nonexistent)
+++ etc/pam.d/runuser	(revision 5)
@@ -0,0 +1,5 @@
+#%PAM-1.0
+auth            sufficient      pam_rootok.so
+session         optional        pam_keyinit.so revoke
+session         required        pam_limits.so
+session         required        pam_unix.so
Index: etc/pam.d/runuser-l
===================================================================
--- etc/pam.d/runuser-l	(nonexistent)
+++ etc/pam.d/runuser-l	(revision 5)
@@ -0,0 +1,4 @@
+#%PAM-1.0
+auth            include         runuser
+session         optional        pam_keyinit.so force revoke
+session         include         runuser
Index: etc/pam.d/su
===================================================================
--- etc/pam.d/su	(nonexistent)
+++ etc/pam.d/su	(revision 5)
@@ -0,0 +1,11 @@
+#%PAM-1.0
+auth            sufficient      pam_rootok.so
+# Uncomment the following line to implicitly trust users in the "wheel" group.
+#auth           sufficient      pam_wheel.so trust use_uid
+# Uncomment the following line to require a user to be in the "wheel" group.
+#auth           required        pam_wheel.so use_uid
+auth            include         system-auth
+account         include         system-auth
+password        include         system-auth
+session         include         system-auth
+session         optional        pam_xauth.so
Index: etc/pam.d/su-l
===================================================================
--- etc/pam.d/su-l	(nonexistent)
+++ etc/pam.d/su-l	(revision 5)
@@ -0,0 +1,6 @@
+#%PAM-1.0
+auth            include         su
+account         include         su
+password        include         su
+session         optional        pam_keyinit.so force revoke
+session         include         su
Index: etc/pam.d
===================================================================
--- etc/pam.d	(nonexistent)
+++ etc/pam.d	(revision 5)

Property changes on: etc/pam.d
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,73 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~
Index: etc/rc.d/rc.setterm
===================================================================
--- etc/rc.d/rc.setterm	(nonexistent)
+++ etc/rc.d/rc.setterm	(revision 5)
@@ -0,0 +1,13 @@
+#!/bin/sh
+#
+# This file provides the command line for the setterm utility to set the
+# terminal attributes (primarily used for screen blanking and power
+# management).
+
+# Screen blanks after 15 minutes idle time, and powers down in one hour
+# if the kernel supports APM or ACPI power management (default setting):
+/bin/setterm -blank 15 -powersave powerdown -powerdown 60
+
+# Screen does not blank or use power management features:
+#/bin/setterm -blank 0 -powersave off -powerdown 0
+
Index: etc/rc.d
===================================================================
--- etc/rc.d	(nonexistent)
+++ etc/rc.d	(revision 5)

Property changes on: etc/rc.d
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,73 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~
Index: etc
===================================================================
--- etc	(nonexistent)
+++ etc	(revision 5)

Property changes on: etc
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,73 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~
Index: util-linux-pkg-description.in
===================================================================
--- util-linux-pkg-description.in	(nonexistent)
+++ util-linux-pkg-description.in	(revision 5)
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description.  Line
+# up the first '|' above the ':' following the base package name, and the '|'
+# on the right side marks the last column you can put a character in.  You must
+# make exactly 11 lines for the formatting to be correct.  It's also
+# customary to leave one space after the ':'.
+
+          |-----handy-ruler------------------------------------------------------|
+util-linux: util-linux @VERSION@ (a huge collection of essential utilities)
+util-linux:
+util-linux: The util-linux package is a huge collection of random utilities
+util-linux: that are essential to run a Linux system.
+util-linux:
+util-linux:
+util-linux:
+util-linux:
+util-linux:
+util-linux:
+util-linux:
Index: util-linux-pkg-install.sh
===================================================================
--- util-linux-pkg-install.sh	(nonexistent)
+++ util-linux-pkg-install.sh	(revision 5)
@@ -0,0 +1,85 @@
+#!/bin/sh
+
+# Preserve new files
+install_file() {
+  NEW="$1"
+  OLD="`dirname $NEW`/`basename $NEW .new`"
+  # If there's no file by that name, mv it over:
+  if [ ! -r $OLD ]; then
+    mv $NEW $OLD
+  elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then
+    # toss the redundant copy:
+    rm $NEW
+  fi
+  # Otherwise, we leave the .new copy for the admin to consider...
+}
+
+
+# arg 1:  the new package version
+pre_install() {
+  /bin/true
+}
+
+# arg 1:  the new package version
+post_install() {
+  # Keep same perms on rc.serial.new:
+  if [ -e etc/rc.d/rc.serial ]; then
+    cp -a etc/rc.d/rc.serial etc/rc.d/rc.serial.new.incoming
+    cat etc/rc.d/rc.serial.new > etc/rc.d/rc.serial.new.incoming
+    mv etc/rc.d/rc.serial.new.incoming etc/rc.d/rc.serial.new
+  fi
+
+  install_file etc/rc.d/rc.serial.new
+  install_file etc/rc.d/rc.setterm.new
+  install_file etc/serial.conf.new
+
+  for cfgfile in chfn.new chsh.new login.new runuser.new runuser-l.new su.new su-l.new ; do
+    if [ -r etc/pam.d/$cfgfile ]; then
+      install_file etc/pam.d/$cfgfile
+    fi
+  done
+
+  if [ -r etc/default/su.new ]; then
+    install_file etc/default/su.new
+  fi
+
+
+  # We use an relative path to 'proc/sys/kernel/osrelease' because we have to be sure
+  # that we are running on the target platform. Only in this case we will use
+  # absolute path to coreutils ('/bin/chgrp' and '/bin/chmod') and we have to check
+  # is the coreutils already installed.
+  if [ -r proc/sys/kernel/osrelease -a -x /bin/chgrp -a -x /bin/chmod ]; then
+    /bin/chgrp tty /usr/bin/wall
+    /bin/chmod g+s /usr/bin/wall
+    /bin/chgrp tty /usr/bin/write
+    /bin/chmod g+s /usr/bin/write
+  fi
+}
+
+# arg 1:  the new package version
+# arg 2:  the old package version
+pre_update() {
+  /bin/true
+}
+
+# arg 1:  the new package version
+# arg 2:  the old package version
+post_update() {
+  post_install
+}
+
+# arg 1:  the old package version
+pre_remove() {
+  /bin/true
+}
+
+# arg 1:  the old package version
+post_remove() {
+  /bin/true
+}
+
+
+operation=$1
+shift
+
+$operation $*

Property changes on: util-linux-pkg-install.sh
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: .
===================================================================
--- .	(nonexistent)
+++ .	(revision 5)

Property changes on: .
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,73 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~