summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog26
-rw-r--r--gcc/Makefile.in1
-rw-r--r--gcc/config/darwin.h4
-rw-r--r--gcc/config/t-slibgcc-darwin3
-rw-r--r--gcc/gthr-gnat.c4
-rw-r--r--gcc/gthr-gnat.h4
-rw-r--r--gcc/gthr.h4
-rw-r--r--gcc/libgcc2.h4
-rw-r--r--gcc/mklibgcc.in999
-rw-r--r--gcc/unwind-dw2-fde.h4
-rw-r--r--gcc/unwind.h4
11 files changed, 641 insertions, 416 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index da0f52dbb34..9185db16e2a 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,29 @@
+2004-11-30 Zack Weinberg <zack@codesourcery.com>
+
+ * gthr-gnat.c, gthr-gnat.h, gthr.h, libgcc2.h, unwind-dw2-fde.h
+ * unwind.h: Surround all visibility pragmas with #ifndef HIDE_EXPORTS.
+
+ * mklibgcc.in: Drastic restructure for comprehensibility.
+ Remove the old hidden-directive hack.
+ Eliminate support for .txt files in LIB2ADD etc (never used).
+ Eliminate support for assembly source files in LIB2ADDEH* and
+ LIBUNWIND (also never used).
+ Build up dependency lists for libraries incrementally.
+ If we have SHLIB_LINK, compile each file twice, once for the
+ static and once for the shared library; also probe for
+ -fvisibility=hidden in the generated libgcc.mk. If found,
+ pass that and -DHIDE_EXPORTS to the compilation of every C
+ source file going into the static library. If found, generate
+ hidden-directive lists for every assembly source file going
+ into the static library, but incorporate them with -include
+ instead of ld -r.
+ Write comments into generated libgcc.mk to facilitate debugging.
+ * Makefile.in: Pass ASM_HIDDEN_OP to mklibgcc.
+ * config/t-slibgcc-darwin: Define ASM_HIDDEN_OP.
+
+ * config/darwin.h (REAL_LIBGCC_SPEC): Put -lgcc back in
+ -Zdynamiclib case.
+
2004-11-29 Richard Henderson <rth@redhat.com>
* expr.c (get_inner_reference): Handle REAL/IMAGPART_EXPR.
diff --git a/gcc/Makefile.in b/gcc/Makefile.in
index 570346fa4aa..13e659a5262 100644
--- a/gcc/Makefile.in
+++ b/gcc/Makefile.in
@@ -1235,6 +1235,7 @@ libgcc.mk: config.status Makefile mklibgcc $(LIB2ADD) $(LIB2ADD_ST) xgcc$(exeext
SHLIB_MAPFILES='$(SHLIB_MAPFILES)' \
SHLIB_NM_FLAGS='$(SHLIB_NM_FLAGS)' \
MULTILIB_OSDIRNAMES='$(MULTILIB_OSDIRNAMES)' \
+ ASM_HIDDEN_OP='$(ASM_HIDDEN_OP)' \
mkinstalldirs='$(mkinstalldirs)' \
$(SHELL) mklibgcc > tmp-libgcc.mk
mv tmp-libgcc.mk libgcc.mk
diff --git a/gcc/config/darwin.h b/gcc/config/darwin.h
index 246062d8c3d..5c9dc2e4cd3 100644
--- a/gcc/config/darwin.h
+++ b/gcc/config/darwin.h
@@ -316,8 +316,8 @@ extern const char *darwin_fix_and_continue_switch;
#define REAL_LIBGCC_SPEC \
"%{static|static-libgcc:-lgcc -lgcc_eh}\
%{!static:%{!static-libgcc:\
- %{!Zdynamiclib:%{!shared-libgcc:-lgcc -lgcc_eh}\
- %{shared-libgcc:-lgcc_s -lgcc} } %{Zdynamiclib:-lgcc_s}}}"
+ %{!Zdynamiclib:%{!shared-libgcc:-lgcc -lgcc_eh}\
+ %{shared-libgcc:-lgcc_s -lgcc}} %{Zdynamiclib:-lgcc_s -lgcc}}}"
/* We specify crt0.o as -lcrt0.o so that ld will search the library path. */
diff --git a/gcc/config/t-slibgcc-darwin b/gcc/config/t-slibgcc-darwin
index 11d652dae74..8127c944559 100644
--- a/gcc/config/t-slibgcc-darwin
+++ b/gcc/config/t-slibgcc-darwin
@@ -34,3 +34,6 @@ SHLIB_INSTALL = \
SHLIB_MKMAP = $(srcdir)/mkmap-flat.awk
SHLIB_MKMAP_OPTS = -v leading_underscore=1
SHLIB_MAPFILES = $(srcdir)/libgcc-std.ver
+
+# Must use a different directive for hidden visibility in assembly sources.
+ASM_HIDDEN_OP = .private_extern
diff --git a/gcc/gthr-gnat.c b/gcc/gthr-gnat.c
index 85d57bcdb15..2d55fdfc7ae 100644
--- a/gcc/gthr-gnat.c
+++ b/gcc/gthr-gnat.c
@@ -28,7 +28,9 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA
#include "gthr-gnat.h"
+#ifndef HIDE_EXPORTS
#pragma GCC visibility push(default)
+#endif
#ifdef __cplusplus
#define UNUSED(x)
@@ -81,4 +83,6 @@ __gthread_mutex_unlock (__gthread_mutex_t * UNUSED (mutex))
return 0;
}
+#ifndef HIDE_EXPORTS
#pragma GCC visibility pop
+#endif
diff --git a/gcc/gthr-gnat.h b/gcc/gthr-gnat.h
index 5b5665c9567..ee9ad947ab9 100644
--- a/gcc/gthr-gnat.h
+++ b/gcc/gthr-gnat.h
@@ -28,7 +28,9 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA
#ifndef GCC_GTHR_GNAT_H
#define GCC_GTHR_GNAT_H
+#ifndef HIDE_EXPORTS
#pragma GCC visibility push(default)
+#endif
/* Just provide compatibility for mutex handling. */
@@ -41,7 +43,9 @@ extern int __gthread_active_p (void);
extern int __gthread_mutex_lock (__gthread_mutex_t *);
extern int __gthread_mutex_unlock (__gthread_mutex_t *);
+#ifndef HIDE_EXPORTS
#pragma GCC visibility pop
+#endif
#endif /* ! GCC_GTHR_GNAT_H */
diff --git a/gcc/gthr.h b/gcc/gthr.h
index 70345a57c6a..ffd40d7aa5d 100644
--- a/gcc/gthr.h
+++ b/gcc/gthr.h
@@ -29,7 +29,9 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA
#ifndef GCC_GTHR_H
#define GCC_GTHR_H
+#ifndef HIDE_EXPORTS
#pragma GCC visibility push(default)
+#endif
/* If this file is compiled with threads support, it must
#define __GTHREADS 1
@@ -116,6 +118,8 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA
#include "gthr-single.h"
#endif
+#ifndef HIDE_EXPORTS
#pragma GCC visibility pop
+#endif
#endif /* ! GCC_GTHR_H */
diff --git a/gcc/libgcc2.h b/gcc/libgcc2.h
index ad7e5682e96..87de9014865 100644
--- a/gcc/libgcc2.h
+++ b/gcc/libgcc2.h
@@ -30,7 +30,9 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA
#ifndef GCC_LIBGCC2_H
#define GCC_LIBGCC2_H
+#ifndef HIDE_EXPORTS
#pragma GCC visibility push(default)
+#endif
extern int __gcc_bcmp (const unsigned char *, const unsigned char *, size_t);
extern void __clear_cache (char *, char *);
@@ -324,6 +326,8 @@ extern int __parityDI2 (UDWtype);
extern void __enable_execute_stack (void *);
+#ifndef HIDE_EXPORTS
#pragma GCC visibility pop
+#endif
#endif /* ! GCC_LIBGCC2_H */
diff --git a/gcc/mklibgcc.in b/gcc/mklibgcc.in
index 9bdbd82b0f9..80d016e988b 100644
--- a/gcc/mklibgcc.in
+++ b/gcc/mklibgcc.in
@@ -40,13 +40,17 @@
# SHLIB_NM_FLAGS
# SHLIB_INSTALL
# MULTILIB_OSDIRNAMES
+# ASM_HIDDEN_OP
# Make needs VPATH to be literal.
echo 'srcdir = @srcdir@'
echo 'VPATH = @srcdir@'
echo 'EQ = ='
+echo 'objects = $(filter %'$objext',$^)'
echo
-echo 'force:'
+echo '# Dependencies are accumulated as we go.'
+echo 'all: stmp-dirs'
+echo 'dirs = libgcc'
echo
# Library members defined in libgcc2.c.
@@ -89,290 +93,570 @@ libgcov_c_dep='stmp-dirs $(srcdir)/libgcov.c $(srcdir)/gcov-io.h $(srcdir)/gcov-
# Dependencies for fp-bit.c
fpbit_c_dep='stmp-dirs config.status tsystem.h'
+if [ "$SHLIB_LINK" ]; then
+ # Test -fvisibility=hidden. We need both a -fvisibility=hidden on
+ # the command line, and a #define to prevent libgcc2.h etc from
+ # overriding that with #pragmas. The dance with @ is to prevent
+ # echo from seeing anything it might take for an option.
+ echo "vis_hide := \$(strip \$(subst @,-,\\"
+ echo " \$(shell if echo 'void foo(void);' | \\"
+ echo " $gcc_compile -fvisibility=hidden -Werror \\"
+ echo " -c -xc - -o /dev/null 2> /dev/null; \\"
+ echo " then echo @fvisibility=hidden @DHIDE_EXPORTS; \\"
+ echo " fi)))"
+ echo
+
+ # If we have -fvisibility=hidden, then we need to generate hide
+ # lists for object files implemented in assembly. The default
+ # pseudo-op for this is ".hidden", but can be overridden with
+ # ASM_HIDDEN_OP.
+ [ "$ASM_HIDDEN_OP" ] || ASM_HIDDEN_OP=".hidden"
+
+ echo "ifneq (,\$(vis_hide))"
+ echo "define gen-hide-list"
+ echo "\$(NM_FOR_TARGET) ${SHLIB_NM_FLAGS} \$< | \\"
+ # non-GNU nm emits three fields even for undefined and typeless symbols,
+ # so explicitly omit them
+ echo " \$(AWK) 'NF == 3 && \$\$2 !~ /^[UN]\$\$/ { print \"\\t${ASM_HIDDEN_OP}\", \$\$3 }' > \$@T"
+ echo "mv -f \$@T \$@"
+ echo "endef"
+ echo "else"
+ echo "gen-hide-list = echo > \$@"
+ echo "endif"
+ echo
+else
+ # It is too hard to guarantee that vis_hide and gen-hide-list will never
+ # be referenced if SHLIB_LINK is not set, so set them to the values they'd
+ # have if SHLIB_LINK were set and we didn't have visibility support.
+ echo "vis_hide ="
+ echo "gen-hide-list = echo > \$@"
+fi
+
+# Remove any objects from lib2funcs and LIB2_DIVMOD_FUNCS that are
+# defined as optimized assembly code in LIB1ASMFUNCS.
+for name in $LIB1ASMFUNCS; do
+ lib2funcs=`echo $lib2funcs | sed -e 's/^'$name' //' \
+ -e 's/ '$name' / /' \
+ -e 's/ '$name'$//'`
+ LIB2_DIVMOD_FUNCS=`echo $LIB2_DIVMOD_FUNCS | sed -e 's/^'$name' //' \
+ -e 's/ '$name' / /' \
+ -e 's/ '$name'$//'`
+done
+
#
-# Build libgcc1 components.
+# Rules to generate object files.
#
-libgcc1_objs=""
+for ml in $MULTILIBS; do
-for name in $LIB1ASMFUNCS; do
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
- out="libgcc/${dir}/${name}${objext}"
+ # Work out relevant parameters that depend only on the multilib.
+ dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
+ flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
+ shlib_dir=
+ shlib_dir_qual=
+ libgcc_a=$dir/libgcc.a
+ libgcov_a=$dir/libgcov.a
+ libgcc_eh_a=
+ libgcc_s_so=
+ libunwind_a=
+ libunwind_so=
- echo ${out}: stmp-dirs '$(srcdir)/config/$(LIB1ASMSRC)'
- echo " $gcc_compile" $flags -DL$name -xassembler-with-cpp \
- -c '$(srcdir)/config/$(LIB1ASMSRC)' -o $out
+ if [ "$LIBUNWIND" ]; then
+ libunwind_a=$dir/libunwind.a
+ fi
+ if [ "$SHLIB_LINK" ]; then
+ if [ -z "$SHLIB_MULTILIB" ]; then
+ if [ "$dir" = . ]; then
+ libgcc_eh_a=$dir/libgcc_eh.a
+ libgcc_s_so_base=$dir/libgcc_s
+ libgcc_s_so=${libgcc_s_so_base}${SHLIB_EXT}
+ if [ "$LIBUNWIND" ]; then
+ libunwind_so_base=$dir/libunwind
+ libunwind_so=${libunwind_so_base}${SHLIB_EXT}
+ fi
+ else
+ libgcc_eh_a=$dir/libgcc_eh.a
+ libgcc_s_so_base=$dir/libgcc_s_`echo $dir | sed s,/,_,g`
+ libgcc_s_so=${libgcc_s_so_base}${SHLIB_EXT}
+ if [ "$LIBUNWIND" ]; then
+ libunwind_so_base=$dir/libunwind_`echo $dir | sed s,/,_,g`
+ libunwind_so=${libunwind_so_base}${SHLIB_EXT}
+ fi
+ fi
- # Remove any objects from lib2funcs and LIB2_DIVMOD_FUNCS that are
- # defined as optimized assembly code in LIB1ASMFUNCS.
- lib2funcs=`echo $lib2funcs | sed -e 's/^'$name' //' \
- -e 's/ '$name' / /' \
- -e 's/ '$name'$//'`
- LIB2_DIVMOD_FUNCS=`echo $LIB2_DIVMOD_FUNCS | sed -e 's/^'$name' //' \
- -e 's/ '$name' / /' \
- -e 's/ '$name'$//'`
- done
- libgcc1_objs="$libgcc1_objs ${name}${objext}"
-done
+ libgcc_s_soname=$libgcc_s_so_base
+ libunwind_soname=$libunwind_so_base
-#
-# Build libgcc2 components.
-#
+ if [ -n "$MULTILIB_OSDIRNAMES" ]; then
+ if [ "$dir" != . ]; then
+ gcc_multilib_dir=`./xgcc -B./ $flags --print-multi-directory`
+ os_multilib_dir=`./xgcc -B./ $flags --print-multi-os-directory`
+ shlib_dir="$dir"/
+ gcc_multilib_sup=`echo $gcc_multilib_dir | sed 's~^[^/]*/~~'`
+ os_multilib_base=`echo $os_multilib_dir | sed -n "s~/${gcc_multilib_sup}\$~~p"`
+ if [ -z "$os_multilib_base" ]; then
+ libgcc_s_soname=libgcc_s
+ libunwind_soname=libunwind
+ if [ "$os_multilib_dir" != "." ]; then
+ shlib_dir_qual="/$os_multilib_dir"
+ fi
+ else
+ libgcc_s_soname=libgcc_s_`echo $gcc_multilib_sup | sed s,/,_,g`
+ libunwind_soname=libunwind_`echo $gcc_multilib_sup | sed s,/,_,g`
+ shlib_dir_qual="/$os_multilib_base"
+ fi
+ fi
+ fi
-libgcc2_objs=""
-libgcc2_st_objs=""
-libgcc2_eh_static_objs=""
-libgcc2_eh_shared_objs=""
+ elif [ "$SHLIB_MULTILIB" = "$dir" ]; then
+ libgcc_eh_a=$dir/libgcc_eh.a
+ libgcc_s_so_base=$dir/libgcc_s
+ libgcc_s_so=${libgcc_s_so_base}${SHLIB_EXT}
+ if [ "$LIBUNWIND" ]; then
+ libunwind_so_base=$dir/libunwind
+ libunwind_so=${libunwind_so_base}${SHLIB_EXT}
+ fi
-for name in $lib2funcs; do
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
- out="libgcc/${dir}/${name}${objext}"
+ libgcc_s_soname=$libgcc_s_so_base
+ libunwind_soname=$libunwind_so_base
+ fi
+ fi
- echo $out: $libgcc2_c_dep
- echo " $gcc_compile" $flags -DL$name \
- -c '$(srcdir)/libgcc2.c' -o $out
+ echo
+ echo \#
+ echo \# ml: $ml
+ echo \# dir: $dir
+ echo \# flags: $flags
+ echo \# libgcc_a: $libgcc_a
+ echo \# libgcov_a: $libgcov_a
+ echo \# libgcc_eh_a: $libgcc_eh_a
+ echo \# libunwind_a: $libunwind_a
+ echo \#
+ echo \# gcc_multilib_dir: $gcc_multilib_dir
+ echo \# gcc_multilib_sup: $gcc_multilib_sup
+ echo \# os_multilib_dir: $os_multilib_dir
+ echo \# os_multilib_base: $os_multilib_base
+ echo \# shlib_dir: $shlib_dir
+ echo \# shlib_dir_qual: $shlib_dir_qual
+ echo \#
+ echo \# libgcc_s_so: $libgcc_s_so
+ echo \# libgcc_s_so_base: $libgcc_s_so_base
+ echo \# libgcc_s_soname: $libgcc_s_soname
+ echo \#
+ echo \# libunwind_so: $libunwind_so
+ echo \# libunwind_so_base: $libunwind_so_base
+ echo \# libunwind_soname: $libunwind_soname
+ echo \#
+ echo
+
+ # Update list of directories.
+ if [ $dir != . ]; then
+ echo "dirs += ${dir} libgcc/${dir}"
+ echo
+ fi
+
+ #
+ # Build libgcc1 components.
+ #
+ for name in $LIB1ASMFUNCS; do
+ if [ "$libgcc_s_so" ]; then
+ out="libgcc/${dir}/${name}${objext}"
+ outS="libgcc/${dir}/${name}_s${objext}"
+ outV="libgcc/${dir}/${name}.vis"
+
+ echo ${outS}: stmp-dirs '$(srcdir)/config/$(LIB1ASMSRC)'
+ echo " $gcc_compile" $flags -DL$name -xassembler-with-cpp \
+ -c '$(srcdir)/config/$(LIB1ASMSRC)' -o $outS
+
+ echo ${out}: stmp-dirs '$(srcdir)/config/$(LIB1ASMSRC)' ${outV}
+ echo " $gcc_compile" $flags -DL$name -xassembler-with-cpp \
+ -c '$(srcdir)/config/$(LIB1ASMSRC)' -include $outV -o $out
+
+ echo "${outV}: ${outS}; \$(gen-hide-list)"
+
+ echo $libgcc_a: $out
+ echo $libgcc_s_so: $outS
+ if [ "$SHLIB_MKMAP" ]; then
+ echo libgcc/${dir}/libgcc.map: $outS
+ fi
+ else
+ out="libgcc/${dir}/${name}${objext}"
+ echo ${out}: stmp-dirs '$(srcdir)/config/$(LIB1ASMSRC)'
+ echo " $gcc_compile" $flags -DL$name -xassembler-with-cpp \
+ -c '$(srcdir)/config/$(LIB1ASMSRC)' -o $out
+ echo $libgcc_a: $out
+ fi
done
- libgcc2_objs="$libgcc2_objs ${name}${objext}"
-done
-for name in $LIB2FUNCS_ST; do
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
- out="libgcc/${dir}/${name}${objext}"
+ #
+ # Build libgcc2 components.
+ #
- echo $out: $libgcc2_c_dep
- echo " $gcc_compile" $flags -DL$name \
- -c '$(srcdir)/libgcc2.c' -o $out
+ for name in $lib2funcs; do
+ if [ "$libgcc_s_so" ]; then
+ out="libgcc/${dir}/${name}${objext}"
+ outS="libgcc/${dir}/${name}_s${objext}"
+
+ echo $outS: $libgcc2_c_dep
+ echo " $gcc_compile" $flags -DL$name -c '$(srcdir)/libgcc2.c' -o $outS
+
+ echo $out: $libgcc2_c_dep
+ echo " $gcc_compile" $flags -DL$name '$(vis_hide)' \
+ -c '$(srcdir)/libgcc2.c' -o $out
+
+ echo $libgcc_a: $out
+ echo $libgcc_s_so: $outS
+ if [ "$SHLIB_MKMAP" ]; then
+ echo libgcc/${dir}/libgcc.map: $outS
+ fi
+ else
+ out="libgcc/${dir}/${name}${objext}"
+ echo ${out}: stmp-dirs '$(srcdir)/config/$(LIB1ASMSRC)'
+ echo " $gcc_compile" $flags -DL$name -c '$(srcdir)/libgcc2.c' -o $outS
+ echo $libgcc_a: $out
+ fi
done
- libgcc2_st_objs="$libgcc2_st_objs ${name}${objext}"
-done
-for name in $LIB2_DIVMOD_FUNCS; do
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
+ for name in $LIB2FUNCS_ST; do
out="libgcc/${dir}/${name}${objext}"
echo $out: $libgcc2_c_dep
- echo " $gcc_compile" $flags -DL$name \
- -c '$(srcdir)/libgcc2.c' -fexceptions -fnon-call-exceptions -o $out
+ echo " $gcc_compile" $flags -DL$name '$(vis_hide)' \
+ -c '$(srcdir)/libgcc2.c' -o $out
+ echo ${dir}/libgcc.a: $out
done
- libgcc2_objs="$libgcc2_objs ${name}${objext}"
-done
-if [ "$FPBIT" ]; then
- for name in $FPBIT_FUNCS; do
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
+ for name in $LIB2_DIVMOD_FUNCS; do
+ if [ "$libgcc_s_so" ]; then
out="libgcc/${dir}/${name}${objext}"
+ outS="libgcc/${dir}/${name}_s${objext}"
- echo $out: $FPBIT $fpbit_c_dep
- echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
- -c $FPBIT -o $out
- done
- libgcc2_objs="$libgcc2_objs ${name}${objext}"
- done
-fi
+ echo $outS: $libgcc2_c_dep
+ echo " $gcc_compile" $flags -DL$name \
+ -fexceptions -fnon-call-exceptions -c '$(srcdir)/libgcc2.c' -o $outS
-if [ "$DPBIT" ]; then
- for name in $DPBIT_FUNCS; do
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
- out="libgcc/${dir}/${name}${objext}"
+ echo $out: $libgcc2_c_dep
+ echo " $gcc_compile" $flags -DL$name '$(vis_hide)' \
+ -fexceptions -fnon-call-exceptions -c '$(srcdir)/libgcc2.c' -o $out
- echo $out: $DPBIT $fpbit_c_dep
- echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
- -c $DPBIT -o $out
- done
- libgcc2_objs="$libgcc2_objs ${name}${objext}"
+ echo $libgcc_a: $out
+ echo $libgcc_s_so: $outS
+ if [ "$SHLIB_MKMAP" ]; then
+ echo libgcc/${dir}/libgcc.map: $outS
+ fi
+ else
+ out="libgcc/${dir}/${name}${objext}"
+ echo ${out}: stmp-dirs '$(srcdir)/config/$(LIB1ASMSRC)'
+ echo " $gcc_compile" $flags -DL$name \
+ -fexceptions -fnon-call-exceptions -c '$(srcdir)/libgcc2.c' -o $outS
+ echo $libgcc_a: $out
+ fi
done
-fi
-if [ "$TPBIT" ]; then
- for name in $TPBIT_FUNCS; do
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
- out="libgcc/${dir}/${name}${objext}"
+ #
+ # Build software floating point functions.
+ #
+
+ if [ "$FPBIT" ]; then
+ for name in $FPBIT_FUNCS; do
+ if [ "$libgcc_s_so" ]; then
+ out="libgcc/${dir}/${name}${objext}"
+ outS="libgcc/${dir}/${name}_s${objext}"
+
+ echo $outS: $FPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ -c $FPBIT -o $outS
+
+ echo $out: $FPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ '$(vis_hide)' -c $FPBIT -o $out
+
+ echo $libgcc_a: $out
+ echo $libgcc_s_so: $outS
+ if [ "$SHLIB_MKMAP" ]; then
+ echo libgcc/${dir}/libgcc.map: $outS
+ fi
+ else
+ out="libgcc/${dir}/${name}${objext}"
+ echo $out: $FPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ -c $FPBIT -o $out
- echo $out: $TPBIT $fpbit_c_dep
- echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
- -c $TPBIT -o $out
+ echo $libgcc_a: $out
+ fi
done
- libgcc2_objs="$libgcc2_objs ${name}${objext}"
- done
-fi
+ fi
-for file in $LIB2ADD; do
- name=`echo $file | sed -e 's/[.][cSo]$//' -e 's/[.]asm$//' -e 's/[.]txt$//'`
- oname=`echo $name | sed -e 's,.*/,,'`
+ if [ "$DPBIT" ]; then
+ for name in $DPBIT_FUNCS; do
+ if [ "$libgcc_s_so" ]; then
+ out="libgcc/${dir}/${name}${objext}"
+ outS="libgcc/${dir}/${name}_s${objext}"
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
- out="libgcc/${dir}/${oname}${objext}"
- if [ ${name}.asm = ${file} ]; then
- flags="$flags -xassembler-with-cpp"
- fi
+ echo $outS: $DPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ -c $DPBIT -o $outS
- echo $out: stmp-dirs $file $libgcc_dep
- echo " $gcc_compile" $flags -c $file -o $out
- done
- libgcc2_objs="$libgcc2_objs ${oname}${objext}"
-done
+ echo $out: $DPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ '$(vis_hide)' -c $DPBIT -o $out
-for file in $LIB2ADDEH; do
- name=`echo $file | sed -e 's/[.][cSo]$//' -e 's/[.]asm$//' -e 's/[.]txt$//'`
- oname=`echo $name | sed -e 's,.*/,,'`
+ echo $libgcc_a: $out
+ echo $libgcc_s_so: $outS
+ if [ "$SHLIB_MKMAP" ]; then
+ echo libgcc/${dir}/libgcc.map: $outS
+ fi
+ else
+ out="libgcc/${dir}/${name}${objext}"
+ echo $out: $DPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ -c $DPBIT -o $out
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
- out="libgcc/${dir}/${oname}${objext}"
- if [ ${name}.asm = ${file} ]; then
- flags="$flags -xassembler-with-cpp"
- fi
+ echo $libgcc_a: $out
+ fi
+ done
+ fi
- echo $out: stmp-dirs $file $LIB2ADDEHDEP $libgcc_dep
- echo " $gcc_compile" $flags -fexceptions -c $file -o $out
- done
- if [ -z "$SHLIB_LINK" ]; then
- libgcc2_objs="$libgcc2_objs ${oname}${objext}"
+ if [ "$TPBIT" ]; then
+ for name in $TPBIT_FUNCS; do
+ if [ "$libgcc_s_so" ]; then
+ out="libgcc/${dir}/${name}${objext}"
+ outS="libgcc/${dir}/${name}_s${objext}"
+
+ echo $outS: $TPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ -c $TPBIT -o $outS
+
+ echo $out: $TPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ '$(vis_hide)' -c $TPBIT -o $out
+
+ echo $libgcc_a: $out
+ echo $libgcc_s_so: $outS
+ if [ "$SHLIB_MKMAP" ]; then
+ echo libgcc/${dir}/libgcc.map: $outS
+ fi
+ else
+ out="libgcc/${dir}/${name}${objext}"
+ echo $out: $TPBIT $fpbit_c_dep
+ echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name \
+ -c $TPBIT -o $out
+
+ echo $libgcc_a: $out
+ fi
+ done
fi
-done
-if [ "$SHLIB_LINK" ]; then
- # Those should be in libgcc_eh.a.
- for file in $LIB2ADDEHSTATIC; do
- name=`echo $file | sed -e 's/[.][cSo]$//' -e 's/[.]asm$//' -e 's/[.]txt$//'`
+ for file in $LIB2ADD; do
+ name=`echo $file | sed -e 's/[.][cS]$//' -e 's/[.]asm$//'`
oname=`echo $name | sed -e 's,.*/,,'`
- libgcc2_eh_static_objs="$libgcc2_eh_static_objs ${oname}${objext}"
- done
- # Those should be in libgcc.so.
- for file in $LIB2ADDEHSHARED; do
- name=`echo $file | sed -e 's/[.][cSo]$//' -e 's/[.]asm$//' -e 's/[.]txt$//'`
- oname=`echo $name | sed -e 's,.*/,,'`
- libgcc2_eh_shared_objs="$libgcc2_eh_shared_objs ${oname}${objext}"
+ if [ "$libgcc_s_so" ]; then
+ out="libgcc/${dir}/${oname}${objext}"
+ outS="libgcc/${dir}/${oname}_s${objext}"
+
+ case $file in
+ *.c)
+ echo $outS: stmp-dirs $file $libgcc_dep
+ echo " $gcc_compile" $flags -c $file -o $outS
+
+ echo $out: stmp-dirs $file $libgcc_dep
+ echo " $gcc_compile" $flags '$(vis_hide)' -c $file -o $out
+ ;;
+
+ *.asm | *.S)
+ outV="libgcc/${dir}/${oname}.vis"
+
+ echo $outS: stmp-dirs $file $libgcc_dep
+ echo " $gcc_compile" $flags -xassembler-with-cpp \
+ -c $file -o $outS
+
+ echo $out: stmp-dirs $file $libgcc_dep $outV
+ echo " $gcc_compile" $flags -xassembler-with-cpp \
+ -include $outV -c $file -o $out
+ echo "${outV}: ${outS}; \$(gen-hide-list)"
+ ;;
+
+ *)
+ echo "Unhandled extension: $file" >&2
+ exit 1
+ ;;
+ esac
+
+ echo $libgcc_a: $out
+ echo $libgcc_s_so: $outS
+ if [ "$SHLIB_MKMAP" ]; then
+ echo libgcc/${dir}/libgcc.map: $outS
+ fi
+ else
+ out="libgcc/${dir}/${oname}${objext}"
+ case $file in
+ *.c)
+ echo $out: stmp-dirs $file $libgcc_dep
+ echo " $gcc_compile" $flags -c $file -o $out
+ ;;
+
+ *.asm | *.S)
+ echo $out: stmp-dirs $file $libgcc_dep
+ echo " $gcc_compile" $flags -xassembler-with-cpp \
+ -c $file -o $out
+ ;;
+
+ *)
+ echo "Unhandled extension: $file" >&2
+ exit 1
+ ;;
+ esac
+
+ echo $libgcc_a: $out
+ fi
done
-fi
-for file in $LIB2ADD_ST; do
- name=`echo $file | sed -e 's/[.][cSo]$//' -e 's/[.]asm$//' -e 's/[.]txt$//'`
- oname=`echo $name | sed -e 's,.*/,,'`
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
+ for file in $LIB2ADD_ST; do
+ name=`echo $file | sed -e 's/[.][cSo]$//' -e 's/[.]asm$//'`
+ oname=`echo $name | sed -e 's,.*/,,'`
out="libgcc/${dir}/${oname}${objext}"
- if [ ${name}.asm = ${file} ]; then
- flags="$flags -xassembler-with-cpp"
- fi
- echo $out: stmp-dirs $file $libgcc_dep
- echo " $gcc_compile" $flags -c $file -o $out
+ case $file in
+ *.c)
+ echo $out: stmp-dirs $file $libgcc_dep
+ echo " $gcc_compile" $flags '$(vis_hide)' -c $file -o $out
+ ;;
+
+ *.asm | *.S)
+ # We may have to compile it twice in order to establish the list
+ # of symbols to be marked hidden.
+ if [ "$libgcc_so" ]; then
+ outV="libgcc/${dir}/${oname}.vis"
+ outT="libgcc/${dir}/${oname}_t${objext}"
+ echo ${outT}: stmp-dirs $file $libgcc_dep
+ echo " $gcc_compile" $flags -xassembler-with-cpp \
+ -c $file -o ${outT}
+ echo $out: stmp-dirs $file $libgcc_dep $outV
+ echo " $gcc_compile" $flags -xassembler-with-cpp \
+ -include $outV -c $file -o $out
+ echo "${outV}: ${outT}; \$(gen-hide-list)"
+ else
+ echo $out: stmp-dirs $file $libgcc_dep
+ echo " $gcc_compile" $flags -xassembler-with-cpp \
+ -c $file -o $out
+ fi
+ ;;
+
+ *)
+ echo "Unhandled extension: $file" >&2
+ exit 1
+ ;;
+ esac
+ echo $libgcc_a: $out
done
- libgcc2_st_objs="$libgcc2_st_objs ${oname}${objext}"
-done
-if [ "$LIBUNWIND" ]; then
- libunwind_static_objs=""
- libunwind_shared_objs=""
- for file in $LIBUNWIND; do
- name=`echo $file | sed -e 's/[.][cSo]$//' -e 's/[.]asm$//' -e 's/[.]txt$//'`
- oname=`echo $name | sed -e 's,.*/,,'`
+ # If we don't have libgcc_eh.a, only LIB2ADDEH matters. If we do, only
+ # LIB2ADDEHSTATIC and LIB2ADDEHSHARED matter. (Usually all three are
+ # identical.) We do _not_ handle assembly files in this context.
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
+ if [ "$libgcc_eh_a" ]; then
+ for file in $LIB2ADDEHSTATIC; do
+ case $file in
+ *.c) ;;
+ *) echo "Unhandled extension: $file">&2; exit 1 ;;
+ esac
+
+ name=`echo $file | sed -e 's/[.]c$//'`
+ oname=`echo $name | sed -e 's,.*/,,'`
out="libgcc/${dir}/${oname}${objext}"
- if [ ${name}.asm = ${file} ]; then
- flags="$flags -xassembler-with-cpp"
- fi
- echo $out: stmp-dirs $file $LIBUNWINDDEP
+ echo $out: stmp-dirs $file $LIB2ADDEHDEP $libgcc_dep
+ echo " $gcc_compile" $flags '$(vis_hide)' -fexceptions -c $file -o $out
+ echo $libgcc_eh_a: $out
+ done
+
+ for file in $LIB2ADDEHSHARED; do
+ case $file in
+ *.c) ;;
+ *) echo "Unhandled extension: $file">&2; exit 1 ;;
+ esac
+
+ name=`echo $file | sed -e 's/[.]c$//'`
+ oname=`echo $name | sed -e 's,.*/,,'`
+ out="libgcc/${dir}/${oname}_s${objext}"
+
+ echo $out: stmp-dirs $file $LIB2ADDEHDEP $libgcc_dep
echo " $gcc_compile" $flags -fexceptions -c $file -o $out
- echo ${out}s: stmp-dirs $file $LIBUNWINDDEP
- echo " $gcc_compile" $flags -fexceptions -DSHARED -c $file -o ${out}s
+ echo $libgcc_s_so: $out
+ if [ "$SHLIB_MKMAP" ]; then
+ echo libgcc/${dir}/libgcc.map: $out
+ fi
done
- libunwind_static_objs="$libunwind_static_objs ${oname}${objext}"
- libunwind_shared_objs="$libunwind_shared_objs ${oname}${objext}s"
- done
-fi
-#
-# build libgcov components
-#
+ else # no SHLIB_LINK
+ for file in $LIB2ADDEH; do
+ case $file in
+ *.c) ;;
+ *) echo "Unhandled extension: $file">&2; exit 1 ;;
+ esac
-libgcov_objs=""
+ name=`echo $file | sed -e 's/[.]c$//'`
+ oname=`echo $name | sed -e 's,.*/,,'`
+ out="libgcc/${dir}/${oname}${objext}"
-for name in $LIBGCOV; do
- for ml in $MULTILIBS; do
+ echo $out: stmp-dirs $file $LIB2ADDEHDEP $libgcc_dep
+ echo " $gcc_compile" $flags -fexceptions '$(vis_hide)' -c $file -o $out
+ echo $libgcc_a: $out
+ done
+ fi
+
+ # Again, this does not handle assembly.
+ if [ "$LIBUNWIND" ]; then
+ for file in $LIBUNWIND; do
+ case $file in
+ *.c) ;;
+ *) echo "Unhandled extension: $file">&2; exit 1 ;;
+ esac
+
+ name=`echo $file | sed -e 's/[.]c$//'`
+ oname=`echo $name | sed -e 's,.*/,,'`
+
+ if [ "$libunwind_so" ]; then
+ out="libgcc/${dir}/${oname}${objext}"
+ outS="libgcc/${dir}/${oname}_s${objext}"
+
+ echo $out: stmp-dirs $file $LIBUNWINDDEP
+ echo " $gcc_compile $flags -fexceptions \$(vis_hide) -c $file -o $out"
+
+ echo $outS: stmp-dirs $file $LIBUNWINDDEP
+ echo " $gcc_compile $flags -fexceptions -DSHARED -c $file -o $outS"
+
+ echo $libunwind_a: $out
+ echo $libunwind_so: $outS
+ else
+ out="libgcc/${dir}/${oname}${objext}"
+ echo $out: stmp-dirs $file $LIBUNWINDDEP
+ echo " $gcc_compile $flags -fexceptions \$(vis_hide) -c $file -o $out"
+ echo $libunwind_a: $out
+ fi
+ done
+ fi
+
+ #
+ # build libgcov components
+ #
+ for name in $LIBGCOV; do
dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
out="libgcc/${dir}/${name}${objext}"
echo $out: $libgcov_c_dep
- echo " $gcc_compile" $flags -DL$name \
- -c '$(srcdir)/libgcov.c' -o $out
+ echo " $gcc_compile $flags -DL$name -c \$(srcdir)/libgcov.c -o $out"
+ echo $libgcov_a: $out
done
- libgcov_objs="$libgcov_objs ${name}${objext}"
-done
-# SHLIB_MKMAP
-# SHLIB_MKMAP_OPTS
-# SHLIB_MAPFILES
-for ml in $MULTILIBS; do
+ # Library build rules.
dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
- libgcc_objs=""
- libgcc_eh_static_objs=""
- libgcc_eh_shared_objs=""
- for o in $libgcc1_objs; do
- libgcc_objs="$libgcc_objs libgcc/${dir}/$o"
- done
- for o in $libgcc2_objs; do
- libgcc_objs="$libgcc_objs libgcc/${dir}/$o"
- done
- for o in $libgcc2_eh_static_objs; do
- libgcc_eh_static_objs="$libgcc_eh_static_objs libgcc/${dir}/$o"
- done
- for o in $libgcc2_eh_shared_objs; do
- libgcc_eh_shared_objs="$libgcc_eh_shared_objs libgcc/${dir}/$o"
- done
- libgcc_sh_objs="$libgcc_objs $libgcc_eh_shared_objs"
- shlib_deps="$libgcc_sh_objs"
-
- libgcc_st_objs=""
- for o in $libgcc2_st_objs; do
- libgcc_st_objs="$libgcc_st_objs libgcc/${dir}/$o"
- done
-
- libgcov_a_objs=""
- for o in $libgcov_objs; do
- libgcov_a_objs="$libgcov_a_objs libgcc/${dir}/$o"
- done
-
- if [ "$LIBUNWIND" ]; then
- libunwind_a_objs=""
- for o in $libunwind_static_objs; do
- libunwind_a_objs="$libunwind_a_objs libgcc/${dir}/$o"
- done
- libunwind_sh_objs=""
- for o in $libunwind_shared_objs; do
- libunwind_sh_objs="$libunwind_sh_objs libgcc/${dir}/$o"
- done
- shlibunwind_deps="$libunwind_sh_objs"
- fi
-
+ # Map-file generation.
if [ "$SHLIB_LINK" -a "$SHLIB_MKMAP" ]; then
mapfile="libgcc/${dir}/libgcc.map"
tmpmapfile="libgcc/${dir}/tmp-libgcc.map"
@@ -381,43 +665,27 @@ for ml in $MULTILIBS; do
# The behavior of here documents is more predictable.
cat <<EOF
-${mapfile}: $SHLIB_MKMAP $SHLIB_MAPFILES $libgcc_sh_objs
- { \$(NM_FOR_TARGET) $SHLIB_NM_FLAGS $libgcc_sh_objs; echo %%; \\
+${mapfile}: $SHLIB_MKMAP $SHLIB_MAPFILES
+ { \$(NM_FOR_TARGET) $SHLIB_NM_FLAGS \$(objects); echo %%; \\
cat $SHLIB_MAPFILES \\
| sed -e '/^[ ]*#/d' \\
-e 's/^%\(if\|else\|elif\|endif\|define\)/#\1/' \\
| $gcc_compile $flags -E -xassembler-with-cpp -; \\
} | \$(AWK) -f $SHLIB_MKMAP $SHLIB_MKMAP_OPTS > ${tmpmapfile}
mv '$tmpmapfile' \$@
+$libgcc_s_so: ${mapfile}
EOF
fi
- shlib_deps="$shlib_deps $mapfile"
# Depend on EXTRA_MULTILIB_PARTS, since that's where crtbegin/end
# usually are put in a true multilib situation.
+ shlib_extra_deps=""
for f in $EXTRA_MULTILIB_PARTS; do
- shlib_deps="$shlib_deps $dir/$f"
+ shlib_extra_deps="$shlib_extra_deps $dir/$f"
done
+ echo $libgcc_s_so: $shlib_extra_deps
- libgcc_a_objs="$libgcc_objs $libgcc_st_objs"
-
- if [ "@libgcc_visibility@" = yes -a "$SHLIB_LINK" ]; then
- libgcc_a_objs=
- echo ""
- echo "libgcc/${dir}/stacknote.s: stmp-dirs"
- echo ' @( echo | $(GCC_FOR_TARGET) $(LIBGCC2_CFLAGS) '${flags}' -S -o - -xc - | grep .note.GNU-stack || : ) > $@.tmp'
- echo ' @mv -f $@.tmp $@'
- echo ""
- for o in $libgcc_objs $libgcc_st_objs; do
- # .oS objects will have all non-local symbol definitions .hidden
- oS=`echo ${o} | sed s~${objext}'$~.oS~g'`
- echo "${oS}: stmp-dirs libgcc/${dir}/stacknote.s ${o}"
- # non-GNU nm emits three fields even for undefined and typeless symbols,
- # so explicitly omit them
- echo ' ( $(NM_FOR_TARGET) '${SHLIB_NM_FLAGS} ${o}' | $(AWK) '\''NF == 3 && $$2 !~ /^[UN]$$/ { print "\t.hidden", $$3 }'\''; cat libgcc/${dir}/stacknote.s ) | $(GCC_FOR_TARGET) $(LIBGCC2_CFLAGS) '${flags}' -r -nostdinc -nostdlib -o $@ '${o}' -xassembler -'
- libgcc_a_objs="${libgcc_a_objs} ${oS}"
- done
- fi
+ # Static libraries.
# Each of these .a files depends on stmp-dirs. It would seem that
# this dependency is redundant, since each of the object files
@@ -426,186 +694,70 @@ EOF
# dependency is required; the directory containing the archive must
# exist before the archive itself can be created.
echo ""
- echo "${dir}/libgcc.a: stmp-dirs $libgcc_a_objs"
- echo " -rm -rf ${dir}/libgcc.a"
- echo ' $(AR_CREATE_FOR_TARGET)' ${dir}/libgcc.a $libgcc_a_objs
- echo ' $(RANLIB_FOR_TARGET)' ${dir}/libgcc.a
+ echo "$libgcc_a: stmp-dirs"
+ echo " -rm -f $libgcc_a"
+ echo ' $(AR_CREATE_FOR_TARGET)' $libgcc_a '$(objects)'
+ echo ' $(RANLIB_FOR_TARGET)' $libgcc_a
+ echo "all: $libgcc_a"
echo ""
- echo "${dir}/libgcov.a: stmp-dirs $libgcov_a_objs"
- echo " -rm -rf ${dir}/libgcov.a"
- echo ' $(AR_CREATE_FOR_TARGET)' ${dir}/libgcov.a $libgcov_a_objs
- echo ' $(RANLIB_FOR_TARGET)' ${dir}/libgcov.a
-
- if [ "$LIBUNWIND" ]; then
- echo ""
- echo "${dir}/libunwind.a: stmp-dirs $libunwind_a_objs"
- echo " -rm -rf ${dir}/libunwind.a"
- echo ' $(AR_CREATE_FOR_TARGET)' ${dir}/libunwind.a $libunwind_a_objs
- echo ' $(RANLIB_FOR_TARGET)' ${dir}/libunwind.a
+ echo "$libgcov_a: stmp-dirs"
+ echo " -rm -f $libgcov_a"
+ echo ' $(AR_CREATE_FOR_TARGET)' $libgcov_a '$(objects)'
+ echo ' $(RANLIB_FOR_TARGET)' $libgcov_a
+ echo "all: $libgcov_a"
+
+ # These libraries are not always built.
+ if [ "$libunwind_a" ]; then
echo ""
- echo "${dir}/libgcc.a: ${dir}/libunwind.a"
+ echo "$libunwind_a: stmp-dirs"
+ echo " -rm -f $libunwind_a"
+ echo ' $(AR_CREATE_FOR_TARGET)' $libunwind_a '$(objects)'
+ echo ' $(RANLIB_FOR_TARGET)' $libunwind_a
+ echo "all: $libunwind_a"
fi
- if [ "$SHLIB_LINK" ]; then
-
+ if [ "$libgcc_eh_a" ]; then
echo ""
- echo "${dir}/libgcc_eh.a: stmp-dirs $libgcc_eh_static_objs"
- echo " -rm -rf ${dir}/libgcc_eh.a"
- echo ' $(AR_CREATE_FOR_TARGET)' ${dir}/libgcc_eh.a $libgcc_eh_static_objs
+ echo "${dir}/libgcc_eh.a: stmp-dirs"
+ echo " -rm -f ${dir}/libgcc_eh.a"
+ echo ' $(AR_CREATE_FOR_TARGET)' ${dir}/libgcc_eh.a '$(objects)'
echo ' $(RANLIB_FOR_TARGET)' ${dir}/libgcc_eh.a
+ echo "all: $libgcc_eh_a"
+ fi
- if [ -z "$SHLIB_MULTILIB" ]; then
- if [ "$dir" = . ]; then
- shlib_base_name=libgcc_s
- shlibunwind_base_name=libunwind
- else
- shlib_base_name=libgcc_s_`echo $dir | sed s,/,_,g`
- shlibunwind_base_name=libunwind_`echo $dir | sed s,/,_,g`
- fi
- shlib_so_name="$shlib_base_name"
- shlibunwind_so_name="$shlibunwind_base_name"
- if [ "$LIBUNWIND" ]; then
- shlib_deps="$shlib_deps ${dir}/${shlibunwind_base_name}${SHLIB_EXT}"
- fi
- shlib_dir=
- shlib_slibdir_qual=
- if [ -n "$MULTILIB_OSDIRNAMES" ]; then
- if [ "$dir" != . ]; then
- gcc_multilib_dir=`./xgcc -B./ $flags --print-multi-directory`
- os_multilib_dir=`./xgcc -B./ $flags --print-multi-os-directory`
- shlib_dir="$dir"/
- gcc_multilib_sup=`echo $gcc_multilib_dir | sed 's~^[^/]*/~~'`
- os_multilib_base=`echo $os_multilib_dir | sed -n "s~/${gcc_multilib_sup}\$~~p"`
- if [ -z "$os_multilib_base" ]; then
- shlib_so_name=libgcc_s
- shlibunwind_so_name=libunwind
- if [ "$os_multilib_dir" != "." ]; then
- shlib_slibdir_qual="/$os_multilib_dir"
- fi
- else
- shlib_so_name=libgcc_s_`echo $gcc_multilib_sup | sed s,/,_,g`
- shlibunwind_so_name=libunwind_`echo $gcc_multilib_sup | sed s,/,_,g`
- shlib_slibdir_qual="/$os_multilib_base"
- fi
- fi
- fi
- echo ""
- echo "${dir}/${shlib_base_name}${SHLIB_EXT}: $shlib_deps"
- echo " $SHLIB_LINK" \
+ # Shared libraries.
+ if [ "$libgcc_s_so" ]; then
+ echo ""
+ echo "$libgcc_s_so: stmp-dirs $libunwind_so"
+ echo " $SHLIB_LINK" \
| sed -e "s%@multilib_flags@%$flags%g" \
-e "s%@multilib_dir@%$dir%g" \
- -e "s%@shlib_objs@%$libgcc_sh_objs%g" \
- -e "s%@shlib_base_name@%$shlib_base_name%g" \
+ -e "s%@shlib_objs@%\$(objects)%g" \
+ -e "s%@shlib_base_name@%$libgcc_s_so_base%g" \
+ -e "s%@shlib_so_name@%$libgcc_s_soname%g" \
-e "s%@shlib_map_file@%$mapfile%g" \
- -e "s%@shlib_so_name@%$shlib_so_name%g" \
-e "s%@shlib_dir@%$shlib_dir%g" \
- -e "s%@shlib_slibdir_qual@%%g"
- if [ "$LIBUNWIND" ]; then
- echo ""
- echo "${dir}/${shlibunwind_base_name}${SHLIB_EXT}: $shlibunwind_deps"
- echo " $SHLIBUNWIND_LINK" \
+ -e "s%@shlib_slibdir_qual@%$shlib_dir_qual%g"
+ echo "all: $libgcc_s_so"
+ fi
+
+ if [ "$libunwind_so" ]; then
+ echo ""
+ echo "$libunwind_so: stmp-dirs"
+ echo " $SHLIBUNWIND_LINK" \
| sed -e "s%@multilib_flags@%$flags%g" \
-e "s%@multilib_dir@%$dir%g" \
- -e "s%@shlib_objs@%$libunwind_sh_objs%g" \
- -e "s%@shlib_base_name@%$shlibunwind_base_name%g" \
- -e "s%@shlib_so_name@%$shlibunwind_so_name%g" \
+ -e "s%@shlib_objs@%\$(objects)%g" \
+ -e "s%@shlib_base_name@%$libunwind_so_base%g" \
+ -e "s%@shlib_so_name@%$libunwind_soname%g" \
-e "s%@shlib_dir@%$shlib_dir%g" \
- -e "s%@shlib_slibdir_qual@%%g"
- fi
- elif [ "$SHLIB_MULTILIB" = "$dir" ]; then
- shlib_base_name="libgcc_s";
- shlibunwind_base_name="libunwind";
- echo ""
- echo "${shlib_base_name}${SHLIB_EXT}: $shlib_deps"
- echo " $SHLIB_LINK" \
- | sed -e "s%@multilib_flags@%$flags%g" \
- -e "s%@multilib_dir@%$dir%g" \
- -e "s%@shlib_objs@%$libgcc_sh_objs%g" \
- -e "s%@shlib_base_name@%$shlib_base_name%g" \
- -e "s%@shlib_map_file@%$mapfile%g" \
- -e "s%@shlib_so_name@%$shlib_base_name%g" \
- -e "s%@shlib_dir@%%g" \
- -e "s%@shlib_slibdir_qual@%%g"
- if [ "$LIBUNWIND" ]; then
- echo ""
- echo "${shlibunwind_base_name}${SHLIB_EXT}: $shlibunwind_deps"
- echo " $SHLIBUNWIND_LINK" \
- | sed -e "s%@multilib_flags@%$flags%g" \
- -e "s%@multilib_dir@%$dir%g" \
- -e "s%@shlib_objs@%$libgcc_sh_objs%g" \
- -e "s%@shlib_base_name@%$shlibunwind_base_name%g" \
- -e "s%@shlib_so_name@%$shlibunwind_base_name%g" \
- -e "s%@shlib_dir@%%g" \
- -e "s%@shlib_slibdir_qual@%%g"
- fi
- fi
+ -e "s%@shlib_slibdir_qual@%$shlib_dir_qual%g"
+ echo "all: $libunwind_so"
fi
-done
-dirs=libgcc
-for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- if [ $dir != . ]; then
- dirs="$dirs ${dir} libgcc/${dir}"
- fi
-done
-echo ''
-echo 'libgcc-stage-start:'
-echo ' for dir in '"${dirs}"'; do \'
-echo ' if [ -d $(stage)/$$dir ]; then true; else '$mkinstalldirs' $(stage)/$$dir; fi; \'
-echo ' done'
-echo ' -for dir in '"${dirs}"'; do \'
-echo ' mv $$dir/*'"${objext}"' $(stage)/$$dir; \'
-echo ' mv $$dir/*'"${objext}s"' $(stage)/$$dir || true; \'
-echo ' test ! -f $$dir/stacknote.s || mv $$dir/stacknote.s $(stage)/$$dir; \'
-echo ' test ! -f $$dir/libgcc.a || mv $$dir/lib* $(stage)/$$dir; \'
-echo ' done'
-
-echo ""
-all=stmp-dirs
-dirs=libgcc
-
-for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- if [ $dir != . ]; then
- dirs="$dirs ${dir} libgcc/${dir}"
- fi
- all="$all ${dir}/libgcc.a ${dir}/libgcov.a"
- if [ "$LIBUNWIND" ]; then
- all="$all ${dir}/libunwind.a"
- fi
- if [ "$SHLIB_LINK" ]; then
- all="$all ${dir}/libgcc_eh.a"
- if [ -z "$SHLIB_MULTILIB" ]; then
- if [ "$dir" = "." ]; then
- suff="";
- else
- suff=_`echo $dir | sed s,/,_,g`
- fi
- all="$all ${dir}/libgcc_s${suff}${SHLIB_EXT}"
- if [ "$LIBUNWIND" ]; then
- all="$all ${dir}/${dir}/libunwind${suff}${SHLIB_EXT}"
- fi
- elif [ "$SHLIB_MULTILIB" = "$dir" ]; then
- all="$all libgcc_s${SHLIB_EXT}"
- if [ "$LIBUNWIND" ]; then
- all="$all ${dir}/${dir}/libunwind${SHLIB_EXT}"
- fi
- fi
- fi
-done
-
-echo 'stmp-dirs: force'
-echo ' for d in '"$dirs"'; do \'
-echo ' if [ -d $$d ]; then true; else '$mkinstalldirs' $$d; fi; \'
-echo ' done'
-echo ' if [ -f stmp-dirs ]; then true; else touch stmp-dirs; fi'
-
-for f in $EXTRA_MULTILIB_PARTS; do
- for ml in $MULTILIBS; do
- dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
- flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
+ # EXTRA_MULTILIB_PARTS.
+ for f in $EXTRA_MULTILIB_PARTS; do
case $dir in
.) out=$f ; t= ;;
*) out=$dir/$f ; t=$dir/ ;;
@@ -620,16 +772,33 @@ for f in $EXTRA_MULTILIB_PARTS; do
echo " $make_compile" \\
echo ' LIBGCC2_CFLAGS="$(LIBGCC2_CFLAGS)' $flags '" ' \\
echo ' MULTILIB_CFLAGS="'$flags'"' T=$t $targ
-
- all="$all $out"
+ echo "all: $out"
done
-done
-echo ""
-echo "all: $all"
+done # ml in MULTILIBS
+
+echo
+echo "libgcc-stage-start:"
+echo " for dir in \$(dirs); do \\"
+echo " if [ -d \$(stage)/\$\$dir ]; then :; \\"
+echo " else $mkinstalldirs \$(stage)/\$\$dir; fi; \\"
+echo " done"
+echo " -for dir in \$(dirs); do \\"
+echo " mv \$\$dir/*${objext} \$(stage)/\$\$dir; \\"
+echo " mv \$\$dir/*.vis \$(stage)/\$\$dir; \\"
+echo " mv \$\$dir/*.map \$(stage)/\$\$dir; \\"
+echo " test ! -f \$\$dir/libgcc.a || mv \$\$dir/lib* \$(stage)/\$\$dir; \\"
+echo " done"
+
+echo
+echo "stmp-dirs:"
+echo " for d in \$(dirs); do \\"
+echo " if [ -d \$\$d ]; then true; else $mkinstalldirs \$\$d; fi; \\"
+echo " done"
+echo " if [ -f stmp-dirs ]; then true; else touch stmp-dirs; fi"
echo ""
-echo "install: $all"
+echo "install: all"
for ml in $MULTILIBS; do
dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'`
flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`;
@@ -728,3 +897,5 @@ for f in $EXTRA_MULTILIB_PARTS; do
echo ' $(INSTALL_DATA)' $out $ldir/
done
done
+
+echo '.PHONY: all install'
diff --git a/gcc/unwind-dw2-fde.h b/gcc/unwind-dw2-fde.h
index 47ec3ab3649..93976e2fd51 100644
--- a/gcc/unwind-dw2-fde.h
+++ b/gcc/unwind-dw2-fde.h
@@ -32,7 +32,9 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA
#ifndef GCC_UNWIND_DW2_FDE_H
#define GCC_UNWIND_DW2_FDE_H
+#ifndef HIDE_EXPORTS
#pragma GCC visibility push(default)
+#endif
struct fde_vector
{
@@ -179,6 +181,8 @@ last_fde (struct object *obj __attribute__ ((__unused__)), const fde *f)
#endif
}
+#ifndef HIDE_EXPORTS
#pragma GCC visibility pop
+#endif
#endif /* unwind-dw2-fde.h */
diff --git a/gcc/unwind.h b/gcc/unwind.h
index ca917b0ad2c..7244fd457c7 100644
--- a/gcc/unwind.h
+++ b/gcc/unwind.h
@@ -31,7 +31,9 @@
#ifndef _UNWIND_H
#define _UNWIND_H
+#ifndef HIDE_EXPORTS
#pragma GCC visibility push(default)
+#endif
#ifdef __cplusplus
extern "C" {
@@ -231,6 +233,8 @@ extern void * _Unwind_FindEnclosingFunction (void *pc);
}
#endif
+#ifndef HIDE_EXPORTS
#pragma GCC visibility pop
+#endif
#endif /* unwind.h */