[prev in list] [next in list] [prev in thread] [next in thread] 

List:       uclibc-cvs
Subject:    Re: [git commit] libubacktrace: fix backtrace for statically linked application
From:       Carmelo Amoroso <carmelo73 () gmail ! com>
Date:       2013-05-13 12:27:18
Message-ID: CAMV2_=Kk7wO5LQR8rc8M+yBGZsLDa07C2DVvChtR7dEbudS04w () mail ! gmail ! com
[Download RAW message or body]

[Attachment #2 (multipart/alternative)]


Il giorno 13/mag/2013 13:59, "Carmelo Amoroso" <carmelo73@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.amoroso@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.arcidiacono@st.com>
>> Signed-off-by: Carmelo Amoroso <carmelo.amoroso@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 unwind_backtrace _Unwind_Backtrace
>> +# define unwind_vrs_get _Unwind_VRS_Get
>> +#endif
>>  /* This function is identical to "_Unwind_GetGR", except that it uses
>>     "unwind_vrs_get" instead of "_Unwind_VRS_Get".  */
>>  static inline _Unwind_Word
>> @@ -81,8 +86,10 @@ int backtrace (void **array, int size)
>>  {
>>         struct trace_arg arg = { .array = array, .size = size, .cnt = -1
};
>>
>> +#ifdef SHARED
>>         if (unwind_backtrace == NULL)
>>                 backtrace_init();
>> +#endif
>>
>>         if (size >= 1)
>>                 unwind_backtrace (backtrace_helper, &arg);
>> diff --git a/libubacktrace/backtrace.c b/libubacktrace/backtrace.c
>> index 0a72bae..08a7010 100644
>> --- a/libubacktrace/backtrace.c
>> +++ b/libubacktrace/backtrace.c
>> @@ -34,6 +34,7 @@ struct trace_arg
>>    int cnt, size;
>>  };
>>
>> +#ifdef SHARED
>>  static _Unwind_Reason_Code (*unwind_backtrace) (_Unwind_Trace_Fn, void
*);
>>  static _Unwind_Ptr (*unwind_getip) (struct _Unwind_Context *);
>>
>> @@ -48,6 +49,10 @@ static void backtrace_init (void)
>>                 abort();
>>         }
>>  }
>> +#else
>> +# define unwind_backtrace _Unwind_Backtrace
>> +# define unwind_getip _Unwind_GetIP
>> +#endif
>>
>>  static _Unwind_Reason_Code
>>  backtrace_helper (struct _Unwind_Context *ctx, void *a)
>> @@ -72,8 +77,10 @@ int backtrace (void **array, int size)
>>  {
>>         struct trace_arg arg = { .array = array, .size = size, .cnt = -1
};
>>
>> +#ifdef SHARED
>>         if (unwind_backtrace == NULL)
>>                 backtrace_init();
>> +#endif
>>
>>         if (size >= 1)
>>                 unwind_backtrace (backtrace_helper, &arg);
>> _______________________________________________
>> uClibc-cvs mailing list
>> uClibc-cvs@uclibc.org
>> http://lists.busybox.net/mailman/listinfo/uclibc-cvs

[Attachment #5 (text/html)]

<p dir="ltr"></p>
<p dir="ltr">Il giorno 13/mag/2013 13:59, &quot;Carmelo Amoroso&quot; &lt;<a \
href="mailto:carmelo73@gmail.com">carmelo73@gmail.com</a>&gt; ha scritto:<br> \
&gt;<br> &gt; A post commit dic will come sono.</p>
<p dir="ltr">Top many typos ... Meant to sa</p>
<p dir="ltr">A post commit fix will come sono</p>
<p dir="ltr"> Apologies.<br>
&gt;<br>
&gt; Carmelo<br>
&gt;<br>
&gt; Il giorno 13/mag/2013 10:24, &quot;Carmelo Amoroso&quot; &lt;<a \
href="mailto:carmelo.amoroso@st.com">carmelo.amoroso@st.com</a>&gt; ha scritto:<br> \
&gt;<br> &gt;&gt; commit: <a \
href="http://git.uclibc.org/uClibc/commit/?id=71c10c484e7dc113396cccb7e503befb759c6346 \
">http://git.uclibc.org/uClibc/commit/?id=71c10c484e7dc113396cccb7e503befb759c6346</a><br>
 &gt;&gt; branch: <a \
href="http://git.uclibc.org/uClibc/commit/?id=refs/heads/master">http://git.uclibc.org/uClibc/commit/?id=refs/heads/master</a><br>
 &gt;&gt;<br>
&gt;&gt; libgcc_s.so&#39;s unwinder could not access unwind tables of statically<br>
&gt;&gt; linked binaries, so we really want to use _Unwind_* stuff from<br>
&gt;&gt; libgcc_eh.a.<br>
&gt;&gt; It required to build backtrace.c differentiating between shared and<br>
&gt;&gt; static case.<br>
&gt;&gt;<br>
&gt;&gt; Signed-off-by: Filippo Arcidiacono &lt;<a \
href="mailto:filippo.arcidiacono@st.com">filippo.arcidiacono@st.com</a>&gt;<br> \
&gt;&gt; Signed-off-by: Carmelo Amoroso &lt;<a \
href="mailto:carmelo.amoroso@st.com">carmelo.amoroso@st.com</a>&gt;<br> &gt;&gt; \
---<br> &gt;&gt;  libubacktrace/Makefile.in       |   23 ++++++++++++++---------<br>
&gt;&gt;  libubacktrace/arm/Makefile.arch |    2 +-<br>
&gt;&gt;  libubacktrace/arm/backtrace.c   |    7 +++++++<br>
&gt;&gt;  libubacktrace/backtrace.c       |    7 +++++++<br>
&gt;&gt;  4 files changed, 29 insertions(+), 10 deletions(-)<br>
&gt;&gt;<br>
&gt;&gt; diff --git a/libubacktrace/Makefile.in b/libubacktrace/Makefile.in<br>
&gt;&gt; index 8a4b081..612bf2d 100644<br>
&gt;&gt; --- a/libubacktrace/Makefile.in<br>
&gt;&gt; +++ b/libubacktrace/Makefile.in<br>
&gt;&gt; @@ -25,11 +25,13 @@ \
libubacktrace_ARCH_OUT:=$(libubacktrace_OUT)/$(TARGET_ARCH)<br> &gt;&gt;  -include \
$(libubacktrace_ARCH_DIR)/Makefile.arch<br> &gt;&gt;<br>
&gt;&gt;  libubacktrace_SRC-y :=<br>
&gt;&gt; -libubacktrace_SRC-$(UCLIBC_HAS_BACKTRACE) := backtrace.c backtracesyms.c \
backtracesymsfd.c<br> &gt;&gt; +libubacktrace_SRC-$(UCLIBC_HAS_BACKTRACE) := \
backtracesyms.c backtracesymsfd.c<br> &gt;&gt; \
+libubacktrace_SRC_SHARED-$(UCLIBC_HAS_BACKTRACE) := backtrace.c<br> &gt;&gt;<br>
&gt;&gt;  # remove generic sources, if arch specific version is present<br>
&gt;&gt;  ifneq ($(strip $(libubacktrace_ARCH_SRC-y)),)<br>
&gt;&gt;  libubacktrace_SRC-y := $(filter-out $(notdir \
$(libubacktrace_ARCH_SRC-y)),$(libubacktrace_SRC-y))<br> &gt;&gt; \
+libubacktrace_SRC_SHARED-y := $(filter-out $(notdir \
$(libubacktrace_ARCH_SRC-y)),$(libubacktrace_SRC_SHARED-y))<br> &gt;&gt;  endif<br>
&gt;&gt;<br>
&gt;&gt;  # -fasynchronous-unwind-tables is required for backtrace to work using \
dwarf2<br> &gt;&gt; @@ -43,12 +45,19 @@ endif<br>
&gt;&gt;  libubacktrace_SRCS := $(patsubst \
%.c,$(libubacktrace_DIR)/%.c,$(libubacktrace_SRC-y))<br> &gt;&gt;  libubacktrace_OBJS \
:= $(patsubst $(libubacktrace_DIR)/%.c,$(libubacktrace_OUT)/%.o,$(libubacktrace_SRCS))<br>
 &gt;&gt;<br>
&gt;&gt; +libubacktrace_SHARED_SRCS := $(patsubst \
%.c,$(libubacktrace_DIR)/%.c,$(libubacktrace_SHARED_SRC-y))<br> &gt;&gt; \
+libubacktrace_SHARED_OBJS := $(patsubst \
$(libubacktrace_DIR)/%.c,$(libubacktrace_OUT)/%.s,$(libubacktrace_SHARED_SRCS))<br> \
&gt;&gt; +<br> &gt;&gt; +libubacktrace-shared-y := \
$(libubacktrace_SHARED_OBJS:.os=.oS)<br> &gt;&gt; +libubacktrace-static-y := \
$(libubacktrace_SHARED_OBJS)<br> &gt;&gt; +<br>
&gt;&gt;  ifeq ($(DOPIC),y)<br>
&gt;&gt; -libubacktrace-a-y += $(libubacktrace_OBJS:.o=.os)<br>
&gt;&gt; +libubacktrace-a-y += $(libubacktrace_OBJS:.o=.os) \
$(libubacktrace-static-y:.o=.os)<br> &gt;&gt;  else<br>
&gt;&gt; -libubacktrace-a-y += $(libubacktrace_OBJS)<br>
&gt;&gt; +libubacktrace-a-y += $(libubacktrace_OBJS) $(libubacktrace-static-y)<br>
&gt;&gt;  endif<br>
&gt;&gt; -libubacktrace-so-y += $(libubacktrace_OBJS:.o=.os)<br>
&gt;&gt; +libubacktrace-so-y += $(libubacktrace_OBJS:.o=.os) \
$(libubacktrace-shared-y)<br> &gt;&gt; +<br>
&gt;&gt;<br>
&gt;&gt;  lib-a-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.a<br>
&gt;&gt;  lib-so-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.so<br>
&gt;&gt; @@ -56,11 +65,7 @@ lib-so-$(UCLIBC_HAS_BACKTRACE) += \
$(top_builddir)lib/libubacktrace.so<br> &gt;&gt;  objclean-y += \
CLEAN_libubacktrace<br> &gt;&gt;<br>
&gt;&gt;  ifeq ($(DOMULTI),n)<br>
&gt;&gt; -ifeq ($(DOPIC),y)<br>
&gt;&gt; -$(top_builddir)lib/libubacktrace.so: $(top_builddir)lib/libubacktrace.a \
$(libdl.depend)<br> &gt;&gt; -else<br>
&gt;&gt;  $(top_builddir)lib/libubacktrace.so: \
$(libubacktrace_OUT)/libubacktrace_so.a $(libdl.depend)<br> &gt;&gt; -endif<br>
&gt;&gt;         $(call link.so,$(libubacktrace_FULL_NAME),$(ABI_VERSION))<br>
&gt;&gt;  else<br>
&gt;&gt;  $(top_builddir)lib/libubacktrace.so: $(libubacktrace_OUT)/libubacktrace.oS \
| $(libdl.depend)<br> &gt;&gt; @@ -71,7 +76,7 @@ \
$(libubacktrace_OUT)/libubacktrace_so.a: $(libubacktrace-so-y)<br> &gt;&gt;         \
$(Q)$(RM) $@<br> &gt;&gt;         $(do_ar)<br>
&gt;&gt;<br>
&gt;&gt; -$(libubacktrace_OUT)/libubacktrace.oS: $(libubacktrace_SRCS) \
$(libubacktrace_ARCH_SRCS)<br> &gt;&gt; +$(libubacktrace_OUT)/libubacktrace.oS: \
$(libubacktrace_SRCS) $(libubacktrace_ARCH_SRCS) $(libubacktrace_SHARED_SRCS)<br> \
&gt;&gt;         $(Q)$(RM) $@<br> &gt;&gt;         $(compile-m)<br>
&gt;&gt;<br>
&gt;&gt; diff --git a/libubacktrace/arm/Makefile.arch \
b/libubacktrace/arm/Makefile.arch<br> &gt;&gt; index 53b8c0e..b3fb500 100644<br>
&gt;&gt; --- a/libubacktrace/arm/Makefile.arch<br>
&gt;&gt; +++ b/libubacktrace/arm/Makefile.arch<br>
&gt;&gt; @@ -14,4 +14,4 @@ libubacktrace-a-y+=$(libubacktrace_ARCH_OBJS:.o=.os)<br>
&gt;&gt;  else<br>
&gt;&gt;  libubacktrace-a-y+=$(libubacktrace_ARCH_OBJS)<br>
&gt;&gt;  endif<br>
&gt;&gt; -libubacktrace-so-y+=$(libubacktrace_ARCH_OBJS:.o=.os)<br>
&gt;&gt; +libubacktrace-so-y+=$(libubacktrace_ARCH_OBJS:.o=.oS)<br>
&gt;&gt; diff --git a/libubacktrace/arm/backtrace.c \
b/libubacktrace/arm/backtrace.c<br> &gt;&gt; index c154496..55689a7 100644<br>
&gt;&gt; --- a/libubacktrace/arm/backtrace.c<br>
&gt;&gt; +++ b/libubacktrace/arm/backtrace.c<br>
&gt;&gt; @@ -26,6 +26,7 @@ struct trace_arg<br>
&gt;&gt;    int cnt, size;<br>
&gt;&gt;  };<br>
&gt;&gt;<br>
&gt;&gt; +#ifdef SHARED<br>
&gt;&gt;  static _Unwind_Reason_Code (*unwind_backtrace) (_Unwind_Trace_Fn, void \
*);<br> &gt;&gt;  static _Unwind_VRS_Result (*unwind_vrs_get) (_Unwind_Context *,<br>
&gt;&gt;                                              _Unwind_VRS_RegClass,<br>
&gt;&gt; @@ -43,6 +44,10 @@ static void backtrace_init (void)<br>
&gt;&gt;                 abort();<br>
&gt;&gt;         }<br>
&gt;&gt;  }<br>
&gt;&gt; +#else<br>
&gt;&gt; +# define unwind_backtrace _Unwind_Backtrace<br>
&gt;&gt; +# define unwind_vrs_get _Unwind_VRS_Get<br>
&gt;&gt; +#endif<br>
&gt;&gt;  /* This function is identical to &quot;_Unwind_GetGR&quot;, except that it \
uses<br> &gt;&gt;     &quot;unwind_vrs_get&quot; instead of \
&quot;_Unwind_VRS_Get&quot;.  */<br> &gt;&gt;  static inline _Unwind_Word<br>
&gt;&gt; @@ -81,8 +86,10 @@ int backtrace (void **array, int size)<br>
&gt;&gt;  {<br>
&gt;&gt;         struct trace_arg arg = { .array = array, .size = size, .cnt = -1 \
};<br> &gt;&gt;<br>
&gt;&gt; +#ifdef SHARED<br>
&gt;&gt;         if (unwind_backtrace == NULL)<br>
&gt;&gt;                 backtrace_init();<br>
&gt;&gt; +#endif<br>
&gt;&gt;<br>
&gt;&gt;         if (size &gt;= 1)<br>
&gt;&gt;                 unwind_backtrace (backtrace_helper, &amp;arg);<br>
&gt;&gt; diff --git a/libubacktrace/backtrace.c b/libubacktrace/backtrace.c<br>
&gt;&gt; index 0a72bae..08a7010 100644<br>
&gt;&gt; --- a/libubacktrace/backtrace.c<br>
&gt;&gt; +++ b/libubacktrace/backtrace.c<br>
&gt;&gt; @@ -34,6 +34,7 @@ struct trace_arg<br>
&gt;&gt;    int cnt, size;<br>
&gt;&gt;  };<br>
&gt;&gt;<br>
&gt;&gt; +#ifdef SHARED<br>
&gt;&gt;  static _Unwind_Reason_Code (*unwind_backtrace) (_Unwind_Trace_Fn, void \
*);<br> &gt;&gt;  static _Unwind_Ptr (*unwind_getip) (struct _Unwind_Context *);<br>
&gt;&gt;<br>
&gt;&gt; @@ -48,6 +49,10 @@ static void backtrace_init (void)<br>
&gt;&gt;                 abort();<br>
&gt;&gt;         }<br>
&gt;&gt;  }<br>
&gt;&gt; +#else<br>
&gt;&gt; +# define unwind_backtrace _Unwind_Backtrace<br>
&gt;&gt; +# define unwind_getip _Unwind_GetIP<br>
&gt;&gt; +#endif<br>
&gt;&gt;<br>
&gt;&gt;  static _Unwind_Reason_Code<br>
&gt;&gt;  backtrace_helper (struct _Unwind_Context *ctx, void *a)<br>
&gt;&gt; @@ -72,8 +77,10 @@ int backtrace (void **array, int size)<br>
&gt;&gt;  {<br>
&gt;&gt;         struct trace_arg arg = { .array = array, .size = size, .cnt = -1 \
};<br> &gt;&gt;<br>
&gt;&gt; +#ifdef SHARED<br>
&gt;&gt;         if (unwind_backtrace == NULL)<br>
&gt;&gt;                 backtrace_init();<br>
&gt;&gt; +#endif<br>
&gt;&gt;<br>
&gt;&gt;         if (size &gt;= 1)<br>
&gt;&gt;                 unwind_backtrace (backtrace_helper, &amp;arg);<br>
&gt;&gt; _______________________________________________<br>
&gt;&gt; uClibc-cvs mailing list<br>
&gt;&gt; <a href="mailto:uClibc-cvs@uclibc.org">uClibc-cvs@uclibc.org</a><br>
&gt;&gt; <a href="http://lists.busybox.net/mailman/listinfo/uclibc-cvs">http://lists.busybox.net/mailman/listinfo/uclibc-cvs</a><br>
 </p>



_______________________________________________
uClibc-cvs mailing list
uClibc-cvs@uclibc.org
http://lists.busybox.net/mailman/listinfo/uclibc-cvs

[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic