diff options
author | Martin Jansa <martin.jansa@gmail.com> | 2015-10-29 11:50:32 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-11-25 08:08:07 +0000 |
commit | b06eacdacf8aa6dd71aad1b49c66a5a5309fb336 (patch) | |
tree | 611bf6937eac2cda9f1951a5f348fd4f9199fb36 /meta/recipes-support | |
parent | c4acacefc18d7cf9c25031c86c07097001c81da3 (diff) | |
download | poky-b06eacdacf8aa6dd71aad1b49c66a5a5309fb336.tar.gz |
libunwind: fix build for qemuarm
(From OE-Core rev: 9c370e54101c2de13cbabefb38eaa6cf584f348c)
Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-support')
-rw-r--r-- | meta/recipes-support/libunwind/libunwind-1.1/Add-AO_REQUIRE_CAS-to-fix-build-on-ARM-v6.patch | 62 | ||||
-rw-r--r-- | meta/recipes-support/libunwind/libunwind_1.1.bb | 1 |
2 files changed, 63 insertions, 0 deletions
diff --git a/meta/recipes-support/libunwind/libunwind-1.1/Add-AO_REQUIRE_CAS-to-fix-build-on-ARM-v6.patch b/meta/recipes-support/libunwind/libunwind-1.1/Add-AO_REQUIRE_CAS-to-fix-build-on-ARM-v6.patch new file mode 100644 index 0000000000..0dff2c86dc --- /dev/null +++ b/meta/recipes-support/libunwind/libunwind-1.1/Add-AO_REQUIRE_CAS-to-fix-build-on-ARM-v6.patch | |||
@@ -0,0 +1,62 @@ | |||
1 | From 24484e80b3e329c9edee1995e102f8612eedb79c Mon Sep 17 00:00:00 2001 | ||
2 | From: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> | ||
3 | Date: Tue, 13 May 2014 23:32:27 +0200 | ||
4 | Subject: [PATCH] Add AO_REQUIRE_CAS to fix build on ARM < v6 | ||
5 | |||
6 | ARM earlier than ARMv6, such as ARMv4 and ARMv5 do not provide | ||
7 | optimize atomic operations in libatomic_ops. Since libunwind is using | ||
8 | such operations, it should define AO_REQUIRE_CAS before including | ||
9 | <atomic_ops.h> so that libatomic_ops knows it should use emulated | ||
10 | atomic operations instead (even though they are obviously a lot more | ||
11 | expensive). | ||
12 | |||
13 | Also, while real atomic operations are all inline functions and | ||
14 | therefore linking against libatomic_ops was not required, the emulated | ||
15 | atomic operations actually require linking against libatomic_ops, so | ||
16 | the commented AC_CHECK_LIB test in acinclude.m4 is uncommented to make | ||
17 | sure we link against libatomic_ops. | ||
18 | |||
19 | Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> | ||
20 | Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com> | ||
21 | |||
22 | Upstream-Status: Pending | ||
23 | Taken from: | ||
24 | https://raw.githubusercontent.com/rdnetto/teapot-buildroot/master/package/libunwind/libunwind-02-Add-AO_REQUIRE_CAS-to-fix-build-on-ARM-v6.patch | ||
25 | |||
26 | --- | ||
27 | acinclude.m4 | 8 +------- | ||
28 | include/libunwind_i.h | 1 + | ||
29 | 2 files changed, 2 insertions(+), 7 deletions(-) | ||
30 | |||
31 | diff --git a/acinclude.m4 b/acinclude.m4 | ||
32 | index 497f7c2..9c15af1 100644 | ||
33 | --- a/acinclude.m4 | ||
34 | +++ b/acinclude.m4 | ||
35 | @@ -22,11 +22,5 @@ fi]) | ||
36 | AC_DEFUN([CHECK_ATOMIC_OPS], | ||
37 | [dnl Check whether the system has the atomic_ops package installed. | ||
38 | AC_CHECK_HEADERS(atomic_ops.h) | ||
39 | -# | ||
40 | -# Don't link against libatomic_ops for now. We don't want libunwind | ||
41 | -# to depend on libatomic_ops.so. Fortunately, none of the platforms | ||
42 | -# we care about so far need libatomic_ops.a (everything is done via | ||
43 | -# inline macros). | ||
44 | -# | ||
45 | -# AC_CHECK_LIB(atomic_ops, main) | ||
46 | + AC_CHECK_LIB(atomic_ops, main) | ||
47 | ]) | ||
48 | diff --git a/include/libunwind_i.h b/include/libunwind_i.h | ||
49 | index 23f615e..deabdfd 100644 | ||
50 | --- a/include/libunwind_i.h | ||
51 | +++ b/include/libunwind_i.h | ||
52 | @@ -95,6 +95,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ | ||
53 | (pthread_mutex_unlock != NULL ? pthread_mutex_unlock (l) : 0) | ||
54 | |||
55 | #ifdef HAVE_ATOMIC_OPS_H | ||
56 | +# define AO_REQUIRE_CAS | ||
57 | # include <atomic_ops.h> | ||
58 | static inline int | ||
59 | cmpxchg_ptr (void *addr, void *old, void *new) | ||
60 | -- | ||
61 | 1.9.2 | ||
62 | |||
diff --git a/meta/recipes-support/libunwind/libunwind_1.1.bb b/meta/recipes-support/libunwind/libunwind_1.1.bb index 8282c1b71a..ebeec16acd 100644 --- a/meta/recipes-support/libunwind/libunwind_1.1.bb +++ b/meta/recipes-support/libunwind/libunwind_1.1.bb | |||
@@ -6,6 +6,7 @@ SRC_URI += "\ | |||
6 | file://Fix-test-case-link-failure-on-PowerPC-systems-with-Altivec.patch \ | 6 | file://Fix-test-case-link-failure-on-PowerPC-systems-with-Altivec.patch \ |
7 | file://Link-libunwind-to-libgcc_s-rather-than-libgcc.patch \ | 7 | file://Link-libunwind-to-libgcc_s-rather-than-libgcc.patch \ |
8 | file://0001-Invalid-dwarf-opcodes-can-cause-references-beyond-th.patch \ | 8 | file://0001-Invalid-dwarf-opcodes-can-cause-references-beyond-th.patch \ |
9 | file://Add-AO_REQUIRE_CAS-to-fix-build-on-ARM-v6.patch \ | ||
9 | " | 10 | " |
10 | 11 | ||
11 | SRC_URI[md5sum] = "fb4ea2f6fbbe45bf032cd36e586883ce" | 12 | SRC_URI[md5sum] = "fb4ea2f6fbbe45bf032cd36e586883ce" |