When checking in the Solaris toplevel libgcc patch on wednesday, I
notice that I still had LIB2ADDEH and LIB2ADDEHDEP in gcc/config/t-sol2.

The latter is completely unused now that libgcc does automatic
dependency generation and I had already removed it in
libgcc/config/t-sol2.  This patch removes it completely.

I also noticed that the move of LIB2ADDEH to libgcc should have made the
variable unnecessary in gcc and was about to remove it on checkin
(seemed obvious at the time), but fortunately I didn't because it
completely broke Solaris 11 EH:

libgcc/Makefile.in completely ignores LIB2ADDEH with --enable-shared,
but only looks at LIB2ADDEHSTATIC and LIB2ADDEHSHARED.  Those variables
are only set in libgcc.mvars from gcc/Makefile.in, and if you remove
them from gcc/config, hell breaks loose ;-(  In the Solaris 11 case, we
need unwind-dw2-fde-glibc.c, but miss it because the LIB2ADDEH default
in gcc/Makefile.in doesn't include it.  I also noticed that
libgcc/config/t-sol2 LIB2ADDEH incorrectly refers to $(srcdir), not
$(gcc_srcdir), and omits emutls.c, which is added behind the scenes by
gcc/Makefile.in.  This patch corrects this.

Bootstrapped without regressions on i386-pc-solaris2.11, ok for
mainline?  I suppose this is obvious.

To get rid of this mess, it seems like we should move all EH-related
stuff to libgcc.  There are several things to do:

* We have mainly two variants of LIB2ADDEH, one (the default) with

  unwind-dw2.c unwind-dw2-fde.c unwind-sjlj.c unwind-c.c

  the other, which uses dl_iterate_phdr, with

  unwind-dw2.c unwind-dw2-fde-glibc.c unwind-sjlj.c unwind-c.c

  There's considerable duplication here right now, so I'd move them to
  t-eh-dw2 and t-eh-dw2-dip (dip is short for dl_iterate_phdr;
  unwind-dw2-fde-glibc.c is a misnomer here since the function is
  available on non-glibc systems like FreeBSD and Solaris).

  The special cases can still be dealt with in target-specific t-* files
  in libgcc.

* The gcc/unwind* files and gcc/emutls.c can move, too.

* LIB2ADDEH* handling in gcc/Makefile.in must be moved to
  libgcc/Makefile.in instead.

If this seems like a sensible plan, I can start working on that.

Thanks.
        Rainer


2011-06-02  Rainer Orth  <r...@cebitec.uni-bielefeld.de>

        gcc:
        * Makefile.in (LIB2ADDEHDEP): Remove.
        * config/arm/t-bpabi (LIB2ADDEHDEP): Remove.
        * config/arm/t-symbian (LIB2ADDEHDEP): Remove.
        * config/picochip/t-picochip (LIB2ADDEHDEP): Remove.
        * config/t-darwin (LIB2ADDEHDEP): Remove.
        * config/t-freebsd (LIB2ADDEHDEP): Remove.
        * config/t-linux (LIB2ADDEHDEP): Remove.

        libgcc:
        * config/s390/t-tpf (LIB2ADDEHDEP): Remove.
        * config/t-sol2 (LIB2ADDEH): Use gcc_srcdir, add emutls.c.

diff --git a/gcc/Makefile.in b/gcc/Makefile.in
--- a/gcc/Makefile.in
+++ b/gcc/Makefile.in
@@ -744,7 +744,6 @@ LIB2ADDEH = $(srcdir)/unwind-dw2.c $(src
    $(srcdir)/unwind-sjlj.c $(srcdir)/unwind-c.c
 LIB2ADDEHSTATIC = $(LIB2ADDEH)
 LIB2ADDEHSHARED = $(LIB2ADDEH)
-LIB2ADDEHDEP = $(UNWIND_H) unwind-pe.h unwind.inc unwind-dw2-fde.h unwind-dw2.h
 
 # Don't build libunwind by default.
 LIBUNWIND =
diff --git a/gcc/config/arm/t-bpabi b/gcc/config/arm/t-bpabi
--- a/gcc/config/arm/t-bpabi
+++ b/gcc/config/arm/t-bpabi
@@ -1,4 +1,4 @@
-# Copyright (C) 2004, 2005 Free Software Foundation, Inc.
+# Copyright (C) 2004, 2005, 2011 Free Software Foundation, Inc.
 #
 # This file is part of GCC.
 #
@@ -29,7 +29,6 @@ UNWIND_H = $(srcdir)/config/arm/unwind-a
 LIB2ADDEH = $(srcdir)/config/arm/unwind-arm.c \
   $(srcdir)/config/arm/libunwind.S \
   $(srcdir)/config/arm/pr-support.c $(srcdir)/unwind-c.c
-LIB2ADDEHDEP = $(UNWIND_H) $(srcdir)/config/$(LIB1ASMSRC)
 
 # Add the BPABI names.
 SHLIB_MAPFILES += $(srcdir)/config/arm/libgcc-bpabi.ver
diff --git a/gcc/config/arm/t-symbian b/gcc/config/arm/t-symbian
--- a/gcc/config/arm/t-symbian
+++ b/gcc/config/arm/t-symbian
@@ -1,4 +1,4 @@
-# Copyright (C) 2004, 2005, 2006, 2008 Free Software Foundation, Inc.
+# Copyright (C) 2004, 2005, 2006, 2008, 2011 Free Software Foundation, Inc.
 #
 # This file is part of GCC.
 #
@@ -33,7 +33,6 @@ LIB1ASMFUNCS += \
 # Include the gcc personality routine
 UNWIND_H = $(srcdir)/config/arm/unwind-arm.h
 LIB2ADDEH = $(srcdir)/unwind-c.c $(srcdir)/config/arm/pr-support.c
-LIB2ADDEHDEP = $(UNWIND_H)
 
 # Include half-float helpers.
 LIB2FUNCS_STATIC_EXTRA = $(srcdir)/config/arm/fp16.c
diff --git a/gcc/config/picochip/t-picochip b/gcc/config/picochip/t-picochip
--- a/gcc/config/picochip/t-picochip
+++ b/gcc/config/picochip/t-picochip
@@ -1,4 +1,4 @@
-# Copyright (C) 2008 Free Software Foundation, Inc.
+# Copyright (C) 2008, 2011 Free Software Foundation, Inc.
 #
 # This file is part of GCC.
 #
@@ -45,7 +45,6 @@ LIB1ASMSRC = picochip/libgccExtras/fake_
 
 # Turn off the building of exception handling libraries.
 LIB2ADDEH =
-LIB2ADDEHDEP =
 
 # Turn off ranlib on target libraries.
 RANLIB_FOR_TARGET = cat
diff --git a/gcc/config/t-darwin b/gcc/config/t-darwin
--- a/gcc/config/t-darwin
+++ b/gcc/config/t-darwin
@@ -54,7 +54,6 @@ EXTRA_MULTILIB_PARTS=crt3.o
 # Use unwind-dw2-fde-darwin
 LIB2ADDEH = $(srcdir)/unwind-dw2.c $(srcdir)/unwind-dw2-fde-darwin.c \
   $(srcdir)/unwind-sjlj.c $(srcdir)/unwind-c.c
-LIB2ADDEHDEP = unwind.inc unwind-dw2-fde.h unwind-dw2-fde.c
 
 # -pipe because there's an assembler bug, 4077127, which causes
 # it to not properly process the first # directive, causing temporary
diff --git a/gcc/config/t-freebsd b/gcc/config/t-freebsd
--- a/gcc/config/t-freebsd
+++ b/gcc/config/t-freebsd
@@ -7,4 +7,3 @@ TARGET_LIBGCC2_CFLAGS += -fPIC
 # Use unwind-dw2-fde-glibc
 LIB2ADDEH = $(srcdir)/unwind-dw2.c $(srcdir)/unwind-dw2-fde-glibc.c \
   $(srcdir)/unwind-sjlj.c $(srcdir)/unwind-c.c
-LIB2ADDEHDEP = unwind.inc unwind-dw2-fde.h unwind-dw2-fde.c
diff --git a/gcc/config/t-linux b/gcc/config/t-linux
--- a/gcc/config/t-linux
+++ b/gcc/config/t-linux
@@ -29,4 +29,3 @@ SHLIB_MAPFILES += $(srcdir)/config/libgc
 # Use unwind-dw2-fde-glibc
 LIB2ADDEH = $(srcdir)/unwind-dw2.c $(srcdir)/unwind-dw2-fde-glibc.c \
   $(srcdir)/unwind-sjlj.c $(srcdir)/unwind-c.c
-LIB2ADDEHDEP = unwind.inc unwind-dw2-fde.h unwind-dw2-fde.c
diff --git a/gcc/config/t-sol2 b/gcc/config/t-sol2
--- a/gcc/config/t-sol2
+++ b/gcc/config/t-sol2
@@ -36,4 +36,3 @@ TARGET_LIBGCC2_CFLAGS = -fPIC
 # are present, automatically falls back to unwind-dw2-fde.c.
 LIB2ADDEH = $(srcdir)/unwind-dw2.c $(srcdir)/unwind-dw2-fde-glibc.c \
   $(srcdir)/unwind-sjlj.c $(srcdir)/unwind-c.c
-LIB2ADDEHDEP = unwind.inc unwind-dw2-fde.h unwind-dw2-fde.c
diff --git a/libgcc/config/s390/t-tpf b/libgcc/config/s390/t-tpf
--- a/libgcc/config/s390/t-tpf
+++ b/libgcc/config/s390/t-tpf
@@ -5,4 +5,3 @@ HOST_LIBGCC2_CFLAGS += -fPIC
 LIB2ADDEH = $(gcc_srcdir)/unwind-dw2.c $(gcc_srcdir)/unwind-dw2-fde-glibc.c \
   $(gcc_srcdir)/unwind-sjlj.c $(gcc_srcdir)/unwind-c.c \
   $(gcc_srcdir)/emutls.c
-LIB2ADDEHDEP = unwind.inc unwind-dw2-fde.h
diff --git a/libgcc/config/t-sol2 b/libgcc/config/t-sol2
--- a/libgcc/config/t-sol2
+++ b/libgcc/config/t-sol2
@@ -18,8 +18,8 @@
 
 # Use unwind-dw2-fde-glibc.c.  Unless linker support and dl_iterate_phdr
 # are present, automatically falls back to unwind-dw2-fde.c.
-LIB2ADDEH = $(srcdir)/unwind-dw2.c $(srcdir)/unwind-dw2-fde-glibc.c \
-  $(srcdir)/unwind-sjlj.c $(srcdir)/unwind-c.c
+LIB2ADDEH = $(gcc_srcdir)/unwind-dw2.c $(gcc_srcdir)/unwind-dw2-fde-glibc.c \
+  $(gcc_srcdir)/unwind-sjlj.c $(gcc_srcdir)/unwind-c.c $(gcc_srcdir)/emutls.c
 
 # gmon build rule:
 gmon.o:        $(srcdir)/config/gmon-sol2.c


-- 
-----------------------------------------------------------------------------
Rainer Orth, Center for Biotechnology, Bielefeld University

Reply via email to