]> code.ossystems Code Review - openembedded-core.git/commitdiff
gcc: Convert cross recipes to stage in do_install. Also moves stdc++ and other libs...
authorRichard Purdie <rpurdie@linux.intel.com>
Mon, 16 Nov 2009 23:36:11 +0000 (23:36 +0000)
committerRichard Purdie <rpurdie@linux.intel.com>
Mon, 16 Nov 2009 23:36:11 +0000 (23:36 +0000)
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
16 files changed:
meta/packages/gcc/gcc-configure-cross.inc
meta/packages/gcc/gcc-cross-initial.inc
meta/packages/gcc/gcc-cross-initial_4.3.1.bb
meta/packages/gcc/gcc-cross-initial_4.3.2.bb
meta/packages/gcc/gcc-cross-initial_4.3.3.bb
meta/packages/gcc/gcc-cross-initial_csl-arm-2007q3.bb
meta/packages/gcc/gcc-cross-initial_csl-arm-2008q1.bb
meta/packages/gcc/gcc-cross-intermediate.inc
meta/packages/gcc/gcc-cross-intermediate_4.3.1.bb
meta/packages/gcc/gcc-cross-intermediate_4.3.2.bb
meta/packages/gcc/gcc-cross-intermediate_4.3.3.bb
meta/packages/gcc/gcc-cross-intermediate_csl-arm-2007q3.bb
meta/packages/gcc/gcc-cross-intermediate_csl-arm-2008q1.bb
meta/packages/gcc/gcc-cross-kernel.inc
meta/packages/gcc/gcc-cross.inc
meta/packages/gcc/gcc-package-cross.inc

