summaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2011-09-21 19:40:55 -0400
committerRich Felker <dalias@aerifal.cx>2011-09-21 19:40:55 -0400
commitd30c331d1f3262223a99408ff2d49641a46ce409 (patch)
treed3976bcc7957b68844042e2c3e7d427bfe420481 /tools
parent7dd86ec16852cf189e88fb2829caee4e114087e7 (diff)
downloadmusl-d30c331d1f3262223a99408ff2d49641a46ce409.tar.gz
new gcc wrapper now supports pre-4.4 gcc versions and is more robust
Diffstat (limited to 'tools')
-rw-r--r--tools/gen-musl-gcc.sh57
1 files changed, 40 insertions, 17 deletions
diff --git a/tools/gen-musl-gcc.sh b/tools/gen-musl-gcc.sh
index 42fdaec7..1ef0550f 100644
--- a/tools/gen-musl-gcc.sh
+++ b/tools/gen-musl-gcc.sh
@@ -3,6 +3,7 @@
printf '#!/bin/sh\n\nlibc_prefix="%s"\nldso_pathname="%s"\n' "$1" "$2"
cat <<"EOF"
+gcc=gcc
libc_lib=$libc_prefix/lib
libc_inc=$libc_prefix/include
libc_crt="$libc_lib/crt1.o"
@@ -10,23 +11,45 @@ libc_start="$libc_lib/crti.o"
libc_end="$libc_lib/crtn.o"
gcc_inc=$libc_inc
-libgcc="`gcc \"$@\" -print-file-name=libgcc.a`"
-libgcc=${libgcc%libgcc.a}
-
-gcc -wrapper sh,-c,'
-x= ; y= ; z= ; s= ; for i ; do
- [ "$z" ] || set -- ; z=1
- case "$i" in
- -shared) s=1 ; set -- "$@" -shared ;;
- -Lxxxxxx) x=1 ;;
- -xxxxxx) x= ; [ "$s" ] || set -- "$@" "'"$libc_start"'" "'"$libc_crt"'" ;;
- -l*) [ "$y" ] || set -- "$@" '"$libc_end"' ; set -- "$@" "$i" ; y=1 ;;
- *) [ "$x" ] || set -- "$@" "$i" ;;
- esac
+libgcc="$("$gcc" -print-file-name=libgcc.a)"
+libgcc=${libgcc%/libgcc.a}
+
+gccver=${libgcc##*/}
+gcctarget=${libgcc%/*}
+gcctarget=${gcctarget##*/}
+
+case "$gccver" in
+[0123].*|4.[01]*) ;;
+*) nosp=-fno-stack-protector ;;
+esac
+
+[ "x$1" = "x-V" ] && { printf "%s: -V not supported\n" "$0" ; exit 1 ; }
+
+for i ; do
+case "$skip$i" in
+-I|-L) skip=--- ; continue ;;
+-[cSE]|-M*) nolink=1 ;;
+-*) ;;
+*) havefile=1 ;;
+esac
+skip=
done
-exec "$0" "$@"
-' -std=gnu99 -nostdinc -nostdlib \
- -isystem "$libc_inc" -isystem "$gcc_inc" \
- -Wl,-xxxxxx "$@" -L"$libc_lib" -lc -L"$libgcc" -lgcc -Lxxxxxx \
+
+[ "$havefile" ] || nolink=1
+
+[ "$nolink" ] || {
+tmp_specs=$HOME/.specs.tmp.$$
+printf '*link_libgcc:\n\n\n' > "$tmp_specs" || exit 1
+exec 3<"$tmp_specs"
+rm -f "$tmp_specs"
+set -- -specs=/proc/self/fd/3 "$libc_start" "$libc_crt" "$@" "$libc_end" \
+ -Wl,--start-group -lc -lgcc -lgcc_eh -Wl,--end-group \
-Wl,-dynamic-linker,"$ldso_pathname" -Wl,-nostdlib
+}
+
+set -- -std=gnu99 -nostdinc -nostdlib $nosp \
+ -isystem "$libc_inc" -isystem "$gcc_inc" "$@" \
+ -L"$libc_lib" -L"$libgcc"
+
+exec "$gcc" "$@"
EOF