mirror of
https://github.com/motioneye-project/motioneyeos.git
synced 2025-07-28 05:36:32 +00:00
Use a local copy of the source when building gcc-target (since
we hacked up the source used to build the cross compiler). Fix the crt1.o not found problems. It turns out gcc was thinking it was acting as a cross compiler, which is clearly not what we want here. With this, everything seems to be working nicely for both C and C++.
This commit is contained in:
parent
1ffc9aa94a
commit
de51377181
@ -25,9 +25,10 @@ ifneq ($(GCC_2_95_TOOLCHAIN),true)
|
|||||||
#GCC_CAT:=zcat
|
#GCC_CAT:=zcat
|
||||||
|
|
||||||
# Shiney new stuff...
|
# Shiney new stuff...
|
||||||
GCC_SITE:=http://gcc.get-software.com/releases/gcc-3.3.1
|
GCC_VERSION:=3.3.1
|
||||||
GCC_SOURCE:=gcc-3.3.1.tar.bz2
|
GCC_SITE:=http://gcc.get-software.com/releases/gcc-$(GCC_VERSION)
|
||||||
GCC_DIR:=$(TOOL_BUILD_DIR)/gcc-3.3.1
|
GCC_SOURCE:=gcc-$(GCC_VERSION).tar.bz2
|
||||||
|
GCC_DIR:=$(TOOL_BUILD_DIR)/gcc-$(GCC_VERSION)
|
||||||
GCC_CAT:=bzcat
|
GCC_CAT:=bzcat
|
||||||
|
|
||||||
#############################################################
|
#############################################################
|
||||||
@ -278,24 +279,41 @@ ifeq ($(HOST_ARCH),$(ARCH))
|
|||||||
TARGET_GCC_ARGS=$(TARGET_CONFIGURE_OPTS)
|
TARGET_GCC_ARGS=$(TARGET_CONFIGURE_OPTS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
$(GCC_BUILD_DIR3)/.gcc3_3_build_hacks: $(GCC_DIR3_DEPENDS)
|
# We need to unpack a pristine source tree to avoid some of
|
||||||
|
# the previously applied hacks, which do not apply here...
|
||||||
|
$(GCC_BUILD_DIR3)/.unpacked: $(DL_DIR)/$(GCC_SOURCE)
|
||||||
|
$(GCC_CAT) $(DL_DIR)/$(GCC_SOURCE) | tar -C $(BUILD_DIR) -xvf -
|
||||||
|
mv $(BUILD_DIR)/gcc-$(GCC_VERSION) $(GCC_BUILD_DIR3)
|
||||||
|
touch $(GCC_BUILD_DIR3)/.unpacked
|
||||||
|
|
||||||
|
$(GCC_BUILD_DIR3)/.patched: $(GCC_BUILD_DIR3)/.unpacked
|
||||||
|
# Apply any files named gcc-*.patch from the source directory to gcc
|
||||||
|
$(SOURCE_DIR)/patch-kernel.sh $(GCC_BUILD_DIR3) $(SOURCE_DIR) gcc-*.patch
|
||||||
|
touch $(GCC_BUILD_DIR3)/.patched
|
||||||
|
|
||||||
|
$(GCC_BUILD_DIR3)/.gcc3_3_build_hacks: $(GCC_BUILD_DIR3)/.patched
|
||||||
#
|
#
|
||||||
# Make certain the uClibc start files are found
|
# Hack things to use the correct shared lib loader
|
||||||
#
|
#
|
||||||
perl -i -p -e "s,standard_startfile_prefix_1 = \".*,standard_startfile_prefix_1=\
|
(cd $(GCC_BUILD_DIR3); set -e; export LIST=`grep -lr -- "-dynamic-linker.*\.so[\.0-9]*" *`;\
|
||||||
\"/lib/\";,;" $(GCC_DIR)/gcc/gcc.c;
|
if [ -n "$$LIST" ] ; then \
|
||||||
perl -i -p -e "s,standard_startfile_prefix_2 = \".*,standard_startfile_prefix_2=\
|
perl -i -p -e "s,-dynamic-linker.*\.so[\.0-9]*},\
|
||||||
\"/usr/lib/\";,;" $(GCC_DIR)/gcc/gcc.c;
|
-dynamic-linker /lib/ld-uClibc.so.0},;" $$LIST; fi);
|
||||||
#
|
#
|
||||||
# Make certain the uClibc include files are found
|
# Prevent gcc from using the unwind-dw2-fde-glibc code
|
||||||
#
|
#
|
||||||
perl -i -p -e "s,^NATIVE_SYSTEM_HEADER_DIR.*,NATIVE_SYSTEM_HEADER_DIR=\
|
perl -i -p -e "s,^#ifndef inhibit_libc,#define inhibit_libc\n\
|
||||||
/usr/include,;" $(GCC_DIR)/gcc/Makefile.in;
|
#ifndef inhibit_libc,g;" $(GCC_BUILD_DIR3)/gcc/unwind-dw2-fde-glibc.c;
|
||||||
perl -i -p -e "s,^CROSS_SYSTEM_HEADER_DIR.*,CROSS_SYSTEM_HEADER_DIR=\
|
#
|
||||||
/usr/include,;" $(GCC_DIR)/gcc/Makefile.in;
|
# Hack up the soname for libstdc++
|
||||||
perl -i -p -e "s,^#define.*STANDARD_INCLUDE_DIR.*,#define STANDARD_INCLUDE_DIR \
|
#
|
||||||
\"/usr/include\",;" $(GCC_DIR)/gcc/cppdefault.h;
|
perl -i -p -e "s,\.so\.1,.so.0.9.9,g;" $(GCC_BUILD_DIR3)/gcc/config/t-slibgcc-elf-ver;
|
||||||
mkdir -p $(GCC_BUILD_DIR3)
|
perl -i -p -e "s,-version-info.*[0-9]:[0-9]:[0-9],-version-info 9:9:0,g;" \
|
||||||
|
$(GCC_BUILD_DIR3)/libstdc++-v3/src/Makefile.am \
|
||||||
|
$(GCC_BUILD_DIR3)/libstdc++-v3/src/Makefile.in;
|
||||||
|
perl -i -p -e "s,3\.0\.0,9.9.0,g;" $(GCC_BUILD_DIR3)/libstdc++-v3/acinclude.m4 \
|
||||||
|
$(GCC_BUILD_DIR3)/libstdc++-v3/aclocal.m4 \
|
||||||
|
$(GCC_BUILD_DIR3)/libstdc++-v3/configure;
|
||||||
touch $(GCC_BUILD_DIR3)/.gcc3_3_build_hacks
|
touch $(GCC_BUILD_DIR3)/.gcc3_3_build_hacks
|
||||||
|
|
||||||
$(GCC_BUILD_DIR3)/.configured: $(GCC_BUILD_DIR3)/.gcc3_3_build_hacks
|
$(GCC_BUILD_DIR3)/.configured: $(GCC_BUILD_DIR3)/.gcc3_3_build_hacks
|
||||||
@ -320,27 +338,20 @@ $(GCC_BUILD_DIR3)/.configured: $(GCC_BUILD_DIR3)/.gcc3_3_build_hacks
|
|||||||
GCC_FOR_TARGET=$(TARGET_CROSS)gcc \
|
GCC_FOR_TARGET=$(TARGET_CROSS)gcc \
|
||||||
CXX_FOR_TARGET=$(TARGET_CROSS)g++ \
|
CXX_FOR_TARGET=$(TARGET_CROSS)g++ \
|
||||||
RANLIB_FOR_TARGET=$(TARGET_CROSS)ranlib \
|
RANLIB_FOR_TARGET=$(TARGET_CROSS)ranlib \
|
||||||
$(GCC_DIR)/configure \
|
./configure \
|
||||||
--target=$(GNU_TARGET_NAME) \
|
--target=$(GNU_TARGET_NAME) \
|
||||||
--host=$(GNU_TARGET_NAME) \
|
--host=$(GNU_TARGET_NAME) \
|
||||||
--build=$(ARCH)-linux \
|
--build=$(ARCH)-linux \
|
||||||
--prefix=/usr \
|
--prefix=/usr \
|
||||||
--exec-prefix=/usr \
|
|
||||||
--bindir=/usr/bin \
|
|
||||||
--sbindir=/usr/sbin \
|
|
||||||
--sysconfdir=/etc \
|
|
||||||
--datadir=/usr/share \
|
|
||||||
--localstatedir=/var \
|
|
||||||
--mandir=/usr/man \
|
--mandir=/usr/man \
|
||||||
--infodir=/usr/info \
|
--infodir=/usr/info \
|
||||||
--with-local-prefix=/usr/local \
|
--with-gxx-include-dir=/usr/include/c++/3.3 \
|
||||||
--libdir=/usr/lib \
|
--enable-shared \
|
||||||
--disable-shared $(MULTILIB) \
|
$(MULTILIB) \
|
||||||
--enable-target-optspace $(DISABLE_NLS) \
|
--enable-target-optspace $(DISABLE_NLS) \
|
||||||
--with-gnu-ld --disable-__cxa_atexit \
|
--with-gnu-ld --disable-__cxa_atexit \
|
||||||
--enable-languages=$(TARGET_LANGUAGES) \
|
--enable-languages=$(TARGET_LANGUAGES) \
|
||||||
$(EXTRA_GCC_CONFIG_OPTIONS) \
|
$(EXTRA_GCC_CONFIG_OPTIONS) \
|
||||||
--program-prefix="" \
|
|
||||||
);
|
);
|
||||||
touch $(GCC_BUILD_DIR3)/.configured
|
touch $(GCC_BUILD_DIR3)/.configured
|
||||||
#Fixme -- for locale handling?
|
#Fixme -- for locale handling?
|
||||||
@ -390,18 +401,6 @@ $(TARGET_DIR)/usr/bin/gcc: $(GCC_BUILD_DIR3)/.compiled
|
|||||||
GCC_FOR_TARGET=$(TARGET_CROSS)gcc \
|
GCC_FOR_TARGET=$(TARGET_CROSS)gcc \
|
||||||
CXX_FOR_TARGET=$(TARGET_CROSS)g++ \
|
CXX_FOR_TARGET=$(TARGET_CROSS)g++ \
|
||||||
RANLIB_FOR_TARGET=$(TARGET_CROSS)ranlib \
|
RANLIB_FOR_TARGET=$(TARGET_CROSS)ranlib \
|
||||||
prefix=/usr \
|
|
||||||
exec_prefix=/usr \
|
|
||||||
bindir=/usr/bin \
|
|
||||||
sbindir=/usr/sbin \
|
|
||||||
libexecdir=/usr/lib \
|
|
||||||
datadir=/usr/share \
|
|
||||||
sysconfdir=/etc \
|
|
||||||
localstatedir=/var \
|
|
||||||
libdir=/usr/lib \
|
|
||||||
infodir=/usr/info \
|
|
||||||
mandir=/usr/man \
|
|
||||||
includedir=/usr/include \
|
|
||||||
DESTDIR=$(TARGET_DIR) install
|
DESTDIR=$(TARGET_DIR) install
|
||||||
(cd $(TARGET_DIR)/usr/bin; ln -fs gcc cc)
|
(cd $(TARGET_DIR)/usr/bin; ln -fs gcc cc)
|
||||||
(cd $(TARGET_DIR)/lib; ln -fs /usr/bin/cpp)
|
(cd $(TARGET_DIR)/lib; ln -fs /usr/bin/cpp)
|
||||||
@ -417,7 +416,9 @@ $(TARGET_DIR)/usr/bin/gcc: $(GCC_BUILD_DIR3)/.compiled
|
|||||||
rm -f $(TARGET_DIR)/lib/libstdc++.so
|
rm -f $(TARGET_DIR)/lib/libstdc++.so
|
||||||
-(cd $(TARGET_DIR)/usr/lib; ln -fs /lib/libstdc++.so.5.0.5 libstdc++.so)
|
-(cd $(TARGET_DIR)/usr/lib; ln -fs /lib/libstdc++.so.5.0.5 libstdc++.so)
|
||||||
# A nasty hack to work around g++ adding -lgcc_eh to the link
|
# A nasty hack to work around g++ adding -lgcc_eh to the link
|
||||||
-(cd $(TARGET_DIR)/usr/lib/gcc-lib/$(ARCH)-linux/3.3.1/ ; ln -s libgcc.a libgcc_eh.a)
|
-(cd $(TARGET_DIR)/usr/lib/gcc-lib/$(ARCH)-linux/$(GCC_VERSION)/ ; ln -s libgcc.a libgcc_eh.a)
|
||||||
|
# Make sure gcc does not think we are cross compiling
|
||||||
|
perl -i -p -e "s/^1/0/;" $(TARGET_DIR)/usr/lib/gcc-lib/$(ARCH)-linux/$(GCC_VERSION)/specs
|
||||||
-(cd $(TARGET_DIR)/bin; find -type f | xargs $(STRIP) > /dev/null 2>&1)
|
-(cd $(TARGET_DIR)/bin; find -type f | xargs $(STRIP) > /dev/null 2>&1)
|
||||||
-(cd $(TARGET_DIR)/usr/bin; find -type f | xargs $(STRIP) > /dev/null 2>&1)
|
-(cd $(TARGET_DIR)/usr/bin; find -type f | xargs $(STRIP) > /dev/null 2>&1)
|
||||||
rm -f $(TARGET_DIR)/usr/lib/*.la*
|
rm -f $(TARGET_DIR)/usr/lib/*.la*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user