mirror of git://gcc.gnu.org/git/gcc.git
re PR bootstrap/56714 (Bootstrap failure libitm/local_atomic:1580:3: error: always_inline function might not be inlinable)
PR bootstrap/56714 * local_atomic (__always_inline): Always define our version. (__calculate_memory_order): Mark inline. (atomic_thread_fence): Ditto. (atomic_signal_fence): Ditto. (atomic_bool::atomic_flag_test_and_set_explicit): Ditto. (atomic_bool::atomic_flag_clear_explicit): Ditto. (atomic_bool::atomic_flag_test_and_set): Ditto. (atomic_bool::atomic_flag_clear): Ditto. From-SVN: r199704
This commit is contained in:
parent
b57ca59bbd
commit
5124937746
|
|
@ -1,3 +1,15 @@
|
||||||
|
2013-03-31 Gerald Pfeifer <gerald@pfeifer.com>
|
||||||
|
|
||||||
|
PR bootstrap/56714
|
||||||
|
* local_atomic (__always_inline): Always define our version.
|
||||||
|
(__calculate_memory_order): Mark inline.
|
||||||
|
(atomic_thread_fence): Ditto.
|
||||||
|
(atomic_signal_fence): Ditto.
|
||||||
|
(atomic_bool::atomic_flag_test_and_set_explicit): Ditto.
|
||||||
|
(atomic_bool::atomic_flag_clear_explicit): Ditto.
|
||||||
|
(atomic_bool::atomic_flag_test_and_set): Ditto.
|
||||||
|
(atomic_bool::atomic_flag_clear): Ditto.
|
||||||
|
|
||||||
2013-04-23 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
|
2013-04-23 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
|
||||||
|
|
||||||
* config/s390/sjlj.S: New file.
|
* config/s390/sjlj.S: New file.
|
||||||
|
|
|
||||||
|
|
@ -41,9 +41,8 @@
|
||||||
#ifndef _GLIBCXX_ATOMIC
|
#ifndef _GLIBCXX_ATOMIC
|
||||||
#define _GLIBCXX_ATOMIC 1
|
#define _GLIBCXX_ATOMIC 1
|
||||||
|
|
||||||
#ifndef __always_inline
|
#undef __always_inline
|
||||||
#define __always_inline inline __attribute__((always_inline))
|
#define __always_inline __attribute__((always_inline))
|
||||||
#endif
|
|
||||||
|
|
||||||
// #pragma GCC system_header
|
// #pragma GCC system_header
|
||||||
|
|
||||||
|
|
@ -75,7 +74,7 @@ namespace std // _GLIBCXX_VISIBILITY(default)
|
||||||
memory_order_seq_cst
|
memory_order_seq_cst
|
||||||
} memory_order;
|
} memory_order;
|
||||||
|
|
||||||
__always_inline memory_order
|
inline __always_inline memory_order
|
||||||
__calculate_memory_order(memory_order __m) noexcept
|
__calculate_memory_order(memory_order __m) noexcept
|
||||||
{
|
{
|
||||||
const bool __cond1 = __m == memory_order_release;
|
const bool __cond1 = __m == memory_order_release;
|
||||||
|
|
@ -85,13 +84,13 @@ namespace std // _GLIBCXX_VISIBILITY(default)
|
||||||
return __mo2;
|
return __mo2;
|
||||||
}
|
}
|
||||||
|
|
||||||
__always_inline void
|
inline __always_inline void
|
||||||
atomic_thread_fence(memory_order __m) noexcept
|
atomic_thread_fence(memory_order __m) noexcept
|
||||||
{
|
{
|
||||||
__atomic_thread_fence (__m);
|
__atomic_thread_fence (__m);
|
||||||
}
|
}
|
||||||
|
|
||||||
__always_inline void
|
inline __always_inline void
|
||||||
atomic_signal_fence(memory_order __m) noexcept
|
atomic_signal_fence(memory_order __m) noexcept
|
||||||
{
|
{
|
||||||
__atomic_thread_fence (__m);
|
__atomic_thread_fence (__m);
|
||||||
|
|
@ -1545,38 +1544,38 @@ namespace std // _GLIBCXX_VISIBILITY(default)
|
||||||
|
|
||||||
|
|
||||||
// Function definitions, atomic_flag operations.
|
// Function definitions, atomic_flag operations.
|
||||||
__always_inline bool
|
inline __always_inline bool
|
||||||
atomic_flag_test_and_set_explicit(atomic_flag* __a,
|
atomic_flag_test_and_set_explicit(atomic_flag* __a,
|
||||||
memory_order __m) noexcept
|
memory_order __m) noexcept
|
||||||
{ return __a->test_and_set(__m); }
|
{ return __a->test_and_set(__m); }
|
||||||
|
|
||||||
__always_inline bool
|
inline __always_inline bool
|
||||||
atomic_flag_test_and_set_explicit(volatile atomic_flag* __a,
|
atomic_flag_test_and_set_explicit(volatile atomic_flag* __a,
|
||||||
memory_order __m) noexcept
|
memory_order __m) noexcept
|
||||||
{ return __a->test_and_set(__m); }
|
{ return __a->test_and_set(__m); }
|
||||||
|
|
||||||
__always_inline void
|
inline __always_inline void
|
||||||
atomic_flag_clear_explicit(atomic_flag* __a, memory_order __m) noexcept
|
atomic_flag_clear_explicit(atomic_flag* __a, memory_order __m) noexcept
|
||||||
{ __a->clear(__m); }
|
{ __a->clear(__m); }
|
||||||
|
|
||||||
__always_inline void
|
inline __always_inline void
|
||||||
atomic_flag_clear_explicit(volatile atomic_flag* __a,
|
atomic_flag_clear_explicit(volatile atomic_flag* __a,
|
||||||
memory_order __m) noexcept
|
memory_order __m) noexcept
|
||||||
{ __a->clear(__m); }
|
{ __a->clear(__m); }
|
||||||
|
|
||||||
__always_inline bool
|
inline __always_inline bool
|
||||||
atomic_flag_test_and_set(atomic_flag* __a) noexcept
|
atomic_flag_test_and_set(atomic_flag* __a) noexcept
|
||||||
{ return atomic_flag_test_and_set_explicit(__a, memory_order_seq_cst); }
|
{ return atomic_flag_test_and_set_explicit(__a, memory_order_seq_cst); }
|
||||||
|
|
||||||
__always_inline bool
|
inline __always_inline bool
|
||||||
atomic_flag_test_and_set(volatile atomic_flag* __a) noexcept
|
atomic_flag_test_and_set(volatile atomic_flag* __a) noexcept
|
||||||
{ return atomic_flag_test_and_set_explicit(__a, memory_order_seq_cst); }
|
{ return atomic_flag_test_and_set_explicit(__a, memory_order_seq_cst); }
|
||||||
|
|
||||||
__always_inline void
|
inline __always_inline void
|
||||||
atomic_flag_clear(atomic_flag* __a) noexcept
|
atomic_flag_clear(atomic_flag* __a) noexcept
|
||||||
{ atomic_flag_clear_explicit(__a, memory_order_seq_cst); }
|
{ atomic_flag_clear_explicit(__a, memory_order_seq_cst); }
|
||||||
|
|
||||||
__always_inline void
|
inline __always_inline void
|
||||||
atomic_flag_clear(volatile atomic_flag* __a) noexcept
|
atomic_flag_clear(volatile atomic_flag* __a) noexcept
|
||||||
{ atomic_flag_clear_explicit(__a, memory_order_seq_cst); }
|
{ atomic_flag_clear_explicit(__a, memory_order_seq_cst); }
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue