Re: [git commit] libubacktrace: fix backtrace for statically linked application

2013-05-13 Thread Carmelo Amoroso
A post commit dic will come sono. Apologies.

Carmelo
Il giorno 13/mag/2013 10:24, Carmelo Amoroso carmelo.amor...@st.com ha
scritto:

 commit:
 http://git.uclibc.org/uClibc/commit/?id=71c10c484e7dc113396cccb7e503befb759c6346
 branch: http://git.uclibc.org/uClibc/commit/?id=refs/heads/master

 libgcc_s.so's unwinder could not access unwind tables of statically
 linked binaries, so we really want to use _Unwind_* stuff from
 libgcc_eh.a.
 It required to build backtrace.c differentiating between shared and
 static case.

 Signed-off-by: Filippo Arcidiacono filippo.arcidiac...@st.com
 Signed-off-by: Carmelo Amoroso carmelo.amor...@st.com
 ---
  libubacktrace/Makefile.in   |   23 ++-
  libubacktrace/arm/Makefile.arch |2 +-
  libubacktrace/arm/backtrace.c   |7 +++
  libubacktrace/backtrace.c   |7 +++
  4 files changed, 29 insertions(+), 10 deletions(-)

 diff --git a/libubacktrace/Makefile.in b/libubacktrace/Makefile.in
 index 8a4b081..612bf2d 100644
 --- a/libubacktrace/Makefile.in
 +++ b/libubacktrace/Makefile.in
 @@ -25,11 +25,13 @@
 libubacktrace_ARCH_OUT:=$(libubacktrace_OUT)/$(TARGET_ARCH)
  -include $(libubacktrace_ARCH_DIR)/Makefile.arch

  libubacktrace_SRC-y :=
 -libubacktrace_SRC-$(UCLIBC_HAS_BACKTRACE) := backtrace.c backtracesyms.c
 backtracesymsfd.c
 +libubacktrace_SRC-$(UCLIBC_HAS_BACKTRACE) := backtracesyms.c
 backtracesymsfd.c
 +libubacktrace_SRC_SHARED-$(UCLIBC_HAS_BACKTRACE) := backtrace.c

  # remove generic sources, if arch specific version is present
  ifneq ($(strip $(libubacktrace_ARCH_SRC-y)),)
  libubacktrace_SRC-y := $(filter-out $(notdir
 $(libubacktrace_ARCH_SRC-y)),$(libubacktrace_SRC-y))
 +libubacktrace_SRC_SHARED-y := $(filter-out $(notdir
 $(libubacktrace_ARCH_SRC-y)),$(libubacktrace_SRC_SHARED-y))
  endif

  # -fasynchronous-unwind-tables is required for backtrace to work using
 dwarf2
 @@ -43,12 +45,19 @@ endif
  libubacktrace_SRCS := $(patsubst
 %.c,$(libubacktrace_DIR)/%.c,$(libubacktrace_SRC-y))
  libubacktrace_OBJS := $(patsubst
 $(libubacktrace_DIR)/%.c,$(libubacktrace_OUT)/%.o,$(libubacktrace_SRCS))

 +libubacktrace_SHARED_SRCS := $(patsubst
 %.c,$(libubacktrace_DIR)/%.c,$(libubacktrace_SHARED_SRC-y))
 +libubacktrace_SHARED_OBJS := $(patsubst
 $(libubacktrace_DIR)/%.c,$(libubacktrace_OUT)/%.s,$(libubacktrace_SHARED_SRCS))
 +
 +libubacktrace-shared-y := $(libubacktrace_SHARED_OBJS:.os=.oS)
 +libubacktrace-static-y := $(libubacktrace_SHARED_OBJS)
 +
  ifeq ($(DOPIC),y)
 -libubacktrace-a-y += $(libubacktrace_OBJS:.o=.os)
 +libubacktrace-a-y += $(libubacktrace_OBJS:.o=.os)
 $(libubacktrace-static-y:.o=.os)
  else
 -libubacktrace-a-y += $(libubacktrace_OBJS)
 +libubacktrace-a-y += $(libubacktrace_OBJS) $(libubacktrace-static-y)
  endif
 -libubacktrace-so-y += $(libubacktrace_OBJS:.o=.os)
 +libubacktrace-so-y += $(libubacktrace_OBJS:.o=.os)
 $(libubacktrace-shared-y)
 +

  lib-a-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.a
  lib-so-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.so
 @@ -56,11 +65,7 @@ lib-so-$(UCLIBC_HAS_BACKTRACE) +=
 $(top_builddir)lib/libubacktrace.so
  objclean-y += CLEAN_libubacktrace

  ifeq ($(DOMULTI),n)
 -ifeq ($(DOPIC),y)
 -$(top_builddir)lib/libubacktrace.so: $(top_builddir)lib/libubacktrace.a
 $(libdl.depend)
 -else
  $(top_builddir)lib/libubacktrace.so:
 $(libubacktrace_OUT)/libubacktrace_so.a $(libdl.depend)
 -endif
 $(call link.so,$(libubacktrace_FULL_NAME),$(ABI_VERSION))
  else
  $(top_builddir)lib/libubacktrace.so:
 $(libubacktrace_OUT)/libubacktrace.oS | $(libdl.depend)
 @@ -71,7 +76,7 @@ $(libubacktrace_OUT)/libubacktrace_so.a:
 $(libubacktrace-so-y)
 $(Q)$(RM) $@
 $(do_ar)

 -$(libubacktrace_OUT)/libubacktrace.oS: $(libubacktrace_SRCS)
 $(libubacktrace_ARCH_SRCS)
 +$(libubacktrace_OUT)/libubacktrace.oS: $(libubacktrace_SRCS)
 $(libubacktrace_ARCH_SRCS) $(libubacktrace_SHARED_SRCS)
 $(Q)$(RM) $@
 $(compile-m)

 diff --git a/libubacktrace/arm/Makefile.arch
 b/libubacktrace/arm/Makefile.arch
 index 53b8c0e..b3fb500 100644
 --- a/libubacktrace/arm/Makefile.arch
 +++ b/libubacktrace/arm/Makefile.arch
 @@ -14,4 +14,4 @@ libubacktrace-a-y+=$(libubacktrace_ARCH_OBJS:.o=.os)
  else
  libubacktrace-a-y+=$(libubacktrace_ARCH_OBJS)
  endif
 -libubacktrace-so-y+=$(libubacktrace_ARCH_OBJS:.o=.os)
 +libubacktrace-so-y+=$(libubacktrace_ARCH_OBJS:.o=.oS)
 diff --git a/libubacktrace/arm/backtrace.c b/libubacktrace/arm/backtrace.c
 index c154496..55689a7 100644
 --- a/libubacktrace/arm/backtrace.c
 +++ b/libubacktrace/arm/backtrace.c
 @@ -26,6 +26,7 @@ struct trace_arg
