diff options
author | Dan Albert <danalbert@google.com> | 2015-01-06 22:18:27 +0000 |
---|---|---|
committer | Dan Albert <danalbert@google.com> | 2015-01-06 22:18:27 +0000 |
commit | d5c19bb16dec134bc9e690b479a8113a9c671c36 (patch) | |
tree | 9c6f8f4d6742add519e108f27a79bf734dd3e7ad /libcxx/test/std/atomics/atomics.general | |
parent | b8602af60271e628e613ff9b53c41568b643cf82 (diff) | |
download | bcm5719-llvm-d5c19bb16dec134bc9e690b479a8113a9c671c36.tar.gz bcm5719-llvm-d5c19bb16dec134bc9e690b479a8113a9c671c36.zip |
Move a test to the new tests directory.
I had written the patch that added this test before the tests were
moved into tests/std, so the test ended up in the wrong directory.
llvm-svn: 225300
Diffstat (limited to 'libcxx/test/std/atomics/atomics.general')
-rw-r--r-- | libcxx/test/std/atomics/atomics.general/replace_failure_order.pass.cpp | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/libcxx/test/std/atomics/atomics.general/replace_failure_order.pass.cpp b/libcxx/test/std/atomics/atomics.general/replace_failure_order.pass.cpp new file mode 100644 index 00000000000..cd0683d6887 --- /dev/null +++ b/libcxx/test/std/atomics/atomics.general/replace_failure_order.pass.cpp @@ -0,0 +1,43 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +// UNSUPPORTED: libcpp-has-no-threads + +// This test verifies behavior specified by [atomics.types.operations.req]/21: +// +// When only one memory_order argument is supplied, the value of success is +// order, and the value of failure is order except that a value of +// memory_order_acq_rel shall be replaced by the value memory_order_acquire +// and a value of memory_order_release shall be replaced by the value +// memory_order_relaxed. +// +// Clang's atomic intrinsics do this for us, but GCC's do not. We don't actually +// have visibility to see what these memory orders are lowered to, but we can at +// least check that they are lowered at all (otherwise there is a compile +// failure with GCC). + +#include <atomic> + +int main() { + std::atomic<int> i; + volatile std::atomic<int> v; + int exp = 0; + + i.compare_exchange_weak(exp, 0, std::memory_order_acq_rel); + i.compare_exchange_weak(exp, 0, std::memory_order_release); + i.compare_exchange_strong(exp, 0, std::memory_order_acq_rel); + i.compare_exchange_strong(exp, 0, std::memory_order_release); + + v.compare_exchange_weak(exp, 0, std::memory_order_acq_rel); + v.compare_exchange_weak(exp, 0, std::memory_order_release); + v.compare_exchange_strong(exp, 0, std::memory_order_acq_rel); + v.compare_exchange_strong(exp, 0, std::memory_order_release); + + return 0; +} |