diff options
author | Xin Ouyang <Xin.Ouyang@windriver.com> | 2012-08-14 09:49:08 +0800 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2012-08-17 18:04:21 +0100 |
commit | 4c70d7e84924ce3e02336b1ad36231f735c37c10 (patch) | |
tree | d2a2ee6e75d032f3c5497e9ba6b8a81596f2009e /meta | |
parent | f31c96eac6e44e12c63e4da0b8353a101e288dc6 (diff) | |
download | poky-4c70d7e84924ce3e02336b1ad36231f735c37c10.tar.gz |
libatomics-ops: update to the latest version 7.2
All old patches are droped because:
Merged into 7.2 by upstream:
* fedora/libatomic_ops-1.2-ppclwzfix.patch
* gentoo/libatomic_ops-1.2-mips.patch
* gentoo/sh4-atomic-ops.patch
* libatomics-ops_fix_for_x32.patch
Obsolete:
* doublefix.patch
(From OE-Core rev: cf7a52c8f2b84901421c7e2cee3009fe91687a1c)
Signed-off-by: Xin Ouyang <Xin.Ouyang@windriver.com>
Signed-off-by: Saul Wold <sgw@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta')
-rw-r--r-- | meta/recipes-multimedia/pulseaudio/libatomics-ops/doublefix.patch | 27 | ||||
-rw-r--r-- | meta/recipes-multimedia/pulseaudio/libatomics-ops/fedora/libatomic_ops-1.2-ppclwzfix.patch | 20 | ||||
-rw-r--r-- | meta/recipes-multimedia/pulseaudio/libatomics-ops/gentoo/libatomic_ops-1.2-mips.patch | 129 | ||||
-rw-r--r-- | meta/recipes-multimedia/pulseaudio/libatomics-ops/gentoo/sh4-atomic-ops.patch | 70 | ||||
-rw-r--r-- | meta/recipes-multimedia/pulseaudio/libatomics-ops/libatomics-ops_fix_for_x32.patch | 41 | ||||
-rw-r--r-- | meta/recipes-multimedia/pulseaudio/libatomics-ops_7.2.bb (renamed from meta/recipes-multimedia/pulseaudio/libatomics-ops_1.2.bb) | 11 |
6 files changed, 3 insertions, 295 deletions
diff --git a/meta/recipes-multimedia/pulseaudio/libatomics-ops/doublefix.patch b/meta/recipes-multimedia/pulseaudio/libatomics-ops/doublefix.patch deleted file mode 100644 index 0d3b718597..0000000000 --- a/meta/recipes-multimedia/pulseaudio/libatomics-ops/doublefix.patch +++ /dev/null | |||
@@ -1,27 +0,0 @@ | |||
1 | Upstream-Status: Inappropriate [configuration] | ||
2 | |||
3 | Double path references breaks recent autoconf+automake | ||
4 | |||
5 | RP 2/1/10 | ||
6 | |||
7 | Index: libatomic_ops-1.2/src/atomic_ops/sysdeps/Makefile.am | ||
8 | =================================================================== | ||
9 | --- libatomic_ops-1.2.orig/src/atomic_ops/sysdeps/Makefile.am 2005-09-28 00:53:16.000000000 +0100 | ||
10 | +++ libatomic_ops-1.2/src/atomic_ops/sysdeps/Makefile.am 2010-02-01 14:28:46.397820574 +0000 | ||
11 | @@ -25,7 +25,6 @@ | ||
12 | README \ | ||
13 | \ | ||
14 | gcc/alpha.h gcc/arm.h gcc/x86.h \ | ||
15 | - gcc/hppa.h gcc/ia64.h \ | ||
16 | gcc/powerpc.h gcc/sparc.h \ | ||
17 | gcc/hppa.h gcc/m68k.h gcc/s390.h \ | ||
18 | gcc/ia64.h gcc/x86_64.h gcc/cris.h \ | ||
19 | Index: libatomic_ops-1.2/doc/Makefile.am | ||
20 | =================================================================== | ||
21 | --- libatomic_ops-1.2.orig/doc/Makefile.am 2010-02-01 15:20:09.207788884 +0000 | ||
22 | +++ libatomic_ops-1.2/doc/Makefile.am 2010-02-01 15:20:20.909049794 +0000 | ||
23 | @@ -1,3 +1,3 @@ | ||
24 | # installed documentation | ||
25 | # | ||
26 | -dist_pkgdata_DATA=COPYING LICENSING.txt README.txt COPYING README_stack.txt README_malloc.txt README_win32.txt | ||
27 | +dist_pkgdata_DATA=LICENSING.txt README.txt COPYING README_stack.txt README_malloc.txt README_win32.txt | ||
diff --git a/meta/recipes-multimedia/pulseaudio/libatomics-ops/fedora/libatomic_ops-1.2-ppclwzfix.patch b/meta/recipes-multimedia/pulseaudio/libatomics-ops/fedora/libatomic_ops-1.2-ppclwzfix.patch deleted file mode 100644 index 315ae917fa..0000000000 --- a/meta/recipes-multimedia/pulseaudio/libatomics-ops/fedora/libatomic_ops-1.2-ppclwzfix.patch +++ /dev/null | |||
@@ -1,20 +0,0 @@ | |||
1 | Upstream-Status: Inappropriate [others] | ||
2 | |||
3 | The patch is imported from fedora project, and is not appropriate for us | ||
4 | to upstream it. | ||
5 | |||
6 | http://cvs.fedoraproject.org/viewcvs/devel/libatomic_ops/libatomic_ops-1.2-ppclwzfix.patch | ||
7 | |||
8 | * add fix for bad variable handling on PPC | ||
9 | |||
10 | --- libatomic_ops-1.2.orig/src/atomic_ops/sysdeps/gcc/powerpc.h 2007-05-29 19:29:52.000000000 +0200 | ||
11 | +++ libatomic_ops-1.2/src/atomic_ops/sysdeps/gcc/powerpc.h 2007-05-29 19:30:48.000000000 +0200 | ||
12 | @@ -72,7 +72,7 @@ | ||
13 | /* registers. I always got "impossible constraint" when I */ | ||
14 | /* tried the "y" constraint. */ | ||
15 | __asm__ __volatile__ ( | ||
16 | - "lwz %0,%1\n" | ||
17 | + "lwz%U1%X1 %0,%1\n" | ||
18 | "cmpw cr7,%0,%0\n" | ||
19 | "bne- cr7,1f\n" | ||
20 | "1: isync\n" | ||
diff --git a/meta/recipes-multimedia/pulseaudio/libatomics-ops/gentoo/libatomic_ops-1.2-mips.patch b/meta/recipes-multimedia/pulseaudio/libatomics-ops/gentoo/libatomic_ops-1.2-mips.patch deleted file mode 100644 index 971379d3ad..0000000000 --- a/meta/recipes-multimedia/pulseaudio/libatomics-ops/gentoo/libatomic_ops-1.2-mips.patch +++ /dev/null | |||
@@ -1,129 +0,0 @@ | |||
1 | Upstream-Status: Inappropriate [others] | ||
2 | |||
3 | Patch from gentoo which is not appropriate for us to upstream. | ||
4 | |||
5 | # Patch copied from the OpenEmbedded libatomics-ops recipe. Original | ||
6 | # source was from Gentoo. | ||
7 | # | ||
8 | # Signed-off-by: Scott Garman <scott.a.garman@intel.com> | ||
9 | diff --git a/src/atomic_ops.h b/src/atomic_ops.h | ||
10 | index c23f30b..791b360 100755 | ||
11 | --- a/src/atomic_ops.h | ||
12 | +++ b/src/atomic_ops.h | ||
13 | @@ -220,6 +220,9 @@ | ||
14 | # if defined(__cris__) || defined(CRIS) | ||
15 | # include "atomic_ops/sysdeps/gcc/cris.h" | ||
16 | # endif | ||
17 | +# if defined(__mips__) | ||
18 | +# include "atomic_ops/sysdeps/gcc/mips.h" | ||
19 | +# endif | ||
20 | #endif /* __GNUC__ && !AO_USE_PTHREAD_DEFS */ | ||
21 | |||
22 | #if defined(__INTEL_COMPILER) && !defined(AO_USE_PTHREAD_DEFS) | ||
23 | diff --git a/src/atomic_ops/sysdeps/Makefile.am b/src/atomic_ops/sysdeps/Makefile.am | ||
24 | index 74122b4..d6737c0 100644 | ||
25 | --- a/src/atomic_ops/sysdeps/Makefile.am | ||
26 | +++ b/src/atomic_ops/sysdeps/Makefile.am | ||
27 | @@ -29,6 +29,7 @@ nobase_sysdep_HEADERS= generic_pthread.h \ | ||
28 | gcc/powerpc.h gcc/sparc.h \ | ||
29 | gcc/hppa.h gcc/m68k.h gcc/s390.h \ | ||
30 | gcc/ia64.h gcc/x86_64.h gcc/cris.h \ | ||
31 | + gcc/mips.h \ | ||
32 | \ | ||
33 | icc/ia64.h \ | ||
34 | \ | ||
35 | diff --git a/src/atomic_ops/sysdeps/gcc/mips.h b/src/atomic_ops/sysdeps/gcc/mips.h | ||
36 | new file mode 100644 | ||
37 | index 0000000..e7f3a5d | ||
38 | --- /dev/null | ||
39 | +++ b/src/atomic_ops/sysdeps/gcc/mips.h | ||
40 | @@ -0,0 +1,89 @@ | ||
41 | +/* | ||
42 | + * Copyright (c) 2005 Thiemo Seufer <ths@networkno.de> | ||
43 | + * Copyright (c) 2007 Zhang Le <r0bertz@gentoo.org> | ||
44 | + * | ||
45 | + * THIS MATERIAL IS PROVIDED AS IS, WITH ABSOLUTELY NO WARRANTY EXPRESSED | ||
46 | + * OR IMPLIED. ANY USE IS AT YOUR OWN RISK. | ||
47 | + * | ||
48 | + * Permission is hereby granted to use or copy this program | ||
49 | + * for any purpose, provided the above notices are retained on all copies. | ||
50 | + * Permission to modify the code and to distribute modified code is granted, | ||
51 | + * provided the above notices are retained, and a notice that the code was | ||
52 | + * modified is included with the above copyright notice. | ||
53 | + */ | ||
54 | + | ||
55 | +#include "../all_aligned_atomic_load_store.h" | ||
56 | +#include "../test_and_set_t_is_ao_t.h" | ||
57 | + | ||
58 | +/* Data dependence does not imply read ordering. */ | ||
59 | +#define AO_NO_DD_ORDERING | ||
60 | + | ||
61 | +AO_INLINE void | ||
62 | +AO_nop_full() | ||
63 | +{ | ||
64 | + __asm__ __volatile__( | ||
65 | + " .set push \n" | ||
66 | + " .set mips3 \n" | ||
67 | + " .set noreorder \n" | ||
68 | + " .set nomacro \n" | ||
69 | + " sync \n" | ||
70 | + " .set pop " | ||
71 | + : : : "memory"); | ||
72 | +} | ||
73 | + | ||
74 | +#define AO_HAVE_nop_full | ||
75 | + | ||
76 | +AO_INLINE int | ||
77 | +AO_compare_and_swap(volatile AO_t *addr, AO_t old, AO_t new_val) | ||
78 | +{ | ||
79 | + register int was_equal = 0; | ||
80 | + register int temp; | ||
81 | + | ||
82 | + __asm__ __volatile__( | ||
83 | + " .set push \n" | ||
84 | + " .set mips3 \n" | ||
85 | + " .set noreorder \n" | ||
86 | + " .set nomacro \n" | ||
87 | + "1: ll %0, %1 \n" | ||
88 | + " bne %0, %4, 2f \n" | ||
89 | + " move %0, %3 \n" | ||
90 | + " sc %0, %1 \n" | ||
91 | + " .set pop \n" | ||
92 | + " beqz %0, 1b \n" | ||
93 | + " li %2, 1 \n" | ||
94 | + "2: " | ||
95 | + : "=&r" (temp), "+R" (*addr), "+r" (was_equal) | ||
96 | + : "r" (new_val), "r" (old) | ||
97 | + : "memory"); | ||
98 | + return was_equal; | ||
99 | +} | ||
100 | + | ||
101 | +#define AO_HAVE_compare_and_swap | ||
102 | + | ||
103 | +AO_INLINE AO_t | ||
104 | +AO_fetch_and_add_full (volatile AO_t *p, AO_t incr) | ||
105 | +{ | ||
106 | + AO_t result, temp; | ||
107 | + __asm__ __volatile__( | ||
108 | + " .set push \n" | ||
109 | + " .set mips3 \n" | ||
110 | + " .set noreorder \n" | ||
111 | + " .set nomacro \n" | ||
112 | + "1: ll %1, %2 \n" | ||
113 | + " addu %0, %1, %3 \n" | ||
114 | + " sc %0, %2 \n" | ||
115 | + " beqz %0, 1b \n" | ||
116 | + " addu %0, %1, %3 \n" | ||
117 | + " sync \n" | ||
118 | + " .set pop \n" | ||
119 | + : "=&r" (result), "=&r" (temp), "=m" (*p) | ||
120 | + : "r" (incr), "m" (*p) | ||
121 | + : "memory"); | ||
122 | + return result; | ||
123 | +} | ||
124 | + | ||
125 | +#define AO_HAVE_fetch_and_add_full | ||
126 | + | ||
127 | +/* | ||
128 | + * FIXME: fetch_and_add_full implemented, any others? | ||
129 | + */ | ||
diff --git a/meta/recipes-multimedia/pulseaudio/libatomics-ops/gentoo/sh4-atomic-ops.patch b/meta/recipes-multimedia/pulseaudio/libatomics-ops/gentoo/sh4-atomic-ops.patch deleted file mode 100644 index dfdd29cad5..0000000000 --- a/meta/recipes-multimedia/pulseaudio/libatomics-ops/gentoo/sh4-atomic-ops.patch +++ /dev/null | |||
@@ -1,70 +0,0 @@ | |||
1 | This patch is taken from Gentoo | ||
2 | http://sources.gentoo.org/cgi-bin/viewvc.cgi/gentoo-x86/dev-libs/libatomic_ops/files/libatomic_ops-1.2-sh4.patch?revision=1.1&view=markup | ||
3 | |||
4 | Upstream-Status: Pending | ||
5 | Signed-off-by: Khem Raj <raj.khem@gmail.com> | ||
6 | |||
7 | Index: libatomic_ops-1.2/src/atomic_ops.h | ||
8 | =================================================================== | ||
9 | --- libatomic_ops-1.2.orig/src/atomic_ops.h 2012-04-30 13:56:17.000000000 -0700 | ||
10 | +++ libatomic_ops-1.2/src/atomic_ops.h 2012-04-30 13:58:28.747602349 -0700 | ||
11 | @@ -223,6 +223,10 @@ | ||
12 | # if defined(__mips__) | ||
13 | # include "atomic_ops/sysdeps/gcc/mips.h" | ||
14 | # endif | ||
15 | +# if defined(__sh__) || defined(SH4) | ||
16 | +# include "atomic_ops/sysdeps/gcc/sh.h" | ||
17 | +# define AO_CAN_EMUL_CAS | ||
18 | +# endif /* __sh__ */ | ||
19 | #endif /* __GNUC__ && !AO_USE_PTHREAD_DEFS */ | ||
20 | |||
21 | #if defined(__INTEL_COMPILER) && !defined(AO_USE_PTHREAD_DEFS) | ||
22 | Index: libatomic_ops-1.2/src/atomic_ops/sysdeps/Makefile.am | ||
23 | =================================================================== | ||
24 | --- libatomic_ops-1.2.orig/src/atomic_ops/sysdeps/Makefile.am 2012-04-30 10:52:18.000000000 -0700 | ||
25 | +++ libatomic_ops-1.2/src/atomic_ops/sysdeps/Makefile.am 2012-04-30 14:00:11.511609965 -0700 | ||
26 | @@ -28,7 +28,7 @@ | ||
27 | gcc/powerpc.h gcc/sparc.h \ | ||
28 | gcc/hppa.h gcc/m68k.h gcc/s390.h \ | ||
29 | gcc/ia64.h gcc/x86_64.h gcc/cris.h \ | ||
30 | - gcc/mips.h \ | ||
31 | + gcc/mips.h gcc/sh.h \ | ||
32 | \ | ||
33 | icc/ia64.h \ | ||
34 | \ | ||
35 | Index: libatomic_ops-1.2/src/atomic_ops/sysdeps/gcc/sh.h | ||
36 | =================================================================== | ||
37 | --- /dev/null 1970-01-01 00:00:00.000000000 +0000 | ||
38 | +++ libatomic_ops-1.2/src/atomic_ops/sysdeps/gcc/sh.h 2012-04-30 13:58:28.755602350 -0700 | ||
39 | @@ -0,0 +1,31 @@ | ||
40 | +/* | ||
41 | + * Copyright (c) 2009 by Takashi YOSHII. All rights reserved. | ||
42 | + * | ||
43 | + * THIS MATERIAL IS PROVIDED AS IS, WITH ABSOLUTELY NO WARRANTY EXPRESSED | ||
44 | + * OR IMPLIED. ANY USE IS AT YOUR OWN RISK. | ||
45 | + * | ||
46 | + * Permission is hereby granted to use or copy this program | ||
47 | + * for any purpose, provided the above notices are retained on all copies. | ||
48 | + * Permission to modify the code and to distribute modified code is granted, | ||
49 | + * provided the above notices are retained, and a notice that the code was | ||
50 | + * modified is included with the above copyright notice. | ||
51 | + */ | ||
52 | + | ||
53 | +#include "../all_atomic_load_store.h" | ||
54 | +#include "../ordered.h" | ||
55 | + | ||
56 | +/* sh has tas.b(byte) only */ | ||
57 | +#include "../test_and_set_t_is_char.h" | ||
58 | + | ||
59 | +AO_INLINE AO_TS_VAL_t | ||
60 | +AO_test_and_set_full(volatile AO_TS_t *addr) | ||
61 | +{ | ||
62 | + int oldval; | ||
63 | + __asm__ __volatile__( | ||
64 | + "tas.b @%1; movt %0" | ||
65 | + : "=r" (oldval) | ||
66 | + : "r" (addr) | ||
67 | + : "t", "memory"); | ||
68 | + return oldval? AO_TS_CLEAR : AO_TS_SET; | ||
69 | +} | ||
70 | +#define AO_HAVE_test_and_set_full | ||
diff --git a/meta/recipes-multimedia/pulseaudio/libatomics-ops/libatomics-ops_fix_for_x32.patch b/meta/recipes-multimedia/pulseaudio/libatomics-ops/libatomics-ops_fix_for_x32.patch deleted file mode 100644 index 17686063de..0000000000 --- a/meta/recipes-multimedia/pulseaudio/libatomics-ops/libatomics-ops_fix_for_x32.patch +++ /dev/null | |||
@@ -1,41 +0,0 @@ | |||
1 | Upstream-Status: Pending | ||
2 | |||
3 | Remove the `q' suffix on x86-64 atomic instructions. | ||
4 | |||
5 | We don't need the `q' suffix on x86_64 atomic instructions for AO_t, | ||
6 | which is defined as "unsigned long". "unsigned long" is 32bit for x32 | ||
7 | and 64bit for x86-64. The register operand in x86-64 atomic instructions | ||
8 | is sufficient to properly determine the register size. | ||
9 | |||
10 | Received this patch from H.J. Lu <hjl.tools@gmail.com> | ||
11 | Signed-Off-By: Nitin A Kamble <nitin.a.kamble@intel.com> 2011/12/02 | ||
12 | |||
13 | --- libatomic_ops-1.2/src/atomic_ops/sysdeps/gcc/x86_64.h.x32 2005-09-28 17:16:38.000000000 -0700 | ||
14 | +++ libatomic_ops-1.2/src/atomic_ops/sysdeps/gcc/x86_64.h 2011-12-02 09:29:54.265251875 -0800 | ||
15 | @@ -60,7 +60,7 @@ AO_fetch_and_add_full (volatile AO_t *p, | ||
16 | { | ||
17 | AO_t result; | ||
18 | |||
19 | - __asm__ __volatile__ ("lock; xaddq %0, %1" : | ||
20 | + __asm__ __volatile__ ("lock; xadd %0, %1" : | ||
21 | "=r" (result), "=m" (*p) : "0" (incr), "m" (*p) | ||
22 | : "memory"); | ||
23 | return result; | ||
24 | @@ -111,7 +111,7 @@ AO_int_fetch_and_add_full (volatile unsi | ||
25 | AO_INLINE void | ||
26 | AO_or_full (volatile AO_t *p, AO_t incr) | ||
27 | { | ||
28 | - __asm__ __volatile__ ("lock; orq %1, %0" : | ||
29 | + __asm__ __volatile__ ("lock; or %1, %0" : | ||
30 | "=m" (*p) : "r" (incr), "m" (*p) : "memory"); | ||
31 | } | ||
32 | |||
33 | @@ -136,7 +136,7 @@ AO_compare_and_swap_full(volatile AO_t * | ||
34 | AO_t old, AO_t new_val) | ||
35 | { | ||
36 | char result; | ||
37 | - __asm__ __volatile__("lock; cmpxchgq %3, %0; setz %1" | ||
38 | + __asm__ __volatile__("lock; cmpxchg %3, %0; setz %1" | ||
39 | : "=m"(*addr), "=q"(result) | ||
40 | : "m"(*addr), "r" (new_val), "a"(old) : "memory"); | ||
41 | return (int) result; | ||
diff --git a/meta/recipes-multimedia/pulseaudio/libatomics-ops_1.2.bb b/meta/recipes-multimedia/pulseaudio/libatomics-ops_7.2.bb index eba43cd216..3706656d60 100644 --- a/meta/recipes-multimedia/pulseaudio/libatomics-ops_1.2.bb +++ b/meta/recipes-multimedia/pulseaudio/libatomics-ops_7.2.bb | |||
@@ -6,18 +6,13 @@ LICENSE = "GPLv2 & MIT" | |||
6 | LIC_FILES_CHKSUM = "file://doc/COPYING;md5=94d55d512a9ba36caa9b7df079bae19f \ | 6 | LIC_FILES_CHKSUM = "file://doc/COPYING;md5=94d55d512a9ba36caa9b7df079bae19f \ |
7 | file://doc/LICENSING.txt;md5=607073e04548eac7d1f763e480477bab \ | 7 | file://doc/LICENSING.txt;md5=607073e04548eac7d1f763e480477bab \ |
8 | " | 8 | " |
9 | PR = "r10" | 9 | PR = "r0" |
10 | 10 | ||
11 | SRC_URI = "http://www.hpl.hp.com/research/linux/atomic_ops/download/libatomic_ops-${PV}.tar.gz \ | 11 | SRC_URI = "http://www.hpl.hp.com/research/linux/atomic_ops/download/libatomic_ops-${PV}.tar.gz \ |
12 | file://fedora/libatomic_ops-1.2-ppclwzfix.patch \ | ||
13 | file://gentoo/libatomic_ops-1.2-mips.patch \ | ||
14 | file://doublefix.patch \ | ||
15 | file://libatomics-ops_fix_for_x32.patch \ | ||
16 | file://gentoo/sh4-atomic-ops.patch \ | ||
17 | " | 12 | " |
18 | 13 | ||
19 | SRC_URI[md5sum] = "1b65e48271c81e3fa2d7a9a69bab7504" | 14 | SRC_URI[md5sum] = "890acdc83a7cd10e2e9536062d3741c8" |
20 | SRC_URI[sha256sum] = "a3d8768aa8fd2f6ae79be2d756b3a6b48816b3889ae906be3d5ffb2de5a5c781" | 15 | SRC_URI[sha256sum] = "c4ee6e0c304c6f13bcc32968453cdb54b2ec233d8bf4cfcf266ee09dc33b4eb5" |
21 | 16 | ||
22 | S = "${WORKDIR}/libatomic_ops-${PV}" | 17 | S = "${WORKDIR}/libatomic_ops-${PV}" |
23 | 18 | ||