index 8a47a45bc990c05ecfe98d48d6597e68fb717a23..569d4b7a82736ee8cb2cd3d440d4e7dfdf0995b4 100644 (file)
@@ -19,33 +19,4 @@ do_compile_prepend () {
 LIBGCCS_VAR = "-lgcc_s"
 LIBGCCS_VAR_avr32 = ""
 
-do_stage_append () {
-       for d in info man share/doc share/locale ; do
-               rm -rf ${CROSS_DIR}/$d
-       done
-
-       # We use libiberty from binutils
-       rm -f ${CROSS_DIR}/lib/libiberty.a
-
-       # We probably don't need these
-       rmdir ${CROSS_DIR}/include || :
-       
-       # Move libssp into staging
-       install -d ${STAGING_DIR_TARGET}${target_base_libdir}/
-       mv ${CROSS_DIR}/${TARGET_SYS}/lib/libssp* ${STAGING_DIR_TARGET}${target_base_libdir}/ || true
-
-       # We don't really need to keep this around
-       # rm -rf ${CROSS_DIR}/share but leave java there
-       for d in share/man share/info;
-       do
-               rm -rf ${CROSS_DIR}/$d
-       done
-
-       #fix up libsupc++ and libstdc++ la files
-       for d in lib lib/nof; do
-               sed -i "s|dependency_libs\s*=\s*.*|dependency_libs='-L${CROSS_DIR}/${TARGET_SYS}/$d ${LIBGCCS_VAR} -lc -lm '|" ${CROSS_DIR}/${TARGET_SYS}/$d/libsupc++.la || true
-               sed -i "s|dependency_libs\s*=\s*.*|dependency_libs='-L${CROSS_DIR}/${TARGET_SYS}/$d ${LIBGCCS_VAR} -lc -lm '|" ${CROSS_DIR}/${TARGET_SYS}/$d/libstdc++.la || true
-       done
-}
-
 do_package_write_ipk[depends] += "virtual/libc:do_package"
index a2c444557874eadc9175519622c11303e4576df3..8da7d7968ff933e41464a4947b24851209631762 100644 (file)
@@ -17,7 +17,3 @@ EXTRA_OECONF = "--with-local-prefix=${STAGING_DIR_TARGET}${target_prefix} \
                --with-sysroot=${STAGING_DIR_TARGET} \
                --with-build-sysroot=${STAGING_DIR_TARGET} \
                ${@get_gcc_fpu_setting(bb, d)}"
-
-do_install () {
-       :
-}
index 1543f72c9a363da76a6e987a0fdcf3dcc8bf9094..2cd2adc486c9d068a684cf4740306994b2a48d62 100644 (file)
@@ -9,7 +9,7 @@ EXTRA_OECONF += " --disable-libmudflap \
                  --disable-libssp"
 
 # Hack till we fix *libc properly
-do_stage_append() {
-        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index 1543f72c9a363da76a6e987a0fdcf3dcc8bf9094..2cd2adc486c9d068a684cf4740306994b2a48d62 100644 (file)
@@ -9,7 +9,7 @@ EXTRA_OECONF += " --disable-libmudflap \
                  --disable-libssp"
 
 # Hack till we fix *libc properly
-do_stage_append() {
-        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index 1543f72c9a363da76a6e987a0fdcf3dcc8bf9094..2cd2adc486c9d068a684cf4740306994b2a48d62 100644 (file)
@@ -9,7 +9,7 @@ EXTRA_OECONF += " --disable-libmudflap \
                  --disable-libssp"
 
 # Hack till we fix *libc properly
-do_stage_append() {
-        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index 99656dbe83bacd70cf3b7168c0dde732aa2e63c1..1a921d2d9c2524ff9ea381234c755b9eada94ed0 100644 (file)
@@ -6,7 +6,7 @@ S = "${WORKDIR}/gcc-4.2"
 EXTRA_OECONF += "--disable-libssp --disable-bootstrap --disable-libgomp --disable-libmudflap "
 
 # Hack till we fix *libc properly
-do_stage_append() {
-       ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+       ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index 99656dbe83bacd70cf3b7168c0dde732aa2e63c1..1a921d2d9c2524ff9ea381234c755b9eada94ed0 100644 (file)
@@ -6,7 +6,7 @@ S = "${WORKDIR}/gcc-4.2"
 EXTRA_OECONF += "--disable-libssp --disable-bootstrap --disable-libgomp --disable-libmudflap "
 
 # Hack till we fix *libc properly
-do_stage_append() {
-       ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+       ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index 57fa9494851dfe053f139f0df7e091f6c1092d6a..7cc822fb76062c8d9b0d32faf45f29d6aaab438b 100644 (file)
@@ -17,5 +17,5 @@ EXTRA_OECONF = "--with-local-prefix=${STAGING_DIR_TARGET}${target_prefix} \
                ${@get_gcc_fpu_setting(bb, d)}"
 
 do_install () {
-       :
+       oe_runmake 'DESTDIR=${D}' install
 }
index b0932f520d450408907a7a6323bfa4c89ebe2013..854911552ea6f0c9f891bb77fbc3305f1d04ac68 100644 (file)
@@ -8,7 +8,7 @@ EXTRA_OECONF += " --disable-libmudflap \
                  --disable-libssp"
 
 # Hack till we fix *libc properly
-do_stage_append() {
-        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index b0932f520d450408907a7a6323bfa4c89ebe2013..854911552ea6f0c9f891bb77fbc3305f1d04ac68 100644 (file)
@@ -8,7 +8,7 @@ EXTRA_OECONF += " --disable-libmudflap \
                  --disable-libssp"
 
 # Hack till we fix *libc properly
-do_stage_append() {
-        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index b0932f520d450408907a7a6323bfa4c89ebe2013..854911552ea6f0c9f891bb77fbc3305f1d04ac68 100644 (file)
@@ -8,7 +8,7 @@ EXTRA_OECONF += " --disable-libmudflap \
                  --disable-libssp"
 
 # Hack till we fix *libc properly
-do_stage_append() {
-        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+        ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index 114d9831c62c4203a14adbe752c6aa4ec88c9ae6..0dabd0b8db07709370e51637bc26a4c242d5c1d6 100644 (file)
@@ -6,7 +6,7 @@ S = "${WORKDIR}/gcc-4.2"
 EXTRA_OECONF += "--disable-libssp --disable-bootstrap --disable-libgomp --disable-libmudflap "
 
 # Hack till we fix *libc properly
-do_stage_append() {
-       ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+       ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index 114d9831c62c4203a14adbe752c6aa4ec88c9ae6..0dabd0b8db07709370e51637bc26a4c242d5c1d6 100644 (file)
@@ -6,7 +6,7 @@ S = "${WORKDIR}/gcc-4.2"
 EXTRA_OECONF += "--disable-libssp --disable-bootstrap --disable-libgomp --disable-libmudflap "
 
 # Hack till we fix *libc properly
-do_stage_append() {
-       ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
+do_install_append() {
+       ln -sf ${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include-fixed/* ${D}${CROSS_DIR}/lib/gcc/${TARGET_SYS}/${BINV}/include/
 }
 
index fe6539b808e368f79f2eaaba074c14c00dba8aa8..c602d725140a8b001f5327ad261a083e1f06afb6 100644 (file)
@@ -4,11 +4,11 @@
 PROVIDES = "virtual/${TARGET_PREFIX}gcc-${PV}"
 
 do_install () {
-       :
+       cd gcc
+       oe_runmake 'DESTDIR=${D}' install-common install-headers install-libgcc
+       install -m 0755 xgcc ${D}${CROSS_DIR}/bin/${TARGET_PREFIX}gcc-${PV}
 }
 
 do_stage () {
-       cd gcc
-       oe_runmake install-common install-headers install-libgcc
-       install -m 0755 xgcc ${CROSS_DIR}/bin/${TARGET_PREFIX}gcc-${PV}
-}
+    use_do_install_for_stage
+}
\ No newline at end of file
index 3485824b8a199ed8068c0f87c0c0df797e59ee06..2ba47fef5b3665886539c99dad1b0b918ecc14a7 100644 (file)
@@ -1,13 +1,8 @@
-# Path mangling needed by the cross packaging
-# Note that we use := here, and require that this is included at the correct 
-# point (before inheriting cross) to ensure that libdir and includedir are
-# target paths, not CROSS_DIR paths.
-target_libdir := "${libdir}"
-target_includedir := "${includedir}"
-target_base_libdir := "${base_libdir}"
-target_prefix := "${prefix}"
-
 inherit cross
 
 DEPENDS = "virtual/${TARGET_PREFIX}binutils virtual/${TARGET_PREFIX}libc-for-gcc"
 PROVIDES = "virtual/${TARGET_PREFIX}gcc virtual/${TARGET_PREFIX}g++"
+
+do_stage () {
+    use_do_install_for_stage
+}
index 9e54af856412c4c20e0ff21bda3d3954f0583e69..cb23b23f22823beeec7252e9741da65578febd99 100644 (file)
@@ -18,55 +18,41 @@ FILES_libstdc++ = "${target_libdir}/libstdc++.so.*"
 do_install () {
        oe_runmake 'DESTDIR=${D}' install
 
-       # Move libgcc_s into /lib
-        mkdir -p ${D}${target_base_libdir}
-        if [ -f ${D}${target_base_libdir}/libgcc_s.so.? ]; then
-                # Already in the right location
-                :
-        elif [ -f ${D}${prefix}/lib/libgcc_s.so.? ]; then
-                mv -f ${D}${prefix}/lib/libgcc_s.so* ${D}${target_base_libdir} || true
-        elif [  -f ${D}${prefix}/*/lib/nof/libgcc_s.so.? ]; then
-                mv -f ${D}${prefix}/*/lib/nof/libgcc_s.so* ${D}${target_base_libdir}
-        elif [  -f ${D}${prefix}/*/lib64/libgcc_s.so.? ]; then
-                mv -f ${D}${prefix}/*/lib64/libgcc_s.so* ${D}${target_base_libdir} || true 
-        else
-                mv -f ${D}${prefix}/*/lib/libgcc_s.so* ${D}${target_base_libdir} || true 
-        fi
-
-
-
-       # Move libstdc++ and libg2c into libdir (resetting our prefix to /usr
-        mkdir -p ${D}${target_libdir}
-
-        if [ -f ${D}${prefix}/*/lib/nof/libstdc++.so ]; then
-
-           mv -f ${D}${prefix}/*/lib/nof/libstdc++.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib/nof/libg2c.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib/nof/libgfortran*.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib/nof/libssp*.so* ${D}${target_libdir} || true      
-        elif [ -f ${D}${prefix}/*/lib64/libstdc++.so ]; then
-           mv -f ${D}${prefix}/*/lib64/libstdc++.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib64/libg2c.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib64/libgfortran*.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib64/libssp*.so* ${D}${target_libdir} || true
-        else
-           mv -f ${D}${prefix}/*/lib/libstdc++.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib/libg2c.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib/libgfortran*.so* ${D}${target_libdir} || true
-           mv -f ${D}${prefix}/*/lib/libssp*.so* ${D}${target_libdir} || true
-        fi
-
-       # Manually run the target stripper since we won't get it run by
-       # the packaging.
-       if [ "x${OLD_INHIBIT_PACKAGE_STRIP}" != "x1" ]; then
-               ${TARGET_PREFIX}strip ${D}${target_libdir}/libstdc++.so.*
-               ${TARGET_PREFIX}strip ${D}${target_libdir}/libg2c.so.* || true
-               ${TARGET_PREFIX}strip ${D}${target_base_libdir}/libgcc_s.so.* || true
-               ${TARGET_PREFIX}strip ${D}${target_libdir}/libgfortran*.so* || true
+       install -d ${D}${target_base_libdir}
+       install -d ${D}${target_libdir}
+
+       for d in ${TARGET_SYS}/lib/nof ${TARGET_SYS}/lib64 ${TARGET_SYS}/lib; do
+               if [ -d ${D}${prefix}/$d/ ]; then
+                       mv -f ${D}${prefix}/$d/libgcc* ${D}${target_base_libdir} || true
+                       mv -f ${D}${prefix}/$d/* ${D}${target_libdir} || true
+               fi
+       done
+
+       # Manually run the target stripper since we won't get it run by
+       # the packaging.
+       if [ "x${OLD_INHIBIT_PACKAGE_STRIP}" != "x1" ]; then
+               ${TARGET_PREFIX}strip ${D}${target_libdir}/libstdc++.so.* || true
+               ${TARGET_PREFIX}strip ${D}${target_libdir}/libg2c.so.* || true
+               ${TARGET_PREFIX}strip ${D}${target_base_libdir}/libgcc_s.so.* || true
+               ${TARGET_PREFIX}strip ${D}${target_libdir}/libgfortran*.so* || true
        fi
      
-       # Link gfortran to g77 to satisfy not-so-smart configure or hard coded g77
-       # gfortran is fully backwards compatible. This is a safe and practical solution. 
-       ln -sf ${CROSS_DIR}/bin/${TARGET_PREFIX}gfortran ${CROSS_DIR}/bin/${TARGET_PREFIX}g77 || true
-       ln -sf ${CROSS_DIR}/${TARGET_SYS}/bin/gfortran ${CROSS_DIR}/${TARGET_SYS}/bin/g77 || true
+       # Link gfortran to g77 to satisfy not-so-smart configure or hard coded g77
+       # gfortran is fully backwards compatible. This is a safe and practical solution. 
+       ln -sf ${CROSS_DIR}/bin/${TARGET_PREFIX}gfortran ${CROSS_DIR}/bin/${TARGET_PREFIX}g77 || true
+       ln -sf ${CROSS_DIR}/${TARGET_SYS}/bin/gfortran ${CROSS_DIR}/${TARGET_SYS}/bin/g77 || true
+
+       # Remove things we don't need but keep share/java
+       for d in info man share/doc share/locale share/man share/info; do
+               rm -rf ${D}${CROSS_DIR}/$d
+       done
+
+       #fix up libsupc++ and libstdc++ la files
+       for f in libssp.la libssp_nonshared.la libsupc++.la libstdc++.la ; do
+               # Remove any -L options from dependency_libs - we should never need them as the 
+               # files are in the sysroot
+               sed -i "s|\(dependency_libs\s*=.*\)-L\s*[^ ]*\(.*\)|\1\2|g" ${D}${target_libdir}/$f || true
+               # Set libdir correctly 
+               sed -i "s|libdir\s*=.*|libdir='${target_libdir}'|g" ${D}${target_libdir}/$f || true
+       done
 }