Viewing file: atomic-exchange-5.c (1.54 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* Test __atomic routines for existence and proper execution on 16 byte values with each valid memory model. */ /* { dg-do run } */ /* { dg-require-effective-target sync_int_128_runtime } */ /* { dg-options "-mcx16" { target { i?86-*-* x86_64-*-* } } } */
/* Test the execution of the __atomic_X builtin for a 16 byte value. */
extern void abort(void);
__int128_t v, count, ret;
int main () { v = 0; count = 0;
if (__atomic_exchange_n (&v, count + 1, __ATOMIC_RELAXED) != count) abort (); count++;
if (__atomic_exchange_n (&v, count + 1, __ATOMIC_ACQUIRE) != count) abort (); count++;
if (__atomic_exchange_n (&v, count + 1, __ATOMIC_RELEASE) != count) abort (); count++;
if (__atomic_exchange_n (&v, count + 1, __ATOMIC_ACQ_REL) != count) abort (); count++;
if (__atomic_exchange_n (&v, count + 1, __ATOMIC_SEQ_CST) != count) abort (); count++;
/* Now test the generic version. */
count++;
__atomic_exchange (&v, &count, &ret, __ATOMIC_RELAXED); if (ret != count - 1 || v != count) abort (); count++;
__atomic_exchange (&v, &count, &ret, __ATOMIC_ACQUIRE); if (ret != count - 1 || v != count) abort (); count++;
__atomic_exchange (&v, &count, &ret, __ATOMIC_RELEASE); if (ret != count - 1 || v != count) abort (); count++;
__atomic_exchange (&v, &count, &ret, __ATOMIC_ACQ_REL); if (ret != count - 1 || v != count) abort (); count++;
__atomic_exchange (&v, &count, &ret, __ATOMIC_SEQ_CST); if (ret != count - 1 || v != count) abort (); count++;
return 0; }
|