llvm-project/clang/test/Sema/atomic-ops.c

38 lines
1.9 KiB
C

// RUN: %clang_cc1 %s -verify -fsyntax-only
// Basic parsing/Sema tests for __atomic_*
// FIXME: Need to implement __atomic_is_lock_free
typedef enum memory_order {
memory_order_relaxed, memory_order_consume, memory_order_acquire,
memory_order_release, memory_order_acq_rel, memory_order_seq_cst
} memory_order;
void f(_Atomic(int) *i, _Atomic(int*) *p, _Atomic(float) *d) {
__atomic_load(0); // expected-error {{too few arguments to function}}
__atomic_load(0,0,0); // expected-error {{too many arguments to function}}
__atomic_store(0,0,0); // expected-error {{first argument to atomic operation}}
__atomic_store((int*)0,0,0); // expected-error {{first argument to atomic operation}}
__atomic_load(i, memory_order_seq_cst);
__atomic_load(p, memory_order_seq_cst);
__atomic_load(d, memory_order_seq_cst);
__atomic_store(i, 1, memory_order_seq_cst);
__atomic_store(p, 1, memory_order_seq_cst); // expected-warning {{incompatible integer to pointer conversion}}
(int)__atomic_store(d, 1, memory_order_seq_cst); // expected-error {{operand of type 'void'}}
__atomic_fetch_add(i, 1, memory_order_seq_cst);
__atomic_fetch_add(p, 1, memory_order_seq_cst);
__atomic_fetch_add(d, 1, memory_order_seq_cst); // expected-error {{must be a pointer to atomic integer or pointer}}
__atomic_fetch_and(i, 1, memory_order_seq_cst);
__atomic_fetch_and(p, 1, memory_order_seq_cst); // expected-error {{must be a pointer to atomic integer}}
__atomic_fetch_and(d, 1, memory_order_seq_cst); // expected-error {{must be a pointer to atomic integer}}
__atomic_compare_exchange_strong(i, 0, 1, memory_order_seq_cst, memory_order_seq_cst);
__atomic_compare_exchange_strong(p, 0, (int*)1, memory_order_seq_cst, memory_order_seq_cst);
__atomic_compare_exchange_strong(d, (int*)0, 1, memory_order_seq_cst, memory_order_seq_cst); // expected-warning {{incompatible pointer types}}
}