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

383 Commits   1 Branch   1 Tag
Index: 2.99/Makefile
===================================================================
--- 2.99/Makefile	(nonexistent)
+++ 2.99/Makefile	(revision 5)
@@ -0,0 +1,243 @@
+
+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/sysvinit
+
+ifeq ($(__USE_BUILT_GCC_LIBS__),yes)
+REQUIRES           = dev/gcc/12.2.0
+else
+REQUIRES           = libs/glibc/2.36
+endif
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version             = 2.99
+tar_xz_archive      = $(SRC_PACKAGE_PATH)/packages/a/sysvinit/sysvinit-$(version).tar.xz
+SRC_ARCHIVE         = $(tar_xz_archive)
+SRC_DIR             = $(TARGET_BUILD_DIR)/sysvinit-$(version)
+src_done            = $(TARGET_BUILD_DIR)/.source_done
+
+PATCHES = PATCHES
+
+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.
+#
+SYSVINIT_PKG_NAME                = sysvinit
+SYSVINIT_PKG_VERSION             = 2.99
+SYSVINIT_PKG_ARCH                = $(PKGARCH)
+SYSVINIT_PKG_DISTRO_NAME         = $(DISTRO_NAME)
+SYSVINIT_PKG_DISTRO_VERSION      = $(DISTRO_VERSION)
+SYSVINIT_PKG_GROUP               = $(PKG_GROUP)
+###                               |---handy-ruler-------------------------------|
+SYSVINIT_PKG_SHORT_DESCRIPTION   = init is the parent of all processes
+SYSVINIT_PKG_URL                 = $(BUG_URL)
+SYSVINIT_PKG_LICENSE             = GPLv2
+SYSVINIT_PKG_DESCRIPTION_FILE    = $(TARGET_BUILD_DIR)/$(SYSVINIT_PKG_NAME)-pkg-description
+SYSVINIT_PKG_DESCRIPTION_FILE_IN = $(SYSVINIT_PKG_NAME)-pkg-description.in
+SYSVINIT_PKG_INSTALL_SCRIPT      = $(SYSVINIT_PKG_NAME)-pkg-install.sh
+
+SYSVINIT_PKG     = $(CURDIR)/$(TARGET_BUILD_DIR)/$(SYSVINIT_PKG_NAME)-package
+
+pkg_basename     = $(SYSVINIT_PKG_NAME)-$(SYSVINIT_PKG_VERSION)-$(SYSVINIT_PKG_ARCH)-$(SYSVINIT_PKG_DISTRO_NAME)-$(SYSVINIT_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
+
+#
+# NOTE:
+#   sysvinit doesn't want to have -I$(TARGET_DEST_DIR)/usr/include in CFLAGS
+#   but we have to pass the architecture dependend CFLAGS. In this case we
+#   overwrite CFLAGS with ARCH_FLAGS value to remove standatd -I flags added
+#   by build-system.
+#
+# GCC CPP documentation:
+#   All directories named by ‘-isystem’ are searched after all directories
+#   named by ‘-I’, no matter what their order was on the command line. If the
+#   same directory is named by both ‘-I’ and ‘-isystem’, the ‘-I’ option is
+#   ignored. GCC provides an informative message when this occurs if ‘-v’ is
+#   used. For example, we can make use following CFLAGS:
+#
+#     CFLAGS = -v -isystem $(TARGET_DEST_DIR)/usr/include $(ARCH_FLAGS)
+#
+CFLAGS = -isystem $(TARGET_DEST_DIR)/usr/include $(ARCH_FLAGS)
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+	$(UNPACK_SRC_ARCHIVE)
+	$(APPLY_PATCHES)
+	@touch $@
+
+$(build_target): $(src_done)
+	@cd $(SRC_DIR)/src && $(BUILD_ENVIRONMENT) $(MAKE) clobber
+	@cd $(SRC_DIR)/src && $(BUILD_ENVIRONMENT) $(MAKE) all
+	@touch $@
+
+$(install_target): $(build_target)
+	@mkdir -p $(SYSVINIT_PKG)/etc/inittab.d
+	@mkdir -p $(SYSVINIT_PKG)/sbin
+	@( cd $(SRC_DIR)/src ; \
+	   for program in bootlogd halt init killall5 shutdown runlevel ; do \
+	     $(STRIP) --strip-unneeded $$program ; \
+	     cat $$program > $(SYSVINIT_PKG)/sbin/$$program ; \
+	     chmod 755 $(SYSVINIT_PKG)/sbin/$$program ; \
+	   done \
+	 )
+	@mkdir -p $(SYSVINIT_PKG)/usr/bin
+	@( cd $(SRC_DIR)/src ; \
+	   for program in last ; do \
+	     $(STRIP) --strip-unneeded $$program ; \
+	     cat $$program > $(SYSVINIT_PKG)/usr/bin/$$program ; \
+	     chmod 755 $(SYSVINIT_PKG)/usr/bin/$$program ; \
+	   done \
+	 )
+	@( cd $(SYSVINIT_PKG)/usr/bin ; ln -sf last lastb )
+	@mv $(SYSVINIT_PKG)/sbin/init $(SYSVINIT_PKG)/sbin/init.new
+	@chmod 755 $(SYSVINIT_PKG)/sbin/init.new
+	# ======= Install Documentation =======
+	@mkdir -p $(SYSVINIT_PKG)/usr/doc/sysvinit-$(version)
+	@( cd $(SRC_DIR) ; \
+	   cp -a COPYING COPYRIGHT \
+	         $(SYSVINIT_PKG)/usr/doc/sysvinit-$(version) \
+	 )
+	@mkdir -p $(SYSVINIT_PKG)/usr/share/doc/sysvinit-$(version)/contrib
+	@( cd $(SRC_DIR) ; \
+	   cp -a contrib/sysd2v.sh \
+	         $(SYSVINIT_PKG)/usr/share/doc/sysvinit-$(version)/contrib \
+	 )
+	@( cd $(SRC_DIR)/doc ; \
+	   cp -a Changelog Install Propaganda bootlogd.README initctl initscript.sample \
+	         ../COPYING ../COPYRIGHT ../README  \
+	         $(SYSVINIT_PKG)/usr/share/doc/sysvinit-$(version) \
+	 )
+	@( cd $(SRC_DIR)/doc ; \
+	   if [ -r ChangeLog ]; then \
+	     DOCSDIR=`echo $(SYSVINIT_PKG)/usr/share/doc/sysvinit-$(version)` ; \
+	     cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
+	     touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
+	   fi \
+	 )
+	@mkdir -p $(SYSVINIT_PKG)/usr/share/man/man{1,5,8}
+	@( cd $(SRC_DIR)/man ; \
+	   for page in last.1 ; do \
+	     cat $$page | gzip -9c > $(SYSVINIT_PKG)/usr/share/man/man1/$$page.gz ; \
+	   done ; \
+	   for page in inittab.5 initscript.5 ; do \
+	     cat $$page | gzip -9c > $(SYSVINIT_PKG)/usr/share/man/man5/$$page.gz ; \
+	   done ; \
+	   for page in halt.8 init.8 killall5.8 \
+	               runlevel.8 shutdown.8 bootlogd.8 ; do \
+	     cat $$page | gzip -9c > $(SYSVINIT_PKG)/usr/share/man/man8/$$page.gz ; \
+	   done \
+	 )
+	@( cd $(SYSVINIT_PKG)/usr/share/man/man1 ; ln -sf last.1.gz lastb.1.gz )
+	@( cd $(SYSVINIT_PKG)/usr/share/man/man8 ; \
+	   ln -sf halt.8.gz poweroff.8.gz ; \
+	   ln -sf halt.8.gz reboot.8.gz   ; \
+	   ln -sf init.8.gz telinit.8.gz  ; \
+	 )
+	# ======= Install the same to $(TARGET_DEST_DIR) =======
+	$(call install-into-devenv, $(SYSVINIT_PKG))
+	# ======= Strip binaries =======
+	@( cd $(SYSVINIT_PKG) ; \
+	   find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null \
+	 )
+	@touch $@
+
+$(SYSVINIT_PKG_DESCRIPTION_FILE): $(SYSVINIT_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) $(SYSVINIT_PKG_DESCRIPTION_FILE) $(SYSVINIT_PKG_INSTALL_SCRIPT)
+	@cp $(SYSVINIT_PKG_DESCRIPTION_FILE) $(SYSVINIT_PKG)/.DESCRIPTION
+	@cp $(SYSVINIT_PKG_INSTALL_SCRIPT) $(SYSVINIT_PKG)/.INSTALL
+	@$(BUILD_PKG_REQUIRES) $(SYSVINIT_PKG)/.REQUIRES
+	@echo "pkgname=$(SYSVINIT_PKG_NAME)"                            >  $(SYSVINIT_PKG)/.PKGINFO ; \
+	 echo "pkgver=$(SYSVINIT_PKG_VERSION)"                          >> $(SYSVINIT_PKG)/.PKGINFO ; \
+	 echo "arch=$(SYSVINIT_PKG_ARCH)"                               >> $(SYSVINIT_PKG)/.PKGINFO ; \
+	 echo "distroname=$(SYSVINIT_PKG_DISTRO_NAME)"                  >> $(SYSVINIT_PKG)/.PKGINFO ; \
+	 echo "distrover=$(SYSVINIT_PKG_DISTRO_VERSION)"                >> $(SYSVINIT_PKG)/.PKGINFO ; \
+	 echo "group=$(SYSVINIT_PKG_GROUP)"                             >> $(SYSVINIT_PKG)/.PKGINFO ; \
+	 echo "short_description=\"$(SYSVINIT_PKG_SHORT_DESCRIPTION)\"" >> $(SYSVINIT_PKG)/.PKGINFO ; \
+	 echo "url=$(SYSVINIT_PKG_URL)"                                 >> $(SYSVINIT_PKG)/.PKGINFO ; \
+	 echo "license=$(SYSVINIT_PKG_LICENSE)"                         >> $(SYSVINIT_PKG)/.PKGINFO
+	@$(PSEUDO) sh -c "cd $(SYSVINIT_PKG) && \
+	                  chown -R root:root . && \
+	                  $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: 2.99/PATCHES
===================================================================
--- 2.99/PATCHES	(nonexistent)
+++ 2.99/PATCHES	(revision 5)
@@ -0,0 +1,4 @@
+
+../../../sources/packages/a/sysvinit/patches/sysvinit-2.99-initctl.patch -p0
+../../../sources/packages/a/sysvinit/patches/sysvinit-2.99-paths.patch   -p0
+../../../sources/packages/a/sysvinit/patches/sysvinit-2.99-version.patch -p0
Index: 2.99/sysvinit-pkg-description.in
===================================================================
--- 2.99/sysvinit-pkg-description.in	(nonexistent)
+++ 2.99/sysvinit-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------------------------------------------------------|
+sysvinit: sysvinit @VERSION@ (init, the parent of all processes)
+sysvinit:
+sysvinit: System V style init programs by Miquel van Smoorenburg that control
+sysvinit: the booting and shutdown of your system. These support a number of
+sysvinit: system runlevels, each with a specific set of utilities spawned.
+sysvinit: For example, the normal system runlevel is 3, which starts agetty
+sysvinit: on virtual consoles tty1 - tty6. Runlevel 4 starts xdm.
+sysvinit: Runlevel 0 shuts the system down.
+sysvinit:
+sysvinit:
+sysvinit:
Index: 2.99/sysvinit-pkg-install.sh
===================================================================
--- 2.99/sysvinit-pkg-install.sh	(nonexistent)
+++ 2.99/sysvinit-pkg-install.sh	(revision 5)
@@ -0,0 +1,82 @@
+#!/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() {
+  if [ -r sbin/init ]; then
+    mv sbin/init sbin/init.old
+  fi
+
+  mv sbin/init.new sbin/init
+
+  # Add a btmp file to store login failure if one doesn't exist:
+  if [ ! -r var/log/btmp ]; then
+    ( cd var/log ; umask 077 ; touch btmp )
+  fi
+
+  # Notice we use an absolute path below, rather than usr/bin/last. This is because
+  # we're testing to see if we are on the bootdisk, which will not have /usr/bin/last.
+  # If we aren't, we will signal init to restart using the new binary.
+  # The presence of "/etc/system-installer" is under consideration as a better test.
+  # Also we have to check that we are not in the installer mode on the target system
+  # ("/etc/system-installer"), and we have to be sure that we are on the working system
+  # on the target hardware ("proc/sys/kernel/osrelease" - relative path).
+  if [ -r proc/sys/kernel/osrelease -a ! -r /etc/system-installer -a -x /usr/bin/last ]; then
+    /sbin/init u
+  fi
+
+  ( cd sbin ; rm -rf telinit )
+  ( cd sbin ; ln -sf init telinit )
+  ( cd sbin ; rm -rf reboot )
+  ( cd sbin ; ln -sf halt reboot )
+  ( cd sbin ; rm -rf poweroff )
+  ( cd sbin ; ln -sf halt poweroff )
+
+  rm -f sbin/init.old
+}
+
+# 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: 2.99/sysvinit-pkg-install.sh
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: 2.99
===================================================================
--- 2.99	(nonexistent)
+++ 2.99	(revision 5)

Property changes on: 2.99
___________________________________________________________________
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: .
===================================================================
--- .	(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
+*~