int cnt, size;
  };

 +#ifdef SHARED
  static _Unwind_Reason_Code (*unwind_backtrace) (_Unwind_Trace_Fn, void *);
  static _Unwind_VRS_Result (*unwind_vrs_get) (_Unwind_Context *,
  _Unwind_VRS_RegClass,
 @@ -43,6 +44,10 @@ static void backtrace_init (void)
 abort();
 }
  }
 +#else
 +# define 

Re: [git commit] libubacktrace: fix backtrace for statically linked application

2013-05-13 Thread Carmelo Amoroso
Il giorno 13/mag/2013 13:59, Carmelo Amoroso carmel...@gmail.com ha
scritto:

 A post commit dic will come sono.

Top many typos ... Meant to sa

A post commit fix will come sono

Apologies.

 Carmelo

 Il giorno 13/mag/2013 10:24, Carmelo Amoroso carmelo.amor...@st.com
ha scritto:

 commit:
http://git.uclibc.org/uClibc/commit/?id=71c10c484e7dc113396cccb7e503befb759c6346
 branch: http://git.uclibc.org/uClibc/commit/?id=refs/heads/master

 libgcc_s.so's unwinder could not access unwind tables of statically
 linked binaries, so we really want to use _Unwind_* stuff from
 libgcc_eh.a.
 It required to build backtrace.c differentiating between shared and
 static case.

 Signed-off-by: Filippo Arcidiacono filippo.arcidiac...@st.com
 Signed-off-by: Carmelo Amoroso carmelo.amor...@st.com
 ---
  libubacktrace/Makefile.in   |   23 ++-
  libubacktrace/arm/Makefile.arch |2 +-
  libubacktrace/arm/backtrace.c   |7 +++
  libubacktrace/backtrace.c   |7 +++
  4 files changed, 29 insertions(+), 10 deletions(-)

 diff --git a/libubacktrace/Makefile.in b/libubacktrace/Makefile.in
 index 8a4b081..612bf2d 100644
 --- a/libubacktrace/Makefile.in
 +++ b/libubacktrace/Makefile.in
 @@ -25,11 +25,13 @@
libubacktrace_ARCH_OUT:=$(libubacktrace_OUT)/$(TARGET_ARCH)
  -include $(libubacktrace_ARCH_DIR)/Makefile.arch

  libubacktrace_SRC-y :=
 -libubacktrace_SRC-$(UCLIBC_HAS_BACKTRACE) := backtrace.c
backtracesyms.c backtracesymsfd.c
 +libubacktrace_SRC-$(UCLIBC_HAS_BACKTRACE) := backtracesyms.c
