The cirros image was rebuilt against the 3.13.0-83 kernel, drivers e1000e, igbvf...
[packages/trusty/cirros-testvm.git] / cirros-testvm / src-cirros / buildroot-2015.05 / package / uclibc / 0.9.33.2 / 0051-libubacktrace-fix-backtrace-for-statically-linked-ap.patch
1 From 6b2250a1a39362abe53e78a45897caecf65ec73f Mon Sep 17 00:00:00 2001
2 From: Filippo Arcidiacono <filippo.arcidiacono@st.com>
3 Date: Thu, 9 May 2013 11:42:23 +0200
4 Subject: [PATCH] libubacktrace: fix backtrace for statically linked
5  application
6
7 libgcc_s.so's unwinder could not access unwind tables of statically
8 linked binaries, so we really want to use _Unwind_* stuff from
9 libgcc_eh.a.
10 It required to build backtrace.c differentiating between shared and
11 static case.
12
13 Signed-off-by: Filippo Arcidiacono <filippo.arcidiacono@st.com>
14 Signed-off-by: Carmelo Amoroso <carmelo.amoroso@st.com>
15 (cherry picked from commit 71c10c484e7dc113396cccb7e503befb759c6346)
16
17 Signed-off-by: Carmelo Amoroso <carmelo.amoroso@st.com>
18 ---
19  libubacktrace/Makefile.in       |   23 ++++++++++++++---------
20  libubacktrace/arm/Makefile.arch |    2 +-
21  libubacktrace/arm/backtrace.c   |    7 +++++++
22  libubacktrace/backtrace.c       |    7 +++++++
23  4 files changed, 29 insertions(+), 10 deletions(-)
24
25 diff --git a/libubacktrace/Makefile.in b/libubacktrace/Makefile.in
26 index 8a4b081..612bf2d 100644
27 --- a/libubacktrace/Makefile.in
28 +++ b/libubacktrace/Makefile.in
29 @@ -25,11 +25,13 @@ libubacktrace_ARCH_OUT:=$(libubacktrace_OUT)/$(TARGET_ARCH)
30  -include $(libubacktrace_ARCH_DIR)/Makefile.arch
31  
32  libubacktrace_SRC-y :=
33 -libubacktrace_SRC-$(UCLIBC_HAS_BACKTRACE) := backtrace.c backtracesyms.c backtracesymsfd.c
34 +libubacktrace_SRC-$(UCLIBC_HAS_BACKTRACE) := backtracesyms.c backtracesymsfd.c
35 +libubacktrace_SRC_SHARED-$(UCLIBC_HAS_BACKTRACE) := backtrace.c
36  
37  # remove generic sources, if arch specific version is present
38  ifneq ($(strip $(libubacktrace_ARCH_SRC-y)),)
39  libubacktrace_SRC-y := $(filter-out $(notdir $(libubacktrace_ARCH_SRC-y)),$(libubacktrace_SRC-y))
40 +libubacktrace_SRC_SHARED-y := $(filter-out $(notdir $(libubacktrace_ARCH_SRC-y)),$(libubacktrace_SRC_SHARED-y))
41  endif
42  
43  # -fasynchronous-unwind-tables is required for backtrace to work using dwarf2
44 @@ -43,12 +45,19 @@ endif
45  libubacktrace_SRCS := $(patsubst %.c,$(libubacktrace_DIR)/%.c,$(libubacktrace_SRC-y))
46  libubacktrace_OBJS := $(patsubst $(libubacktrace_DIR)/%.c,$(libubacktrace_OUT)/%.o,$(libubacktrace_SRCS))
47  
48 +libubacktrace_SHARED_SRCS := $(patsubst %.c,$(libubacktrace_DIR)/%.c,$(libubacktrace_SHARED_SRC-y))
49 +libubacktrace_SHARED_OBJS := $(patsubst $(libubacktrace_DIR)/%.c,$(libubacktrace_OUT)/%.s,$(libubacktrace_SHARED_SRCS))
50 +
51 +libubacktrace-shared-y := $(libubacktrace_SHARED_OBJS:.os=.oS)
52 +libubacktrace-static-y := $(libubacktrace_SHARED_OBJS)
53 +
54  ifeq ($(DOPIC),y)
55 -libubacktrace-a-y += $(libubacktrace_OBJS:.o=.os)
56 +libubacktrace-a-y += $(libubacktrace_OBJS:.o=.os) $(libubacktrace-static-y:.o=.os)
57  else
58 -libubacktrace-a-y += $(libubacktrace_OBJS)
59 +libubacktrace-a-y += $(libubacktrace_OBJS) $(libubacktrace-static-y)
60  endif
61 -libubacktrace-so-y += $(libubacktrace_OBJS:.o=.os)
62 +libubacktrace-so-y += $(libubacktrace_OBJS:.o=.os) $(libubacktrace-shared-y)
63 +
64  
65  lib-a-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.a
66  lib-so-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.so
67 @@ -56,11 +65,7 @@ lib-so-$(UCLIBC_HAS_BACKTRACE) += $(top_builddir)lib/libubacktrace.so
68  objclean-y += CLEAN_libubacktrace
69  
70  ifeq ($(DOMULTI),n)
71 -ifeq ($(DOPIC),y)
72 -$(top_builddir)lib/libubacktrace.so: $(top_builddir)lib/libubacktrace.a $(libdl.depend)
73 -else
74  $(top_builddir)lib/libubacktrace.so: $(libubacktrace_OUT)/libubacktrace_so.a $(libdl.depend)
75 -endif
76         $(call link.so,$(libubacktrace_FULL_NAME),$(ABI_VERSION))
77  else
78  $(top_builddir)lib/libubacktrace.so: $(libubacktrace_OUT)/libubacktrace.oS | $(libdl.depend)
79 @@ -71,7 +76,7 @@ $(libubacktrace_OUT)/libubacktrace_so.a: $(libubacktrace-so-y)
80         $(Q)$(RM) $@
81         $(do_ar)
82  
83 -$(libubacktrace_OUT)/libubacktrace.oS: $(libubacktrace_SRCS) $(libubacktrace_ARCH_SRCS)
84 +$(libubacktrace_OUT)/libubacktrace.oS: $(libubacktrace_SRCS) $(libubacktrace_ARCH_SRCS) $(libubacktrace_SHARED_SRCS)
85         $(Q)$(RM) $@
86         $(compile-m)
87  
88 diff --git a/libubacktrace/arm/Makefile.arch b/libubacktrace/arm/Makefile.arch
89 index 53b8c0e..b3fb500 100644
90 --- a/libubacktrace/arm/Makefile.arch
91 +++ b/libubacktrace/arm/Makefile.arch
92 @@ -14,4 +14,4 @@ libubacktrace-a-y+=$(libubacktrace_ARCH_OBJS:.o=.os)
93  else
94  libubacktrace-a-y+=$(libubacktrace_ARCH_OBJS)
95  endif
96 -libubacktrace-so-y+=$(libubacktrace_ARCH_OBJS:.o=.os)
97 +libubacktrace-so-y+=$(libubacktrace_ARCH_OBJS:.o=.oS)
98 diff --git a/libubacktrace/arm/backtrace.c b/libubacktrace/arm/backtrace.c
99 index d4eca32..5955189 100644
100 --- a/libubacktrace/arm/backtrace.c
101 +++ b/libubacktrace/arm/backtrace.c
102 @@ -25,6 +25,7 @@ struct trace_arg
103    int cnt, size;
104  };
105  
106 +#ifdef SHARED
107  static _Unwind_Reason_Code (*unwind_backtrace) (_Unwind_Trace_Fn, void *);
108  static _Unwind_VRS_Result (*unwind_vrs_get) (_Unwind_Context *,
109                                              _Unwind_VRS_RegClass,
110 @@ -42,6 +43,10 @@ static void backtrace_init (void)
111                 abort();
112         }
113  }
114 +#else
115 +# define unwind_backtrace _Unwind_Backtrace
116 +# define unwind_vrs_get _Unwind_VRS_Get
117 +#endif
118  /* This function is identical to "_Unwind_GetGR", except that it uses
119     "unwind_vrs_get" instead of "_Unwind_VRS_Get".  */
120  static inline _Unwind_Word
121 @@ -80,8 +85,10 @@ int backtrace (void **array, int size)
122  {
123         struct trace_arg arg = { .array = array, .size = size, .cnt = -1 };
124  
125 +#ifdef SHARED
126         if (unwind_backtrace == NULL)
127                 backtrace_init();
128 +#endif
129  
130         if (size >= 1)
131                 unwind_backtrace (backtrace_helper, &arg);
132 diff --git a/libubacktrace/backtrace.c b/libubacktrace/backtrace.c
133 index fdd5981..1e0a0ec 100644
134 --- a/libubacktrace/backtrace.c
135 +++ b/libubacktrace/backtrace.c
136 @@ -33,6 +33,7 @@ struct trace_arg
137    int cnt, size;
138  };
139  
140 +#ifdef SHARED
141  static _Unwind_Reason_Code (*unwind_backtrace) (_Unwind_Trace_Fn, void *);
142  static _Unwind_Ptr (*unwind_getip) (struct _Unwind_Context *);
143  
144 @@ -47,6 +48,10 @@ static void backtrace_init (void)
145                 abort();
146         }
147  }
148 +#else
149 +# define unwind_backtrace _Unwind_Backtrace
150 +# define unwind_getip _Unwind_GetIP
151 +#endif
152  
153  static _Unwind_Reason_Code
154  backtrace_helper (struct _Unwind_Context *ctx, void *a)
155 @@ -71,8 +76,10 @@ int backtrace (void **array, int size)
156  {
157         struct trace_arg arg = { .array = array, .size = size, .cnt = -1 };
158  
159 +#ifdef SHARED
160         if (unwind_backtrace == NULL)
161                 backtrace_init();
162 +#endif
163  
164         if (size >= 1)
165                 unwind_backtrace (backtrace_helper, &arg);
166 -- 
167 1.7.10.4
168