atomic-ops.c 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472
  1. // RUN: %clang_cc1 %s -verify -ffreestanding -fsyntax-only -triple=i686-linux-gnu -std=c11
  2. // Basic parsing/Sema tests for __c11_atomic_*
  3. #include <stdatomic.h>
  4. struct S { char c[3]; };
  5. _Static_assert(__GCC_ATOMIC_BOOL_LOCK_FREE == 2, "");
  6. _Static_assert(__GCC_ATOMIC_CHAR_LOCK_FREE == 2, "");
  7. _Static_assert(__GCC_ATOMIC_CHAR16_T_LOCK_FREE == 2, "");
  8. _Static_assert(__GCC_ATOMIC_CHAR32_T_LOCK_FREE == 2, "");
  9. _Static_assert(__GCC_ATOMIC_WCHAR_T_LOCK_FREE == 2, "");
  10. _Static_assert(__GCC_ATOMIC_SHORT_LOCK_FREE == 2, "");
  11. _Static_assert(__GCC_ATOMIC_INT_LOCK_FREE == 2, "");
  12. _Static_assert(__GCC_ATOMIC_LONG_LOCK_FREE == 2, "");
  13. #ifdef __i386__
  14. _Static_assert(__GCC_ATOMIC_LLONG_LOCK_FREE == 1, "");
  15. #else
  16. _Static_assert(__GCC_ATOMIC_LLONG_LOCK_FREE == 2, "");
  17. #endif
  18. _Static_assert(__GCC_ATOMIC_POINTER_LOCK_FREE == 2, "");
  19. _Static_assert(__c11_atomic_is_lock_free(1), "");
  20. _Static_assert(__c11_atomic_is_lock_free(2), "");
  21. _Static_assert(__c11_atomic_is_lock_free(3), ""); // expected-error {{not an integral constant expression}}
  22. _Static_assert(__c11_atomic_is_lock_free(4), "");
  23. _Static_assert(__c11_atomic_is_lock_free(8), "");
  24. _Static_assert(__c11_atomic_is_lock_free(16), ""); // expected-error {{not an integral constant expression}}
  25. _Static_assert(__c11_atomic_is_lock_free(17), ""); // expected-error {{not an integral constant expression}}
  26. _Static_assert(__atomic_is_lock_free(1, 0), "");
  27. _Static_assert(__atomic_is_lock_free(2, 0), "");
  28. _Static_assert(__atomic_is_lock_free(3, 0), ""); // expected-error {{not an integral constant expression}}
  29. _Static_assert(__atomic_is_lock_free(4, 0), "");
  30. _Static_assert(__atomic_is_lock_free(8, 0), "");
  31. _Static_assert(__atomic_is_lock_free(16, 0), ""); // expected-error {{not an integral constant expression}}
  32. _Static_assert(__atomic_is_lock_free(17, 0), ""); // expected-error {{not an integral constant expression}}
  33. _Static_assert(atomic_is_lock_free((atomic_char*)0), "");
  34. _Static_assert(atomic_is_lock_free((atomic_short*)0), "");
  35. _Static_assert(atomic_is_lock_free((atomic_int*)0), "");
  36. _Static_assert(atomic_is_lock_free((atomic_long*)0), "");
  37. // expected-error@+1 {{__int128 is not supported on this target}}
  38. _Static_assert(atomic_is_lock_free((_Atomic(__int128)*)0), ""); // expected-error {{not an integral constant expression}}
  39. _Static_assert(atomic_is_lock_free(0 + (atomic_char*)0), "");
  40. char i8;
  41. short i16;
  42. int i32;
  43. int __attribute__((vector_size(8))) i64;
  44. struct Incomplete *incomplete; // expected-note {{forward declaration of 'struct Incomplete'}}
  45. _Static_assert(__atomic_is_lock_free(1, &i8), "");
  46. _Static_assert(__atomic_is_lock_free(1, &i64), "");
  47. _Static_assert(__atomic_is_lock_free(2, &i8), ""); // expected-error {{not an integral constant expression}}
  48. _Static_assert(__atomic_is_lock_free(2, &i16), "");
  49. _Static_assert(__atomic_is_lock_free(2, &i64), "");
  50. _Static_assert(__atomic_is_lock_free(4, &i16), ""); // expected-error {{not an integral constant expression}}
  51. _Static_assert(__atomic_is_lock_free(4, &i32), "");
  52. _Static_assert(__atomic_is_lock_free(4, &i64), "");
  53. _Static_assert(__atomic_is_lock_free(8, &i32), ""); // expected-error {{not an integral constant expression}}
  54. _Static_assert(__atomic_is_lock_free(8, &i64), "");
  55. _Static_assert(__atomic_always_lock_free(1, 0), "");
  56. _Static_assert(__atomic_always_lock_free(2, 0), "");
  57. _Static_assert(!__atomic_always_lock_free(3, 0), "");
  58. _Static_assert(__atomic_always_lock_free(4, 0), "");
  59. _Static_assert(__atomic_always_lock_free(8, 0), "");
  60. _Static_assert(!__atomic_always_lock_free(16, 0), "");
  61. _Static_assert(!__atomic_always_lock_free(17, 0), "");
  62. _Static_assert(__atomic_always_lock_free(1, incomplete), "");
  63. _Static_assert(!__atomic_always_lock_free(2, incomplete), "");
  64. _Static_assert(!__atomic_always_lock_free(4, incomplete), "");
  65. _Static_assert(__atomic_always_lock_free(1, &i8), "");
  66. _Static_assert(__atomic_always_lock_free(1, &i64), "");
  67. _Static_assert(!__atomic_always_lock_free(2, &i8), "");
  68. _Static_assert(__atomic_always_lock_free(2, &i16), "");
  69. _Static_assert(__atomic_always_lock_free(2, &i64), "");
  70. _Static_assert(!__atomic_always_lock_free(4, &i16), "");
  71. _Static_assert(__atomic_always_lock_free(4, &i32), "");
  72. _Static_assert(__atomic_always_lock_free(4, &i64), "");
  73. _Static_assert(!__atomic_always_lock_free(8, &i32), "");
  74. _Static_assert(__atomic_always_lock_free(8, &i64), "");
  75. void f(_Atomic(int) *i, _Atomic(int*) *p, _Atomic(float) *d,
  76. int *I, int **P, float *D, struct S *s1, struct S *s2) {
  77. __c11_atomic_init(I, 5); // expected-error {{pointer to _Atomic}}
  78. __c11_atomic_load(0); // expected-error {{too few arguments to function}}
  79. __c11_atomic_load(0,0,0); // expected-error {{too many arguments to function}}
  80. __c11_atomic_store(0,0,0); // expected-error {{address argument to atomic builtin must be a pointer}}
  81. __c11_atomic_store((int*)0,0,0); // expected-error {{address argument to atomic operation must be a pointer to _Atomic}}
  82. __c11_atomic_load(i, memory_order_seq_cst);
  83. __c11_atomic_load(p, memory_order_seq_cst);
  84. __c11_atomic_load(d, memory_order_seq_cst);
  85. int load_n_1 = __atomic_load_n(I, memory_order_relaxed);
  86. int *load_n_2 = __atomic_load_n(P, memory_order_relaxed);
  87. float load_n_3 = __atomic_load_n(D, memory_order_relaxed); // expected-error {{must be a pointer to integer or pointer}}
  88. __atomic_load_n(s1, memory_order_relaxed); // expected-error {{must be a pointer to integer or pointer}}
  89. __atomic_load(i, I, memory_order_relaxed); // expected-error {{must be a pointer to a trivially-copyable type}}
  90. __atomic_load(I, i, memory_order_relaxed); // expected-warning {{passing '_Atomic(int) *' to parameter of type 'int *'}}
  91. __atomic_load(I, *P, memory_order_relaxed);
  92. __atomic_load(I, *P, memory_order_relaxed, 42); // expected-error {{too many arguments}}
  93. (int)__atomic_load(I, I, memory_order_seq_cst); // expected-error {{operand of type 'void'}}
  94. __atomic_load(s1, s2, memory_order_acquire);
  95. __c11_atomic_store(i, 1, memory_order_seq_cst);
  96. __c11_atomic_store(p, 1, memory_order_seq_cst); // expected-warning {{incompatible integer to pointer conversion}}
  97. (int)__c11_atomic_store(d, 1, memory_order_seq_cst); // expected-error {{operand of type 'void'}}
  98. __atomic_store_n(I, 4, memory_order_release);
  99. __atomic_store_n(I, 4.0, memory_order_release);
  100. __atomic_store_n(I, P, memory_order_release); // expected-warning {{parameter of type 'int'}}
  101. __atomic_store_n(i, 1, memory_order_release); // expected-error {{must be a pointer to integer or pointer}}
  102. __atomic_store_n(s1, *s2, memory_order_release); // expected-error {{must be a pointer to integer or pointer}}
  103. __atomic_store(I, *P, memory_order_release);
  104. __atomic_store(s1, s2, memory_order_release);
  105. __atomic_store(i, I, memory_order_release); // expected-error {{trivially-copyable}}
  106. int exchange_1 = __c11_atomic_exchange(i, 1, memory_order_seq_cst);
  107. int exchange_2 = __c11_atomic_exchange(I, 1, memory_order_seq_cst); // expected-error {{must be a pointer to _Atomic}}
  108. int exchange_3 = __atomic_exchange_n(i, 1, memory_order_seq_cst); // expected-error {{must be a pointer to integer or pointer}}
  109. int exchange_4 = __atomic_exchange_n(I, 1, memory_order_seq_cst);
  110. __atomic_exchange(s1, s2, s2, memory_order_seq_cst);
  111. __atomic_exchange(s1, I, P, memory_order_seq_cst); // expected-warning 2{{parameter of type 'struct S *'}}
  112. (int)__atomic_exchange(s1, s2, s2, memory_order_seq_cst); // expected-error {{operand of type 'void'}}
  113. __c11_atomic_fetch_add(i, 1, memory_order_seq_cst);
  114. __c11_atomic_fetch_add(p, 1, memory_order_seq_cst);
  115. __c11_atomic_fetch_add(d, 1, memory_order_seq_cst); // expected-error {{must be a pointer to atomic integer or pointer}}
  116. __atomic_fetch_add(i, 3, memory_order_seq_cst); // expected-error {{pointer to integer or pointer}}
  117. __atomic_fetch_sub(I, 3, memory_order_seq_cst);
  118. __atomic_fetch_sub(P, 3, memory_order_seq_cst);
  119. __atomic_fetch_sub(D, 3, memory_order_seq_cst); // expected-error {{must be a pointer to integer or pointer}}
  120. __atomic_fetch_sub(s1, 3, memory_order_seq_cst); // expected-error {{must be a pointer to integer or pointer}}
  121. __c11_atomic_fetch_and(i, 1, memory_order_seq_cst);
  122. __c11_atomic_fetch_and(p, 1, memory_order_seq_cst); // expected-error {{must be a pointer to atomic integer}}
  123. __c11_atomic_fetch_and(d, 1, memory_order_seq_cst); // expected-error {{must be a pointer to atomic integer}}
  124. __atomic_fetch_and(i, 3, memory_order_seq_cst); // expected-error {{pointer to integer}}
  125. __atomic_fetch_or(I, 3, memory_order_seq_cst);
  126. __atomic_fetch_xor(P, 3, memory_order_seq_cst); // expected-error {{must be a pointer to integer}}
  127. __atomic_fetch_or(D, 3, memory_order_seq_cst); // expected-error {{must be a pointer to integer}}
  128. __atomic_fetch_and(s1, 3, memory_order_seq_cst); // expected-error {{must be a pointer to integer}}
  129. _Bool cmpexch_1 = __c11_atomic_compare_exchange_strong(i, 0, 1, memory_order_seq_cst, memory_order_seq_cst);
  130. _Bool cmpexch_2 = __c11_atomic_compare_exchange_strong(p, 0, (int*)1, memory_order_seq_cst, memory_order_seq_cst);
  131. _Bool cmpexch_3 = __c11_atomic_compare_exchange_strong(d, (int*)0, 1, memory_order_seq_cst, memory_order_seq_cst); // expected-warning {{incompatible pointer types}}
  132. _Bool cmpexch_4 = __atomic_compare_exchange_n(I, I, 5, 1, memory_order_seq_cst, memory_order_seq_cst);
  133. _Bool cmpexch_5 = __atomic_compare_exchange_n(I, P, 5, 0, memory_order_seq_cst, memory_order_seq_cst); // expected-warning {{; dereference with *}}
  134. _Bool cmpexch_6 = __atomic_compare_exchange_n(I, I, P, 0, memory_order_seq_cst, memory_order_seq_cst); // expected-warning {{passing 'int **' to parameter of type 'int'}}
  135. _Bool cmpexch_7 = __atomic_compare_exchange(I, I, 5, 1, memory_order_seq_cst, memory_order_seq_cst); // expected-warning {{passing 'int' to parameter of type 'int *'}}
  136. _Bool cmpexch_8 = __atomic_compare_exchange(I, P, I, 0, memory_order_seq_cst, memory_order_seq_cst); // expected-warning {{; dereference with *}}
  137. _Bool cmpexch_9 = __atomic_compare_exchange(I, I, I, 0, memory_order_seq_cst, memory_order_seq_cst);
  138. const volatile int flag_k = 0;
  139. volatile int flag = 0;
  140. (void)(int)__atomic_test_and_set(&flag_k, memory_order_seq_cst); // expected-warning {{passing 'const volatile int *' to parameter of type 'volatile void *'}}
  141. (void)(int)__atomic_test_and_set(&flag, memory_order_seq_cst);
  142. __atomic_clear(&flag_k, memory_order_seq_cst); // expected-warning {{passing 'const volatile int *' to parameter of type 'volatile void *'}}
  143. __atomic_clear(&flag, memory_order_seq_cst);
  144. (int)__atomic_clear(&flag, memory_order_seq_cst); // expected-error {{operand of type 'void'}}
  145. const _Atomic(int) const_atomic;
  146. __c11_atomic_init(&const_atomic, 0); // expected-error {{address argument to atomic operation must be a pointer to non-const _Atomic type ('const _Atomic(int) *' invalid)}}
  147. __c11_atomic_store(&const_atomic, 0, memory_order_release); // expected-error {{address argument to atomic operation must be a pointer to non-const _Atomic type ('const _Atomic(int) *' invalid)}}
  148. __c11_atomic_load(&const_atomic, memory_order_acquire); // expected-error {{address argument to atomic operation must be a pointer to non-const _Atomic type ('const _Atomic(int) *' invalid)}}
  149. // Ensure the <stdatomic.h> macros behave appropriately.
  150. atomic_int n = ATOMIC_VAR_INIT(123);
  151. atomic_init(&n, 456);
  152. atomic_init(&n, (void*)0); // expected-warning {{passing 'void *' to parameter of type 'int'}}
  153. const atomic_wchar_t cawt;
  154. atomic_init(&cawt, L'x'); // expected-error {{non-const}}
  155. atomic_wchar_t awt;
  156. atomic_init(&awt, L'x');
  157. int x = kill_dependency(12);
  158. atomic_thread_fence(); // expected-error {{too few arguments to function call}}
  159. atomic_thread_fence(memory_order_seq_cst);
  160. atomic_signal_fence(memory_order_seq_cst);
  161. void (*pfn)(memory_order) = &atomic_thread_fence;
  162. pfn = &atomic_signal_fence;
  163. int k = atomic_load_explicit(&n, memory_order_relaxed);
  164. atomic_store_explicit(&n, k, memory_order_relaxed);
  165. atomic_store(&n, atomic_load(&n));
  166. k = atomic_exchange(&n, 72);
  167. k = atomic_exchange_explicit(&n, k, memory_order_release);
  168. atomic_compare_exchange_strong(&n, k, k); // expected-warning {{take the address with &}}
  169. atomic_compare_exchange_weak(&n, &k, k);
  170. atomic_compare_exchange_strong_explicit(&n, &k, k, memory_order_seq_cst); // expected-error {{too few arguments}}
  171. atomic_compare_exchange_weak_explicit(&n, &k, k, memory_order_seq_cst, memory_order_acquire);
  172. atomic_fetch_add(&k, n); // expected-error {{must be a pointer to _Atomic}}
  173. k = atomic_fetch_add(&n, k);
  174. k = atomic_fetch_sub(&n, k);
  175. k = atomic_fetch_and(&n, k);
  176. k = atomic_fetch_or(&n, k);
  177. k = atomic_fetch_xor(&n, k);
  178. k = atomic_fetch_add_explicit(&n, k, memory_order_acquire);
  179. k = atomic_fetch_sub_explicit(&n, k, memory_order_release);
  180. k = atomic_fetch_and_explicit(&n, k, memory_order_acq_rel);
  181. k = atomic_fetch_or_explicit(&n, k, memory_order_consume);
  182. k = atomic_fetch_xor_explicit(&n, k, memory_order_relaxed);
  183. // C11 7.17.1/4: atomic_flag is a structure type.
  184. struct atomic_flag must_be_struct = ATOMIC_FLAG_INIT;
  185. // C11 7.17.8/5 implies that it is also a typedef type.
  186. atomic_flag guard = ATOMIC_FLAG_INIT;
  187. _Bool old_val = atomic_flag_test_and_set(&guard);
  188. if (old_val) atomic_flag_clear(&guard);
  189. old_val = (atomic_flag_test_and_set)(&guard);
  190. if (old_val) (atomic_flag_clear)(&guard);
  191. const atomic_flag const_guard;
  192. atomic_flag_test_and_set(&const_guard); // expected-error {{address argument to atomic operation must be a pointer to non-const _Atomic type ('const atomic_bool *' (aka 'const _Atomic(_Bool) *') invalid)}}
  193. atomic_flag_clear(&const_guard); // expected-error {{address argument to atomic operation must be a pointer to non-const _Atomic type ('const atomic_bool *' (aka 'const _Atomic(_Bool) *') invalid)}}
  194. }
  195. _Atomic(int*) PR12527_a;
  196. void PR12527() { int *b = PR12527_a; }
  197. void PR16931(int* x) { // expected-note {{passing argument to parameter 'x' here}}
  198. typedef struct { _Atomic(_Bool) flag; } flag;
  199. flag flagvar = { 0 };
  200. PR16931(&flagvar); // expected-warning {{incompatible pointer types}}
  201. }
  202. void memory_checks(_Atomic(int) *Ap, int *p, int val) {
  203. (void)__c11_atomic_load(Ap, memory_order_relaxed);
  204. (void)__c11_atomic_load(Ap, memory_order_acquire);
  205. (void)__c11_atomic_load(Ap, memory_order_consume);
  206. (void)__c11_atomic_load(Ap, memory_order_release); // expected-warning {{memory order argument to atomic operation is invalid}}
  207. (void)__c11_atomic_load(Ap, memory_order_acq_rel); // expected-warning {{memory order argument to atomic operation is invalid}}
  208. (void)__c11_atomic_load(Ap, memory_order_seq_cst);
  209. (void)__c11_atomic_load(Ap, val);
  210. (void)__c11_atomic_load(Ap, -1); // expected-warning {{memory order argument to atomic operation is invalid}}
  211. (void)__c11_atomic_load(Ap, 42); // expected-warning {{memory order argument to atomic operation is invalid}}
  212. (void)__c11_atomic_store(Ap, val, memory_order_relaxed);
  213. (void)__c11_atomic_store(Ap, val, memory_order_acquire); // expected-warning {{memory order argument to atomic operation is invalid}}
  214. (void)__c11_atomic_store(Ap, val, memory_order_consume); // expected-warning {{memory order argument to atomic operation is invalid}}
  215. (void)__c11_atomic_store(Ap, val, memory_order_release);
  216. (void)__c11_atomic_store(Ap, val, memory_order_acq_rel); // expected-warning {{memory order argument to atomic operation is invalid}}
  217. (void)__c11_atomic_store(Ap, val, memory_order_seq_cst);
  218. (void)__c11_atomic_fetch_add(Ap, 1, memory_order_relaxed);
  219. (void)__c11_atomic_fetch_add(Ap, 1, memory_order_acquire);
  220. (void)__c11_atomic_fetch_add(Ap, 1, memory_order_consume);
  221. (void)__c11_atomic_fetch_add(Ap, 1, memory_order_release);
  222. (void)__c11_atomic_fetch_add(Ap, 1, memory_order_acq_rel);
  223. (void)__c11_atomic_fetch_add(Ap, 1, memory_order_seq_cst);
  224. (void)__c11_atomic_fetch_add(
  225. (struct Incomplete * _Atomic *)0, // expected-error {{incomplete type 'struct Incomplete'}}
  226. 1, memory_order_seq_cst);
  227. (void)__c11_atomic_init(Ap, val);
  228. (void)__c11_atomic_init(Ap, val);
  229. (void)__c11_atomic_init(Ap, val);
  230. (void)__c11_atomic_init(Ap, val);
  231. (void)__c11_atomic_init(Ap, val);
  232. (void)__c11_atomic_init(Ap, val);
  233. (void)__c11_atomic_fetch_sub(Ap, val, memory_order_relaxed);
  234. (void)__c11_atomic_fetch_sub(Ap, val, memory_order_acquire);
  235. (void)__c11_atomic_fetch_sub(Ap, val, memory_order_consume);
  236. (void)__c11_atomic_fetch_sub(Ap, val, memory_order_release);
  237. (void)__c11_atomic_fetch_sub(Ap, val, memory_order_acq_rel);
  238. (void)__c11_atomic_fetch_sub(Ap, val, memory_order_seq_cst);
  239. (void)__c11_atomic_fetch_and(Ap, val, memory_order_relaxed);
  240. (void)__c11_atomic_fetch_and(Ap, val, memory_order_acquire);
  241. (void)__c11_atomic_fetch_and(Ap, val, memory_order_consume);
  242. (void)__c11_atomic_fetch_and(Ap, val, memory_order_release);
  243. (void)__c11_atomic_fetch_and(Ap, val, memory_order_acq_rel);
  244. (void)__c11_atomic_fetch_and(Ap, val, memory_order_seq_cst);
  245. (void)__c11_atomic_fetch_or(Ap, val, memory_order_relaxed);
  246. (void)__c11_atomic_fetch_or(Ap, val, memory_order_acquire);
  247. (void)__c11_atomic_fetch_or(Ap, val, memory_order_consume);
  248. (void)__c11_atomic_fetch_or(Ap, val, memory_order_release);
  249. (void)__c11_atomic_fetch_or(Ap, val, memory_order_acq_rel);
  250. (void)__c11_atomic_fetch_or(Ap, val, memory_order_seq_cst);
  251. (void)__c11_atomic_fetch_xor(Ap, val, memory_order_relaxed);
  252. (void)__c11_atomic_fetch_xor(Ap, val, memory_order_acquire);
  253. (void)__c11_atomic_fetch_xor(Ap, val, memory_order_consume);
  254. (void)__c11_atomic_fetch_xor(Ap, val, memory_order_release);
  255. (void)__c11_atomic_fetch_xor(Ap, val, memory_order_acq_rel);
  256. (void)__c11_atomic_fetch_xor(Ap, val, memory_order_seq_cst);
  257. (void)__c11_atomic_exchange(Ap, val, memory_order_relaxed);
  258. (void)__c11_atomic_exchange(Ap, val, memory_order_acquire);
  259. (void)__c11_atomic_exchange(Ap, val, memory_order_consume);
  260. (void)__c11_atomic_exchange(Ap, val, memory_order_release);
  261. (void)__c11_atomic_exchange(Ap, val, memory_order_acq_rel);
  262. (void)__c11_atomic_exchange(Ap, val, memory_order_seq_cst);
  263. (void)__c11_atomic_compare_exchange_strong(Ap, p, val, memory_order_relaxed, memory_order_relaxed);
  264. (void)__c11_atomic_compare_exchange_strong(Ap, p, val, memory_order_acquire, memory_order_relaxed);
  265. (void)__c11_atomic_compare_exchange_strong(Ap, p, val, memory_order_consume, memory_order_relaxed);
  266. (void)__c11_atomic_compare_exchange_strong(Ap, p, val, memory_order_release, memory_order_relaxed);
  267. (void)__c11_atomic_compare_exchange_strong(Ap, p, val, memory_order_acq_rel, memory_order_relaxed);
  268. (void)__c11_atomic_compare_exchange_strong(Ap, p, val, memory_order_seq_cst, memory_order_relaxed);
  269. (void)__c11_atomic_compare_exchange_weak(Ap, p, val, memory_order_relaxed, memory_order_relaxed);
  270. (void)__c11_atomic_compare_exchange_weak(Ap, p, val, memory_order_acquire, memory_order_relaxed);
  271. (void)__c11_atomic_compare_exchange_weak(Ap, p, val, memory_order_consume, memory_order_relaxed);
  272. (void)__c11_atomic_compare_exchange_weak(Ap, p, val, memory_order_release, memory_order_relaxed);
  273. (void)__c11_atomic_compare_exchange_weak(Ap, p, val, memory_order_acq_rel, memory_order_relaxed);
  274. (void)__c11_atomic_compare_exchange_weak(Ap, p, val, memory_order_seq_cst, memory_order_relaxed);
  275. (void)__atomic_load_n(p, memory_order_relaxed);
  276. (void)__atomic_load_n(p, memory_order_acquire);
  277. (void)__atomic_load_n(p, memory_order_consume);
  278. (void)__atomic_load_n(p, memory_order_release); // expected-warning {{memory order argument to atomic operation is invalid}}
  279. (void)__atomic_load_n(p, memory_order_acq_rel); // expected-warning {{memory order argument to atomic operation is invalid}}
  280. (void)__atomic_load_n(p, memory_order_seq_cst);
  281. (void)__atomic_load(p, p, memory_order_relaxed);
  282. (void)__atomic_load(p, p, memory_order_acquire);
  283. (void)__atomic_load(p, p, memory_order_consume);
  284. (void)__atomic_load(p, p, memory_order_release); // expected-warning {{memory order argument to atomic operation is invalid}}
  285. (void)__atomic_load(p, p, memory_order_acq_rel); // expected-warning {{memory order argument to atomic operation is invalid}}
  286. (void)__atomic_load(p, p, memory_order_seq_cst);
  287. (void)__atomic_store(p, p, memory_order_relaxed);
  288. (void)__atomic_store(p, p, memory_order_acquire); // expected-warning {{memory order argument to atomic operation is invalid}}
  289. (void)__atomic_store(p, p, memory_order_consume); // expected-warning {{memory order argument to atomic operation is invalid}}
  290. (void)__atomic_store(p, p, memory_order_release);
  291. (void)__atomic_store(p, p, memory_order_acq_rel); // expected-warning {{memory order argument to atomic operation is invalid}}
  292. (void)__atomic_store(p, p, memory_order_seq_cst);
  293. (void)__atomic_store_n(p, val, memory_order_relaxed);
  294. (void)__atomic_store_n(p, val, memory_order_acquire); // expected-warning {{memory order argument to atomic operation is invalid}}
  295. (void)__atomic_store_n(p, val, memory_order_consume); // expected-warning {{memory order argument to atomic operation is invalid}}
  296. (void)__atomic_store_n(p, val, memory_order_release);
  297. (void)__atomic_store_n(p, val, memory_order_acq_rel); // expected-warning {{memory order argument to atomic operation is invalid}}
  298. (void)__atomic_store_n(p, val, memory_order_seq_cst);
  299. (void)__atomic_fetch_add(p, val, memory_order_relaxed);
  300. (void)__atomic_fetch_add(p, val, memory_order_acquire);
  301. (void)__atomic_fetch_add(p, val, memory_order_consume);
  302. (void)__atomic_fetch_add(p, val, memory_order_release);
  303. (void)__atomic_fetch_add(p, val, memory_order_acq_rel);
  304. (void)__atomic_fetch_add(p, val, memory_order_seq_cst);
  305. (void)__atomic_fetch_sub(p, val, memory_order_relaxed);
  306. (void)__atomic_fetch_sub(p, val, memory_order_acquire);
  307. (void)__atomic_fetch_sub(p, val, memory_order_consume);
  308. (void)__atomic_fetch_sub(p, val, memory_order_release);
  309. (void)__atomic_fetch_sub(p, val, memory_order_acq_rel);
  310. (void)__atomic_fetch_sub(p, val, memory_order_seq_cst);
  311. (void)__atomic_add_fetch(p, val, memory_order_relaxed);
  312. (void)__atomic_add_fetch(p, val, memory_order_acquire);
  313. (void)__atomic_add_fetch(p, val, memory_order_consume);
  314. (void)__atomic_add_fetch(p, val, memory_order_release);
  315. (void)__atomic_add_fetch(p, val, memory_order_acq_rel);
  316. (void)__atomic_add_fetch(p, val, memory_order_seq_cst);
  317. (void)__atomic_sub_fetch(p, val, memory_order_relaxed);
  318. (void)__atomic_sub_fetch(p, val, memory_order_acquire);
  319. (void)__atomic_sub_fetch(p, val, memory_order_consume);
  320. (void)__atomic_sub_fetch(p, val, memory_order_release);
  321. (void)__atomic_sub_fetch(p, val, memory_order_acq_rel);
  322. (void)__atomic_sub_fetch(p, val, memory_order_seq_cst);
  323. (void)__atomic_fetch_and(p, val, memory_order_relaxed);
  324. (void)__atomic_fetch_and(p, val, memory_order_acquire);
  325. (void)__atomic_fetch_and(p, val, memory_order_consume);
  326. (void)__atomic_fetch_and(p, val, memory_order_release);
  327. (void)__atomic_fetch_and(p, val, memory_order_acq_rel);
  328. (void)__atomic_fetch_and(p, val, memory_order_seq_cst);
  329. (void)__atomic_fetch_or(p, val, memory_order_relaxed);
  330. (void)__atomic_fetch_or(p, val, memory_order_acquire);
  331. (void)__atomic_fetch_or(p, val, memory_order_consume);
  332. (void)__atomic_fetch_or(p, val, memory_order_release);
  333. (void)__atomic_fetch_or(p, val, memory_order_acq_rel);
  334. (void)__atomic_fetch_or(p, val, memory_order_seq_cst);
  335. (void)__atomic_fetch_xor(p, val, memory_order_relaxed);
  336. (void)__atomic_fetch_xor(p, val, memory_order_acquire);
  337. (void)__atomic_fetch_xor(p, val, memory_order_consume);
  338. (void)__atomic_fetch_xor(p, val, memory_order_release);
  339. (void)__atomic_fetch_xor(p, val, memory_order_acq_rel);
  340. (void)__atomic_fetch_xor(p, val, memory_order_seq_cst);
  341. (void)__atomic_fetch_nand(p, val, memory_order_relaxed);
  342. (void)__atomic_fetch_nand(p, val, memory_order_acquire);
  343. (void)__atomic_fetch_nand(p, val, memory_order_consume);
  344. (void)__atomic_fetch_nand(p, val, memory_order_release);
  345. (void)__atomic_fetch_nand(p, val, memory_order_acq_rel);
  346. (void)__atomic_fetch_nand(p, val, memory_order_seq_cst);
  347. (void)__atomic_and_fetch(p, val, memory_order_relaxed);
  348. (void)__atomic_and_fetch(p, val, memory_order_acquire);
  349. (void)__atomic_and_fetch(p, val, memory_order_consume);
  350. (void)__atomic_and_fetch(p, val, memory_order_release);
  351. (void)__atomic_and_fetch(p, val, memory_order_acq_rel);
  352. (void)__atomic_and_fetch(p, val, memory_order_seq_cst);
  353. (void)__atomic_or_fetch(p, val, memory_order_relaxed);
  354. (void)__atomic_or_fetch(p, val, memory_order_acquire);
  355. (void)__atomic_or_fetch(p, val, memory_order_consume);
  356. (void)__atomic_or_fetch(p, val, memory_order_release);
  357. (void)__atomic_or_fetch(p, val, memory_order_acq_rel);
  358. (void)__atomic_or_fetch(p, val, memory_order_seq_cst);
  359. (void)__atomic_xor_fetch(p, val, memory_order_relaxed);
  360. (void)__atomic_xor_fetch(p, val, memory_order_acquire);
  361. (void)__atomic_xor_fetch(p, val, memory_order_consume);
  362. (void)__atomic_xor_fetch(p, val, memory_order_release);
  363. (void)__atomic_xor_fetch(p, val, memory_order_acq_rel);
  364. (void)__atomic_xor_fetch(p, val, memory_order_seq_cst);
  365. (void)__atomic_nand_fetch(p, val, memory_order_relaxed);
  366. (void)__atomic_nand_fetch(p, val, memory_order_acquire);
  367. (void)__atomic_nand_fetch(p, val, memory_order_consume);
  368. (void)__atomic_nand_fetch(p, val, memory_order_release);
  369. (void)__atomic_nand_fetch(p, val, memory_order_acq_rel);
  370. (void)__atomic_nand_fetch(p, val, memory_order_seq_cst);
  371. (void)__atomic_exchange_n(p, val, memory_order_relaxed);
  372. (void)__atomic_exchange_n(p, val, memory_order_acquire);
  373. (void)__atomic_exchange_n(p, val, memory_order_consume);
  374. (void)__atomic_exchange_n(p, val, memory_order_release);
  375. (void)__atomic_exchange_n(p, val, memory_order_acq_rel);
  376. (void)__atomic_exchange_n(p, val, memory_order_seq_cst);
  377. (void)__atomic_exchange(p, p, p, memory_order_relaxed);
  378. (void)__atomic_exchange(p, p, p, memory_order_acquire);
  379. (void)__atomic_exchange(p, p, p, memory_order_consume);
  380. (void)__atomic_exchange(p, p, p, memory_order_release);
  381. (void)__atomic_exchange(p, p, p, memory_order_acq_rel);
  382. (void)__atomic_exchange(p, p, p, memory_order_seq_cst);
  383. (void)__atomic_compare_exchange(p, p, p, 0, memory_order_relaxed, memory_order_relaxed);
  384. (void)__atomic_compare_exchange(p, p, p, 0, memory_order_acquire, memory_order_relaxed);
  385. (void)__atomic_compare_exchange(p, p, p, 0, memory_order_consume, memory_order_relaxed);
  386. (void)__atomic_compare_exchange(p, p, p, 0, memory_order_release, memory_order_relaxed);
  387. (void)__atomic_compare_exchange(p, p, p, 0, memory_order_acq_rel, memory_order_relaxed);
  388. (void)__atomic_compare_exchange(p, p, p, 0, memory_order_seq_cst, memory_order_relaxed);
  389. (void)__atomic_compare_exchange_n(p, p, val, 0, memory_order_relaxed, memory_order_relaxed);
  390. (void)__atomic_compare_exchange_n(p, p, val, 0, memory_order_acquire, memory_order_relaxed);
  391. (void)__atomic_compare_exchange_n(p, p, val, 0, memory_order_consume, memory_order_relaxed);
  392. (void)__atomic_compare_exchange_n(p, p, val, 0, memory_order_release, memory_order_relaxed);
  393. (void)__atomic_compare_exchange_n(p, p, val, 0, memory_order_acq_rel, memory_order_relaxed);
  394. (void)__atomic_compare_exchange_n(p, p, val, 0, memory_order_seq_cst, memory_order_relaxed);
  395. }