backtracesymsfd.c
 +libubacktrace_SRC_SHARED-$(UCLIBC_HAS_BACKTRACE) := backtrace.c

  # remove generic sources, if arch specific version is present
  ifneq ($(strip $(libubacktrace_ARCH_SRC-y)),)
  libubacktrace_SRC-y := $(filter-out $(notdir
$(libubacktrace_ARCH_SRC-y)),$(libubacktrace_SRC-y))
 +libubacktrace_SRC_SHARED-y := $(filter-out $(notdir
$(libubacktrace_ARCH_SRC-y)),$(libubacktrace_SRC_SHARED-y))
  endif

  # -fasynchronous-unwind-tables is required for backtrace to work using
dwarf2
 @@ -43,12 +45,19 @@ endif
  libubacktrace_SRCS := $(patsubst
%.c,$(libubacktrace_DIR)/%.c,$(libubacktrace_SRC-y))
  libubacktrace_OBJS := $(patsubst
$(libubacktrace_DIR)/%.c,$(libubacktrace_OUT)/%.o,$(libubacktrace_SRCS))

 +libubacktrace_SHARED_SRCS := $(patsubst
%.c,$(libubacktrace_DIR)/%.c,$(libubacktrace_SHARED_SRC-y))
 +libubacktrace_SHARED_OBJS := $(patsubst
$(libubacktrace_DIR)/%.c,$(libubacktrace_OUT)/%.s,$(libubacktrace_SHARED_SRCS))
 +
 +libubacktrace-shared-y := $(libubacktrace_SHARED_OBJS:.os=.oS)
 +libubacktrace-static-y := $(libubacktrace_SHARED_OBJS)
 +
  ifeq ($(DOPIC),y)
 -libubacktrace-a-y += $(libubacktrace_OBJS:.o=.os)
 +libubacktrace-a-y += $(libubacktrace_OBJS:.o=.os)
$(libubacktrace-static-y:.o=.os)
  else
 -libubacktrace-a-y += $(libubacktrace_OBJS)
 +libubacktrace-a-y += $(libubacktrace_OBJS) $(libubacktrace-static-y)
  endif
 -libubacktrace-so-y += $(libubacktrace_OBJS:.o=.os)
 +libubacktrace-so-y += $(libubacktrace_OBJS:.o=.os)
$(libubacktrace-shared-y)
 +

  lib-a-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.a
  lib-so-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.so
 @@ -56,11 +65,7 @@ lib-so-$(UCLIBC_HAS_BACKTRACE) +=
$(top_builddir)lib/libubacktrace.so
  objclean-y += CLEAN_libubacktrace

  ifeq ($(DOMULTI),n)
 -ifeq ($(DOPIC),y)
 -$(top_builddir)lib/libubacktrace.so: $(top_builddir)lib/libubacktrace.a
$(libdl.depend)
 -else
  $(top_builddir)lib/libubacktrace.so:
$(libubacktrace_OUT)/libubacktrace_so.a $(libdl.depend)
 -endif
 $(call link.so,$(libubacktrace_FULL_NAME),$(ABI_VERSION))
  else
  $(top_builddir)lib/libubacktrace.so:
$(libubacktrace_OUT)/libubacktrace.oS | $(libdl.depend)
 @@ -71,7 +76,7 @@ $(libubacktrace_OUT)/libubacktrace_so.a:
$(libubacktrace-so-y)
 $(Q)$(RM) $@
 $(do_ar)

 -$(libubacktrace_OUT)/libubacktrace.oS: $(libubacktrace_SRCS)
$(libubacktrace_ARCH_SRCS)
 +$(libubacktrace_OUT)/libubacktrace.oS: $(libubacktrace_SRCS)
$(libubacktrace_ARCH_SRCS) $(libubacktrace_SHARED_SRCS)
 $(Q)$(RM) $@
 $(compile-m)

 diff --git a/libubacktrace/arm/Makefile.arch
b/libubacktrace/arm/Makefile.arch
 index 53b8c0e..b3fb500 100644
 --- a/libubacktrace/arm/Makefile.arch
 +++ b/libubacktrace/arm/Makefile.arch
 @@ -14,4 +14,4 @@ libubacktrace-a-y+=$(libubacktrace_ARCH_OBJS:.o=.os)
  else
  libubacktrace-a-y+=$(libubacktrace_ARCH_OBJS)
  endif
 -libubacktrace-so-y+=$(libubacktrace_ARCH_OBJS:.o=.os)
 +libubacktrace-so-y+=$(libubacktrace_ARCH_OBJS:.o=.oS)
 diff --git a/libubacktrace/arm/backtrace.c
b/libubacktrace/arm/backtrace.c
 index c154496..55689a7 100644
 --- a/libubacktrace/arm/backtrace.c
 +++ b/libubacktrace/arm/backtrace.c
 @@ -26,6 +26,7 @@ struct trace_arg
int cnt, size;
  };

 +#ifdef SHARED
  static _Unwind_Reason_Code (*unwind_backtrace) (_Unwind_Trace_Fn, void
*);
  static _Unwind_VRS_Result (*unwind_vrs_get) (_Unwind_Context *,
  _Unwind_VRS_RegClass,