Index: Makefile
===================================================================
--- Makefile (nonexistent)
+++ Makefile (revision 5)
@@ -0,0 +1,189 @@
+
+COMPONENT_TARGETS = $(HARDWARE_INTEL_PC64)
+
+NEED_ABS_PATH = true
+COMPONENT_IS_3PP = true
+
+CREATE_X86_32_PACKAGE = true
+
+
+include ../../../build-system/constants.mk
+
+
+SOURCE_REQUIRES = sources/GNU/glibc/2.36
+SOURCE_REQUIRES += sources/iana/tz
+
+REQUIRES = libs/glibc/2.36
+REQUIRES += dev/kernel-headers
+REQUIRES += dev/gcc-runtime/12.2.0
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version = 2.36
+tar_xz_archive = $(SRC_PACKAGE_PATH)/GNU/glibc/$(version)/glibc-$(version).tar.xz
+
+tz_version = 2022f
+tar_gz_code_archive = $(SRC_PACKAGE_PATH)/iana/tz/tzcode$(tz_version).tar.gz
+tar_gz_data_archive = $(SRC_PACKAGE_PATH)/iana/tz/tzdata$(tz_version).tar.gz
+exclude_list = $(CURDIR)/tz-exclude.list
+
+SRC_ARCHIVE = $(tar_xz_archive)
+SRC_DIR = $(TARGET_BUILD_DIR)/glibc-$(version)
+src_dir_name = glibc-$(version)
+src_done = $(TARGET_BUILD_DIR)/.source-done
+
+PATCHES = PATCHES
+
+build_dir = $(TARGET_BUILD_DIR)/build
+build_target = $(TARGET_BUILD_DIR)/.built
+install_target = $(TARGET_BUILD_DIR)/.installed
+
+
+build_glibc32_pkg = $(TARGET_BUILD_DIR)/.glibc32_pkg_done
+
+
+OPTIMIZATION_FLAGS = -O3
+
+
+####### Targets
+
+PKG_GROUP = libs
+
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+GLIBC_32_PKG_NAME = glibc-x32
+GLIBC_32_PKG_VERSION = 2.36
+GLIBC_32_PKG_ARCH = $(PKGARCH)
+GLIBC_32_PKG_DISTRO_NAME = $(DISTRO_NAME)
+GLIBC_32_PKG_DISTRO_VERSION = $(DISTRO_VERSION)
+GLIBC_32_PKG_GROUP = $(PKG_GROUP)
+### |---handy-ruler-------------------------------|
+GLIBC_32_PKG_SHORT_DESCRIPTION = GNU C libraries
+GLIBC_32_PKG_URL = $(BUG_URL)
+GLIBC_32_PKG_LICENSE = GPLv2
+GLIBC_32_PKG_DESCRIPTION_FILE = $(TARGET_BUILD_DIR)/$(GLIBC_32_PKG_NAME)-pkg-description
+GLIBC_32_PKG_DESCRIPTION_FILE_IN = $(GLIBC_32_PKG_NAME)-pkg-description.in
+GLIBC_32_PKG_INSTALL_SCRIPT = $(GLIBC_32_PKG_NAME)-pkg-install.sh
+
+GLIBC_32_PKG = $(CURDIR)/$(TARGET_BUILD_DIR)/$(GLIBC_32_PKG_NAME)-package
+
+pkg_basename = $(GLIBC_32_PKG_NAME)-$(GLIBC_32_PKG_VERSION)-$(GLIBC_32_PKG_ARCH)-$(GLIBC_32_PKG_DISTRO_NAME)-$(GLIBC_32_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)
+BUILD_TARGETS += $(build_glibc32_pkg)
+
+PRODUCT_TARGETS = $(products)
+
+ROOTFS_TARGETS = $(pkg_archive)
+
+
+include ../../../build-system/core.mk
+
+
+env_sysroot = install_root=$(GLIBC_32_PKG)
+
+
+extra_configure_switches += --libdir=/usr/lib$(MULTILIB_X86_32_SUFFIX)
+extra_configure_switches += --with-headers=$(TARGET_DEST_DIR)/usr/include
+extra_configure_switches += --with-binutils=$(TOOLCHAIN_PATH)/bin
+extra_configure_switches += --enable-kernel=2.6.36
+extra_configure_switches += --enable-add-ons
+extra_configure_switches += --enable-profile
+extra_configure_switches += --enable-bind-now
+extra_configure_switches += --without-gd
+extra_configure_switches += --without-cvs
+
+
+extra_configure_switches += libc_cv_slibdir=/lib$(MULTILIB_X86_32_SUFFIX)
+extra_configure_switches += libc_cv_rtlddir=/lib$(MULTILIB_X86_32_SUFFIX)
+
+
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+ $(UNPACK_SRC_ARCHIVE)
+ @tar --exclude-from=$(exclude_list) -xzf $(tar_gz_code_archive) -C $(SRC_DIR)/timezone
+ @tar --exclude-from=$(exclude_list) -xzf $(tar_gz_data_archive) -C $(SRC_DIR)/timezone
+ $(APPLY_PATCHES)
+ @touch $@
+
+$(build_target): $(src_done)
+ @mkdir -p $(build_dir)
+ @echo "slibdir=/lib$(MULTILIB_X86_32_SUFFIX)" >> $(build_dir)/configparms
+ @echo "rtlddir=/lib$(MULTILIB_X86_32_SUFFIX)" >> $(build_dir)/configparms
+ @cd $(build_dir) && $(BUILD_ENVIRONMENT) $(env_sysroot) ../$(src_dir_name)/configure \
+ --prefix=/usr \
+ --build=$(BUILD) \
+ --host=$(TARGET32) \
+ $(extra_configure_switches)
+ @cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE)
+ @touch $@
+
+$(install_target): $(build_target)
+ @mkdir -p $(GLIBC_32_PKG)
+ @cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 install $(env_sysroot)
+ # ======= fake LOCALES installation to allow implementation of iconv and intl into GLIBC =======
+ @cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 SUPPORTED-LOCALES="" \
+ localedata/install-locales $(env_sysroot)
+ @touch $@
+
+$(build_glibc32_pkg): $(install_target)
+ # ======= Remove not needed stuff =======
+ @rm -rf $(GLIBC_32_PKG)/etc
+ @rm -rf $(GLIBC_32_PKG)/sbin
+ @rm -rf $(GLIBC_32_PKG)/usr/bin
+ @rm -rf $(GLIBC_32_PKG)/usr/sbin
+ @rm -rf $(GLIBC_32_PKG)/usr/share
+ @rm -rf $(GLIBC_32_PKG)/var
+ @( cd $(GLIBC_32_PKG)/usr/include/gnu ; cp lib-names-32.h stubs-32.h ../.. )
+ @rm -rf $(GLIBC_32_PKG)/usr/include
+ @( mkdir -p $(GLIBC_32_PKG)/usr/include/gnu ; \
+ mv $(GLIBC_32_PKG)/usr/lib-names-32.h $(GLIBC_32_PKG)/usr/include/gnu ; \
+ mv $(GLIBC_32_PKG)/usr/stubs-32.h $(GLIBC_32_PKG)/usr/include/gnu ; \
+ )
+ # ======= Create symbolic link to libnsl.so.1 =======
+ @( cd $(GLIBC_32_PKG)/usr/lib$(MULTILIB_X86_32_SUFFIX) ; \
+ ln -sf ../../lib$(MULTILIB_X86_32_SUFFIX)/libnsl.so.1 libnsl.so ; \
+ )
+ # ======= Install the same to $(TARGET_DEST_DIR) =======
+ $(call install-into-devenv, $(GLIBC_32_PKG))
+ # ======= Strip binaries =======
+ @( cd $(GLIBC_32_PKG) ; \
+ find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-debug 2> /dev/null ; \
+ find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+ find . | xargs file | grep "current ar archive" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+ find . | xargs file | grep "relocatable" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+ )
+ @touch $@
+
+$(GLIBC_32_PKG_DESCRIPTION_FILE): $(GLIBC_32_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): $(build_glibc32_pkg) $(GLIBC_32_PKG_DESCRIPTION_FILE) $(GLIBC_32_PKG_INSTALL_SCRIPT)
+ @cp $(GLIBC_32_PKG_DESCRIPTION_FILE) $(GLIBC_32_PKG)/.DESCRIPTION
+ @cp $(GLIBC_32_PKG_INSTALL_SCRIPT) $(GLIBC_32_PKG)/.INSTALL
+ @$(BUILD_BIN_PKG_REQUIRES) $(GLIBC_32_PKG)/.REQUIRES
+ @echo "pkgname=$(GLIBC_32_PKG_NAME)" > $(GLIBC_32_PKG)/.PKGINFO ; \
+ echo "pkgver=$(GLIBC_32_PKG_VERSION)" >> $(GLIBC_32_PKG)/.PKGINFO ; \
+ echo "arch=$(GLIBC_32_PKG_ARCH)" >> $(GLIBC_32_PKG)/.PKGINFO ; \
+ echo "distroname=$(GLIBC_32_PKG_DISTRO_NAME)" >> $(GLIBC_32_PKG)/.PKGINFO ; \
+ echo "distrover=$(GLIBC_32_PKG_DISTRO_VERSION)" >> $(GLIBC_32_PKG)/.PKGINFO ; \
+ echo "group=$(GLIBC_32_PKG_GROUP)" >> $(GLIBC_32_PKG)/.PKGINFO ; \
+ echo "short_description=\"$(GLIBC_32_PKG_SHORT_DESCRIPTION)\"" >> $(GLIBC_32_PKG)/.PKGINFO ; \
+ echo "url=$(GLIBC_32_PKG_URL)" >> $(GLIBC_32_PKG)/.PKGINFO ; \
+ echo "license=$(GLIBC_32_PKG_LICENSE)" >> $(GLIBC_32_PKG)/.PKGINFO
+ @$(PSEUDO) sh -c "cd $(GLIBC_32_PKG) && \
+ chown -R root:root . && \
+ $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: PATCHES
===================================================================
--- PATCHES (nonexistent)
+++ PATCHES (revision 5)
@@ -0,0 +1,13 @@
+
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-b3736d1a3c-2.36.1.patch -p0
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-i18n.patch -p0
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-malloc-hooks.patch -p0
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-en_US-no-am-pm.patch -p0
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-reenable-DT-HASH.patch -p0
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-locale-no-archive.patch -p0
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-zonefile.patch -p0
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-zoneinfo.patch
+../../../sources/iana/tz/patches/glibc-2.36-tzcode-2022f.patch -p0
+
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-ppc64-interpreter.patch -p0
+../../../sources/GNU/glibc/2.36/patches/glibc-2.36-x86_64-interpreter.patch -p0
Index: glibc-x32-pkg-description.in
===================================================================
--- glibc-x32-pkg-description.in (nonexistent)
+++ glibc-x32-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------------------------------------------------------|
+glibc-x32: glibc-x32 @VERSION@ (GNU C libraries)
+glibc-x32:
+glibc-x32: This package contains the GNU C libraries and header files.
+glibc-x32: The GNU C library was written originally by Roland McGrath,
+glibc-x32: and is currently maintained by Ulrich Drepper. Some parts of
+glibc-x32: the library were contributed or worked on by other people.
+glibc-x32:
+glibc-x32:
+glibc-x32:
+glibc-x32:
+glibc-x32:
Index: glibc-x32-pkg-install.sh
===================================================================
--- glibc-x32-pkg-install.sh (nonexistent)
+++ glibc-x32-pkg-install.sh (revision 5)
@@ -0,0 +1,39 @@
+#!/bin/sh
+
+# arg 1: the new package version
+pre_install() {
+ /bin/true
+}
+
+# arg 1: the new package version
+post_install() {
+ /bin/true
+}
+
+# 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: glibc-x32-pkg-install.sh
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: tz-exclude.list
===================================================================
--- tz-exclude.list (nonexistent)
+++ tz-exclude.list (revision 5)
@@ -0,0 +1 @@
+Makefile
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
+*~