1
0
mirror of git://projects.qi-hardware.com/xburst-tools.git synced 2024-11-23 04:42:27 +02:00

make glibc compile & install properly

locale support added (modify the SUPPORTED file if needed)
This commit is contained in:
lindnermarek 2009-04-06 10:48:09 +00:00
parent 75c9bd2885
commit 6b95584211
2 changed files with 30 additions and 18 deletions

View File

@ -32,8 +32,8 @@ KERNEL_PATH=kernel
TOOLCHAIN_PATH=toolchain TOOLCHAIN_PATH=toolchain
DL_PATH=$(TOOLCHAIN_PATH)/dl DL_PATH=$(TOOLCHAIN_PATH)/dl
INSTALL_PATH=install INSTALL_PATH=install
PATCHES_PATH= PATCHES_PATH=$(TOOLCHAIN_PATH)/patches
GLIBC_PATCHES_PATH=$(TOOLCHAIN_PATH)/patches/glibc GLIBC_PATCHES_PATH=$(PATCHES_PATH)/glibc
BINUTILS_PACKAGE=$(BINUTILS_VER).tar.bz2 BINUTILS_PACKAGE=$(BINUTILS_VER).tar.bz2
BINUTILS_URL= \ BINUTILS_URL= \
@ -51,6 +51,14 @@ CFLAGS="-O2"
export PATH:=$(PWD)/install/bin:$(PATH) export PATH:=$(PWD)/install/bin:$(PATH)
# this glibc version does not build with gcc 4.3 - hence this special compat parameter
GCC_VERSION=$(shell [ "`gcc --version | grep '4.3'`" ] && echo "43" )
ifeq ($(GCC_VERSION),43)
BUILD_CC="gcc -fgnu89-inline"
else
BUILD_CC="gcc"
endif
toolchain: binutils gcc glibc toolchain: binutils gcc glibc
@ -68,7 +76,7 @@ $(INSTALL_PATH):
%$(GLIBC_PACKAGE): URL=$(GLIBC_URL) %$(GLIBC_PACKAGE): URL=$(GLIBC_URL)
%$(GLIBC_PORTS_PACKAGE): URL=$(GLIBC_PORTS_URL) %$(GLIBC_PORTS_PACKAGE): URL=$(GLIBC_PORTS_URL)
%.bz2: $(DL_PATH) $(INSTALL_PATH) .tar.bz2: $(DL_PATH) $(INSTALL_PATH)
wget -c -O $@ $(URL) wget -c -O $@ $(URL)
touch $@ touch $@
@ -105,31 +113,30 @@ glibc: $(DL_PATH)/$(GLIBC_PACKAGE) $(DL_PATH)/$(GLIBC_PORTS_PACKAGE) $(DL_PATH)/
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-cross_hacks-1.patch && \ patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-cross_hacks-1.patch && \
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-libgcc_eh-1.patch && \ patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-libgcc_eh-1.patch && \
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-localedef_segfault-1.patch && \ patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-localedef_segfault-1.patch && \
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-mawk_fix-1.patch && \ patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-mawk_fix-1.patch
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-alpha_ioperm_fix-1.patch && \ # patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-alpha_ioperm_fix-1.patch && \
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-RTLD_SINGLE_THREAD_P-1.patch && \ # patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-RTLD_SINGLE_THREAD_P-1.patch && \
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-sysdep_cancel-1.patch && \ # patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-sysdep_cancel-1.patch && \
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-hppa_nptl-1.patch && \ # patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-hppa_nptl-1.patch
patch -Np1 -i $(PWD)/$(GLIBC_PATCHES_PATH)/glibc-2.6.1-for_gcc-4.3.patch
mkdir -p $(TOOLCHAIN_PATH)/$(GLIBC_VER)/build mkdir -p $(TOOLCHAIN_PATH)/$(GLIBC_VER)/build
cd $(TOOLCHAIN_PATH)/$(GLIBC_VER)/build && \ cd $(TOOLCHAIN_PATH)/$(GLIBC_VER)/build && \
echo "libc_cv_forced_unwind=yes" > config.cache && \ echo "libc_cv_forced_unwind=yes" > config.cache && \
echo "libc_cv_c_cleanup=yes" >> config.cache && \ echo "libc_cv_c_cleanup=yes" >> config.cache && \
echo "libc_cv_mips_tls=yes" >> config.cache && \ echo "libc_cv_mips_tls=yes" >> config.cache && \
BUILD_CC="gcc" CC="mipsel-linux-gcc" \ BUILD_CC=$(BUILD_CC) CC="mipsel-linux-gcc" \
AR="mipsel-linux-ar" RANLIB="mipsel-linux-ranlib" \ AR="mipsel-linux-ar" RANLIB="mipsel-linux-ranlib" \
../configure --prefix=/usr --libexecdir=/usr/lib/glibc \ ../configure --prefix=$(PWD)/$(INSTALL_PATH) --libexecdir=$(PWD)/$(INSTALL_PATH)/libexec/glibc \
--host=mipsel-linux --build=i686-pc-linux-gnu \ --host=mipsel-linux --build=i686-pc-linux-gnu \
--disable-profile --enable-add-ons --with-tls --enable-kernel=2.6.0 \ --disable-profile --enable-add-ons --with-tls --enable-kernel=2.6.0 \
--with-__thread --with-binutils=$(PWD)/$(INSTALL_PATH)/bin \ --with-__thread --with-binutils=$(PWD)/$(INSTALL_PATH)/bin \
--with-headers=$(PWD)/$(TOOLCHAIN_PATH)/$(KERNEL_HEADERS_VER) \ --with-headers=$(PWD)/$(TOOLCHAIN_PATH)/$(KERNEL_HEADERS_VER) \
--cache-file=config.cache && \ --cache-file=config.cache && \
make CFLAGS=$(CFLAGS) && \ make CFLAGS=$(CFLAGS) && make install
mkdir -p $(PWD)$(TOOLCHAIN_PATH)/$(GLIBC_VER)/glibc-install && \ cp $(GLIBC_PATCHES_PATH)/SUPPORTED $(TOOLCHAIN_PATH)/$(GLIBC_VER)/localedata/
make install_root=$(PWD)/$(TOOLCHAIN_PATH)/$(GLIBC_VER)/glibc-install install cd $(TOOLCHAIN_PATH)/$(GLIBC_VER)/build && \
make localedata/install-locales
touch $@ touch $@
### u-boot ### u-boot
.PHONY: u-boot .PHONY: u-boot
u-boot: u-boot:
@ -163,7 +170,7 @@ clean-toolchain: clean-glibc
rm -rf $(INSTALL_PATH) rm -rf $(INSTALL_PATH)
clean-glibc: clean-glibc:
rm -rf $(TOOLCHAIN_PATH)/$(GLIBC_VER) glibc rm -rf $(TOOLCHAIN_PATH)/$(GLIBC_VER) glibc
clean-u-boot: clean-u-boot:
rm -rf $(U-BOOT_PATH)/$(U-BOOT_VER) rm -rf $(U-BOOT_PATH)/$(U-BOOT_VER)

View File

@ -0,0 +1,5 @@
# This file names the currently supported and somewhat tested locales.
# If you have any additions please file a glibc bug report.
SUPPORTED-LOCALES=\
en_US.UTF-8/UTF-8