]> granicus.if.org Git - libatomic_ops/commitdiff
Remove auto-generated tests/list_atomic.c and test_atomic_include.h
authorIvan Maidanski <ivmai@mail.ru>
Tue, 9 Aug 2011 15:26:42 +0000 (19:26 +0400)
committerIvan Maidanski <ivmai@mail.ru>
Tue, 9 Aug 2011 15:26:42 +0000 (19:26 +0400)
from the repo.

The files are still present in the distributive tar-ball as it is hard
to generate them on Windows (without Cygwin/MinGW).  Note that these
files are used only for testing (unlike generalize-small.h).
The later remains even in the repo as it makes possible to use
libatomic_ops without running any script.

* .gitignore: add tests/list_atomic.c and test_atomic_include.h.
* src/Makefile.msft: Add comment about test_atomic_include.h; wrap
long lines.
* src/Makefile.msft (all): Build "libatomic_ops_gpl.lib" instead of
"check".
* tests/list_atomic.c, tests/test_atomic_include.h: Remove.

.gitignore
TODO
src/Makefile.msft
tests/list_atomic.c [deleted file]
tests/test_atomic_include.h [deleted file]

index bec74a5c325bbb18acb192e21ddeb51c07b76007..4ea6525def5251d67a8024a47bc339903f77ea32 100644 (file)
@@ -42,3 +42,7 @@ Makefile
 /mkinstalldirs
 /src/config.h.in
 Makefile.in
+
+# These files are generated by make check:
+/tests/list_atomic.c
+/tests/test_atomic_include.h
diff --git a/TODO b/TODO
index e5e3b4220a1ede185c373648e3b7ae870bd49c57..0917065abb704b9e0643bde516fc36d46e7612e3 100644 (file)
--- a/TODO
+++ b/TODO
@@ -8,6 +8,3 @@ to create a work-around if possible.
 Add equivalent of __sync_val_compare_and_swap. Add tests.
 
 Fix make distcheck: fails with "config.h: No such file or directory"
-
-Remove list_atomic.c and test_atomic_include.h (as auto-generated).
-Make sure they appear in the dist tarball.
index ae96702f00040126cabe712c719ea57a513ba6d4..2aa40c27073c7fdb7be95e5b5a74b8b56596ff29 100644 (file)
@@ -1,9 +1,12 @@
 #
 # Copyright (c) 2003-2005 Hewlett-Packard Development Company, L.P.
-# 
+#
 # The really trivial win32/VC++ Makefile.  Note that atomic_ops.c isn't useful.
 # And we rely on a pre-built test_atomic_include.h and generalize-small.h,
-# since we can't rely on sed.
+# since we can't rely on sed.  But we don't keep list_atomic.c and
+# test_atomic_include.h in the development repository any longer, so if you
+# want to do "make check" for the sources obtained from the repository then
+# do "autoreconf -vif; ./configure; make check" in Cygwin first.
 # Win32 clients only need to include the header files.
 # To install, copy atomic_ops.h and the atomic_ops/... tree to your favorite
 # include directory.
@@ -14,7 +17,7 @@
 
 LIB_OBJS=atomic_ops_stack.obj atomic_ops_malloc.obj
 
-all: check
+all: libatomic_ops_gpl.lib
 
 atomic_ops_stack.obj:
        cl -O2 -c -DAO_ASSUME_WINDOWS98 atomic_ops_stack.c
@@ -29,8 +32,9 @@ test_atomic_w95: ..\tests\test_atomic.c ..\tests\test_atomic_include.h
        cl -O2 -I. ..\tests\test_atomic.c -o test_atomic_w95
 
 test_malloc: ..\tests\test_malloc.c ..\tests\test_atomic_include.h \
-            libatomic_ops_gpl.lib 
-       cl -O2 -DAO_ASSUME_WINDOWS98 -I. ..\tests\test_malloc.c -o test_malloc libatomic_ops_gpl.lib
+            libatomic_ops_gpl.lib
+       cl -O2 -DAO_ASSUME_WINDOWS98 -I. ..\tests\test_malloc.c \
+            -o test_malloc libatomic_ops_gpl.lib
 
 libatomic_ops_gpl.lib: $(LIB_OBJS)
        lib /MACHINE:i386 /out:libatomic_ops_gpl.lib $(LIB_OBJS)
@@ -41,5 +45,3 @@ check:  test_atomic test_atomic_w95 test_malloc
        echo The following will print some \"Missing ...\" messages.
        test_atomic
        test_malloc
-
-
diff --git a/tests/list_atomic.c b/tests/list_atomic.c
deleted file mode 100644 (file)
index 9b2cb3a..0000000
+++ /dev/null
@@ -1,545 +0,0 @@
-#include "atomic_ops.h" 
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* This generates a compilable program.  But it is really meant to be   */
-/* be used only with cc -E, to inspect the expensions generated by      */
-/* primitives.                                                          */
-
-/* The result will not link or run.                                     */
-
-void list_atomic(void)
-{
-  AO_T val, newval = 0, oldval = 0;
-  AO_TS_T ts;
-  long incr = 0;
-
-# if defined(AO_HAVE_nop)
-    "AO_nop(): ";
-    AO_nop();
-# else
-    "No AO_nop";
-# endif
-# if defined(AO_HAVE_load)
-    "AO_load(&val):";
-    AO_load(&val);
-# else
-    "No AO_load";
-# endif
-# if defined(AO_HAVE_store)
-    "AO_store(&val, newval):";
-    AO_store(&val, newval);
-# else
-    "No AO_store";
-# endif
-# if defined(AO_HAVE_test_and_set)
-    "AO_test_and_set(&ts):";
-    AO_test_and_set(&ts);
-# else
-    "No AO_test_and_set";
-# endif
-# if defined(AO_HAVE_fetch_and_add1)
-    "AO_fetch_and_add1(&val):";
-    AO_fetch_and_add1(&val);
-# else
-    "No AO_fetch_and_add1";
-# endif
-# if defined(AO_HAVE_fetch_and_sub1)
-    "AO_fetch_and_sub1(&val):";
-    AO_fetch_and_sub1(&val);
-# else
-    "No AO_fetch_and_sub1";
-# endif
-# if defined(AO_HAVE_fetch_and_add)
-    "AO_fetch_and_add(&val, incr):";
-    AO_fetch_and_add(&val, incr);
-# else
-    "No AO_fetch_and_add";
-# endif
-# if defined(AO_HAVE_compare_and_swap)
-    "AO_compare_and_swap(&val, oldval, newval):";
-    AO_compare_and_swap(&val, oldval, newval);
-# else
-    "No AO_compare_and_swap";
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* This generates a compilable program.  But it is really meant to be   */
-/* be used only with cc -E, to inspect the expensions generated by      */
-/* primitives.                                                          */
-
-/* The result will not link or run.                                     */
-
-void list_atomic_release(void)
-{
-  AO_T val, newval = 0, oldval = 0;
-  AO_TS_T ts;
-  long incr = 0;
-
-# if defined(AO_HAVE_nop_release)
-    "AO_nop_release(): ";
-    AO_nop_release();
-# else
-    "No AO_nop_release";
-# endif
-# if defined(AO_HAVE_load_release)
-    "AO_load_release(&val):";
-    AO_load_release(&val);
-# else
-    "No AO_load_release";
-# endif
-# if defined(AO_HAVE_store_release)
-    "AO_store_release(&val, newval):";
-    AO_store_release(&val, newval);
-# else
-    "No AO_store_release";
-# endif
-# if defined(AO_HAVE_test_and_set_release)
-    "AO_test_and_set_release(&ts):";
-    AO_test_and_set_release(&ts);
-# else
-    "No AO_test_and_set_release";
-# endif
-# if defined(AO_HAVE_fetch_and_add1_release)
-    "AO_fetch_and_add1_release(&val):";
-    AO_fetch_and_add1_release(&val);
-# else
-    "No AO_fetch_and_add1_release";
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_release)
-    "AO_fetch_and_sub1_release(&val):";
-    AO_fetch_and_sub1_release(&val);
-# else
-    "No AO_fetch_and_sub1_release";
-# endif
-# if defined(AO_HAVE_fetch_and_add_release)
-    "AO_fetch_and_add_release(&val, incr):";
-    AO_fetch_and_add_release(&val, incr);
-# else
-    "No AO_fetch_and_add_release";
-# endif
-# if defined(AO_HAVE_compare_and_swap_release)
-    "AO_compare_and_swap_release(&val, oldval, newval):";
-    AO_compare_and_swap_release(&val, oldval, newval);
-# else
-    "No AO_compare_and_swap_release";
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* This generates a compilable program.  But it is really meant to be   */
-/* be used only with cc -E, to inspect the expensions generated by      */
-/* primitives.                                                          */
-
-/* The result will not link or run.                                     */
-
-void list_atomic_acquire(void)
-{
-  AO_T val, newval = 0, oldval = 0;
-  AO_TS_T ts;
-  long incr = 0;
-
-# if defined(AO_HAVE_nop_acquire)
-    "AO_nop_acquire(): ";
-    AO_nop_acquire();
-# else
-    "No AO_nop_acquire";
-# endif
-# if defined(AO_HAVE_load_acquire)
-    "AO_load_acquire(&val):";
-    AO_load_acquire(&val);
-# else
-    "No AO_load_acquire";
-# endif
-# if defined(AO_HAVE_store_acquire)
-    "AO_store_acquire(&val, newval):";
-    AO_store_acquire(&val, newval);
-# else
-    "No AO_store_acquire";
-# endif
-# if defined(AO_HAVE_test_and_set_acquire)
-    "AO_test_and_set_acquire(&ts):";
-    AO_test_and_set_acquire(&ts);
-# else
-    "No AO_test_and_set_acquire";
-# endif
-# if defined(AO_HAVE_fetch_and_add1_acquire)
-    "AO_fetch_and_add1_acquire(&val):";
-    AO_fetch_and_add1_acquire(&val);
-# else
-    "No AO_fetch_and_add1_acquire";
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_acquire)
-    "AO_fetch_and_sub1_acquire(&val):";
-    AO_fetch_and_sub1_acquire(&val);
-# else
-    "No AO_fetch_and_sub1_acquire";
-# endif
-# if defined(AO_HAVE_fetch_and_add_acquire)
-    "AO_fetch_and_add_acquire(&val, incr):";
-    AO_fetch_and_add_acquire(&val, incr);
-# else
-    "No AO_fetch_and_add_acquire";
-# endif
-# if defined(AO_HAVE_compare_and_swap_acquire)
-    "AO_compare_and_swap_acquire(&val, oldval, newval):";
-    AO_compare_and_swap_acquire(&val, oldval, newval);
-# else
-    "No AO_compare_and_swap_acquire";
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* This generates a compilable program.  But it is really meant to be   */
-/* be used only with cc -E, to inspect the expensions generated by      */
-/* primitives.                                                          */
-
-/* The result will not link or run.                                     */
-
-void list_atomic_read(void)
-{
-  AO_T val, newval = 0, oldval = 0;
-  AO_TS_T ts;
-  long incr = 0;
-
-# if defined(AO_HAVE_nop_read)
-    "AO_nop_read(): ";
-    AO_nop_read();
-# else
-    "No AO_nop_read";
-# endif
-# if defined(AO_HAVE_load_read)
-    "AO_load_read(&val):";
-    AO_load_read(&val);
-# else
-    "No AO_load_read";
-# endif
-# if defined(AO_HAVE_store_read)
-    "AO_store_read(&val, newval):";
-    AO_store_read(&val, newval);
-# else
-    "No AO_store_read";
-# endif
-# if defined(AO_HAVE_test_and_set_read)
-    "AO_test_and_set_read(&ts):";
-    AO_test_and_set_read(&ts);
-# else
-    "No AO_test_and_set_read";
-# endif
-# if defined(AO_HAVE_fetch_and_add1_read)
-    "AO_fetch_and_add1_read(&val):";
-    AO_fetch_and_add1_read(&val);
-# else
-    "No AO_fetch_and_add1_read";
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_read)
-    "AO_fetch_and_sub1_read(&val):";
-    AO_fetch_and_sub1_read(&val);
-# else
-    "No AO_fetch_and_sub1_read";
-# endif
-# if defined(AO_HAVE_fetch_and_add_read)
-    "AO_fetch_and_add_read(&val, incr):";
-    AO_fetch_and_add_read(&val, incr);
-# else
-    "No AO_fetch_and_add_read";
-# endif
-# if defined(AO_HAVE_compare_and_swap_read)
-    "AO_compare_and_swap_read(&val, oldval, newval):";
-    AO_compare_and_swap_read(&val, oldval, newval);
-# else
-    "No AO_compare_and_swap_read";
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* This generates a compilable program.  But it is really meant to be   */
-/* be used only with cc -E, to inspect the expensions generated by      */
-/* primitives.                                                          */
-
-/* The result will not link or run.                                     */
-
-void list_atomic_write(void)
-{
-  AO_T val, newval = 0, oldval = 0;
-  AO_TS_T ts;
-  long incr = 0;
-
-# if defined(AO_HAVE_nop_write)
-    "AO_nop_write(): ";
-    AO_nop_write();
-# else
-    "No AO_nop_write";
-# endif
-# if defined(AO_HAVE_load_write)
-    "AO_load_write(&val):";
-    AO_load_write(&val);
-# else
-    "No AO_load_write";
-# endif
-# if defined(AO_HAVE_store_write)
-    "AO_store_write(&val, newval):";
-    AO_store_write(&val, newval);
-# else
-    "No AO_store_write";
-# endif
-# if defined(AO_HAVE_test_and_set_write)
-    "AO_test_and_set_write(&ts):";
-    AO_test_and_set_write(&ts);
-# else
-    "No AO_test_and_set_write";
-# endif
-# if defined(AO_HAVE_fetch_and_add1_write)
-    "AO_fetch_and_add1_write(&val):";
-    AO_fetch_and_add1_write(&val);
-# else
-    "No AO_fetch_and_add1_write";
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_write)
-    "AO_fetch_and_sub1_write(&val):";
-    AO_fetch_and_sub1_write(&val);
-# else
-    "No AO_fetch_and_sub1_write";
-# endif
-# if defined(AO_HAVE_fetch_and_add_write)
-    "AO_fetch_and_add_write(&val, incr):";
-    AO_fetch_and_add_write(&val, incr);
-# else
-    "No AO_fetch_and_add_write";
-# endif
-# if defined(AO_HAVE_compare_and_swap_write)
-    "AO_compare_and_swap_write(&val, oldval, newval):";
-    AO_compare_and_swap_write(&val, oldval, newval);
-# else
-    "No AO_compare_and_swap_write";
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* This generates a compilable program.  But it is really meant to be   */
-/* be used only with cc -E, to inspect the expensions generated by      */
-/* primitives.                                                          */
-
-/* The result will not link or run.                                     */
-
-void list_atomic_full(void)
-{
-  AO_T val, newval = 0, oldval = 0;
-  AO_TS_T ts;
-  long incr = 0;
-
-# if defined(AO_HAVE_nop_full)
-    "AO_nop_full(): ";
-    AO_nop_full();
-# else
-    "No AO_nop_full";
-# endif
-# if defined(AO_HAVE_load_full)
-    "AO_load_full(&val):";
-    AO_load_full(&val);
-# else
-    "No AO_load_full";
-# endif
-# if defined(AO_HAVE_store_full)
-    "AO_store_full(&val, newval):";
-    AO_store_full(&val, newval);
-# else
-    "No AO_store_full";
-# endif
-# if defined(AO_HAVE_test_and_set_full)
-    "AO_test_and_set_full(&ts):";
-    AO_test_and_set_full(&ts);
-# else
-    "No AO_test_and_set_full";
-# endif
-# if defined(AO_HAVE_fetch_and_add1_full)
-    "AO_fetch_and_add1_full(&val):";
-    AO_fetch_and_add1_full(&val);
-# else
-    "No AO_fetch_and_add1_full";
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_full)
-    "AO_fetch_and_sub1_full(&val):";
-    AO_fetch_and_sub1_full(&val);
-# else
-    "No AO_fetch_and_sub1_full";
-# endif
-# if defined(AO_HAVE_fetch_and_add_full)
-    "AO_fetch_and_add_full(&val, incr):";
-    AO_fetch_and_add_full(&val, incr);
-# else
-    "No AO_fetch_and_add_full";
-# endif
-# if defined(AO_HAVE_compare_and_swap_full)
-    "AO_compare_and_swap_full(&val, oldval, newval):";
-    AO_compare_and_swap_full(&val, oldval, newval);
-# else
-    "No AO_compare_and_swap_full";
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* This generates a compilable program.  But it is really meant to be   */
-/* be used only with cc -E, to inspect the expensions generated by      */
-/* primitives.                                                          */
-
-/* The result will not link or run.                                     */
-
-void list_atomic_release_write(void)
-{
-  AO_T val, newval = 0, oldval = 0;
-  AO_TS_T ts;
-  long incr = 0;
-
-# if defined(AO_HAVE_nop_release_write)
-    "AO_nop_release_write(): ";
-    AO_nop_release_write();
-# else
-    "No AO_nop_release_write";
-# endif
-# if defined(AO_HAVE_load_release_write)
-    "AO_load_release_write(&val):";
-    AO_load_release_write(&val);
-# else
-    "No AO_load_release_write";
-# endif
-# if defined(AO_HAVE_store_release_write)
-    "AO_store_release_write(&val, newval):";
-    AO_store_release_write(&val, newval);
-# else
-    "No AO_store_release_write";
-# endif
-# if defined(AO_HAVE_test_and_set_release_write)
-    "AO_test_and_set_release_write(&ts):";
-    AO_test_and_set_release_write(&ts);
-# else
-    "No AO_test_and_set_release_write";
-# endif
-# if defined(AO_HAVE_fetch_and_add1_release_write)
-    "AO_fetch_and_add1_release_write(&val):";
-    AO_fetch_and_add1_release_write(&val);
-# else
-    "No AO_fetch_and_add1_release_write";
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_release_write)
-    "AO_fetch_and_sub1_release_write(&val):";
-    AO_fetch_and_sub1_release_write(&val);
-# else
-    "No AO_fetch_and_sub1_release_write";
-# endif
-# if defined(AO_HAVE_fetch_and_add_release_write)
-    "AO_fetch_and_add_release_write(&val, incr):";
-    AO_fetch_and_add_release_write(&val, incr);
-# else
-    "No AO_fetch_and_add_release_write";
-# endif
-# if defined(AO_HAVE_compare_and_swap_release_write)
-    "AO_compare_and_swap_release_write(&val, oldval, newval):";
-    AO_compare_and_swap_release_write(&val, oldval, newval);
-# else
-    "No AO_compare_and_swap_release_write";
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* This generates a compilable program.  But it is really meant to be   */
-/* be used only with cc -E, to inspect the expensions generated by      */
-/* primitives.                                                          */
-
-/* The result will not link or run.                                     */
-
-void list_atomic_acquire_read(void)
-{
-  AO_T val, newval = 0, oldval = 0;
-  AO_TS_T ts;
-  long incr = 0;
-
-# if defined(AO_HAVE_nop_acquire_read)
-    "AO_nop_acquire_read(): ";
-    AO_nop_acquire_read();
-# else
-    "No AO_nop_acquire_read";
-# endif
-# if defined(AO_HAVE_load_acquire_read)
-    "AO_load_acquire_read(&val):";
-    AO_load_acquire_read(&val);
-# else
-    "No AO_load_acquire_read";
-# endif
-# if defined(AO_HAVE_store_acquire_read)
-    "AO_store_acquire_read(&val, newval):";
-    AO_store_acquire_read(&val, newval);
-# else
-    "No AO_store_acquire_read";
-# endif
-# if defined(AO_HAVE_test_and_set_acquire_read)
-    "AO_test_and_set_acquire_read(&ts):";
-    AO_test_and_set_acquire_read(&ts);
-# else
-    "No AO_test_and_set_acquire_read";
-# endif
-# if defined(AO_HAVE_fetch_and_add1_acquire_read)
-    "AO_fetch_and_add1_acquire_read(&val):";
-    AO_fetch_and_add1_acquire_read(&val);
-# else
-    "No AO_fetch_and_add1_acquire_read";
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_acquire_read)
-    "AO_fetch_and_sub1_acquire_read(&val):";
-    AO_fetch_and_sub1_acquire_read(&val);
-# else
-    "No AO_fetch_and_sub1_acquire_read";
-# endif
-# if defined(AO_HAVE_fetch_and_add_acquire_read)
-    "AO_fetch_and_add_acquire_read(&val, incr):";
-    AO_fetch_and_add_acquire_read(&val, incr);
-# else
-    "No AO_fetch_and_add_acquire_read";
-# endif
-# if defined(AO_HAVE_compare_and_swap_acquire_read)
-    "AO_compare_and_swap_acquire_read(&val, oldval, newval):";
-    AO_compare_and_swap_acquire_read(&val, oldval, newval);
-# else
-    "No AO_compare_and_swap_acquire_read";
-# endif
-}
diff --git a/tests/test_atomic_include.h b/tests/test_atomic_include.h
deleted file mode 100644 (file)
index 2595708..0000000
+++ /dev/null
@@ -1,1712 +0,0 @@
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* Some basic sanity tests.  These do not test the barrier semantics. */
-
-#undef TA_assert
-#define TA_assert(e) \
-  if (!(e)) { fprintf(stderr, "Assertion failed %s:%d (barrier: )\n", \
-                    __FILE__, __LINE__), exit(1); }
-
-#undef MISSING
-#define MISSING(name) \
-  fprintf(stderr, "Missing: %s\n", #name "")
-
-void test_atomic(void)
-{
-  AO_t x;
-  unsigned char b;
-  unsigned short s;
-  unsigned int zz;
-# if defined(AO_HAVE_test_and_set)
-    AO_TS_t z = AO_TS_INITIALIZER;
-# endif
-# if defined(AO_HAVE_double_t)
-    AO_double_t w;
-    w.AO_val1 = 0;
-    w.AO_val2 = 0;
-# endif
-
-# if defined(AO_HAVE_nop)
-    AO_nop();
-# else
-    MISSING(AO_nop);
-# endif
-# if defined(AO_HAVE_store)
-    AO_store(&x, 13);
-    TA_assert (x == 13);
-# else
-    MISSING(AO_store);
-    x = 13;
-# endif
-# if defined(AO_HAVE_load)
-    TA_assert(AO_load(&x) == 13);
-# else
-    MISSING(AO_load);
-# endif
-# if defined(AO_HAVE_test_and_set)
-    assert(AO_test_and_set(&z) == AO_TS_CLEAR);
-    assert(AO_test_and_set(&z) == AO_TS_SET);
-    assert(AO_test_and_set(&z) == AO_TS_SET);
-    AO_CLEAR(&z);
-# else
-    MISSING(AO_test_and_set);
-# endif
-# if defined(AO_HAVE_fetch_and_add)
-    TA_assert(AO_fetch_and_add(&x, 42) == 13);
-    TA_assert(AO_fetch_and_add(&x, -42) == 55);
-# else
-    MISSING(AO_fetch_and_add);
-# endif
-# if defined(AO_HAVE_fetch_and_add1)
-    TA_assert(AO_fetch_and_add1(&x) == 13);
-# else
-    MISSING(AO_fetch_and_add1);
-    ++x;
-# endif
-# if defined(AO_HAVE_fetch_and_sub1)
-    TA_assert(AO_fetch_and_sub1(&x) == 14);
-# else
-    MISSING(AO_fetch_and_sub1);
-    --x;
-# endif
-# if defined(AO_HAVE_short_store)
-    AO_short_store(&s, 13);
-# else
-    MISSING(AO_short_store);
-    s = 13;
-# endif
-# if defined(AO_HAVE_short_load)
-    TA_assert(AO_short_load(&s) == 13);
-# else
-    MISSING(AO_short_load);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add)
-    TA_assert(AO_short_fetch_and_add(&s, 42) == 13);
-    TA_assert(AO_short_fetch_and_add(&s, -42) == 55);
-# else
-    MISSING(AO_short_fetch_and_add);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add1)
-    TA_assert(AO_short_fetch_and_add1(&s) == 13);
-# else
-    MISSING(AO_short_fetch_and_add1);
-    ++s;
-# endif
-# if defined(AO_HAVE_short_fetch_and_sub1)
-    TA_assert(AO_short_fetch_and_sub1(&s) == 14);
-# else
-    MISSING(AO_short_fetch_and_sub1);
-    --s;
-# endif
-# if defined(AO_HAVE_char_store)
-    AO_char_store(&b, 13);
-# else
-    MISSING(AO_char_store);
-    b = 13;
-# endif
-# if defined(AO_HAVE_char_load)
-    TA_assert(AO_char_load(&b) == 13);
-# else
-    MISSING(AO_char_load);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add)
-    TA_assert(AO_char_fetch_and_add(&b, 42) == 13);
-    TA_assert(AO_char_fetch_and_add(&b, -42) == 55);
-# else
-    MISSING(AO_char_fetch_and_add);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add1)
-    TA_assert(AO_char_fetch_and_add1(&b) == 13);
-# else
-    MISSING(AO_char_fetch_and_add1);
-    ++b;
-# endif
-# if defined(AO_HAVE_char_fetch_and_sub1)
-    TA_assert(AO_char_fetch_and_sub1(&b) == 14);
-# else
-    MISSING(AO_char_fetch_and_sub1);
-    --b;
-# endif
-# if defined(AO_HAVE_int_store)
-    AO_int_store(&zz, 13);
-# else
-    MISSING(AO_int_store);
-    zz = 13;
-# endif
-# if defined(AO_HAVE_int_load)
-    TA_assert(AO_int_load(&zz) == 13);
-# else
-    MISSING(AO_int_load);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add)
-    TA_assert(AO_int_fetch_and_add(&zz, 42) == 13);
-    TA_assert(AO_int_fetch_and_add(&zz, -42) == 55);
-# else
-    MISSING(AO_int_fetch_and_add);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add1)
-    TA_assert(AO_int_fetch_and_add1(&zz) == 13);
-# else
-    MISSING(AO_int_fetch_and_add1);
-    ++zz;
-# endif
-# if defined(AO_HAVE_int_fetch_and_sub1)
-    TA_assert(AO_int_fetch_and_sub1(&zz) == 14);
-# else
-    MISSING(AO_int_fetch_and_sub1);
-    --zz;
-# endif
-# if defined(AO_HAVE_compare_and_swap)
-    TA_assert(!AO_compare_and_swap(&x, 14, 42));
-    TA_assert(x == 13);
-    TA_assert(AO_compare_and_swap(&x, 13, 42));
-    TA_assert(x == 42);
-# else
-    MISSING(AO_compare_and_swap);
-# endif
-# if defined(AO_HAVE_or)
-    AO_or(&x, 66);
-    TA_assert(x == 106);
-# else
-    MISSING(AO_or);
-    x |= 66;
-# endif
-# if defined(AO_HAVE_xor)
-    AO_xor(&x, 181);
-    TA_assert(x == 223);
-# else
-    MISSING(AO_xor);
-    x ^= 181;
-# endif
-# if defined(AO_HAVE_and)
-    AO_and(&x, 57);
-    TA_assert(x == 25);
-# else
-    MISSING(AO_and);
-    x &= 57;
-# endif
-# if defined(AO_HAVE_compare_double_and_swap_double)
-    TA_assert(!AO_compare_double_and_swap_double(&w, 17, 42, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_double_and_swap_double(&w, 0, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_double_and_swap_double(&w, 12, 13, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-    w.AO_val1 = 0; w.AO_val2 = 0;
-# else
-    MISSING(AO_compare_double_and_swap_double);
-# endif
-# if defined(AO_HAVE_compare_and_swap_double)
-    TA_assert(!AO_compare_and_swap_double(&w, 17, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_and_swap_double(&w, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_and_swap_double(&w, 12, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-# else
-    MISSING(AO_compare_and_swap_double);
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* Some basic sanity tests.  These do not test the barrier semantics. */
-
-#undef TA_assert
-#define TA_assert(e) \
-  if (!(e)) { fprintf(stderr, "Assertion failed %s:%d (barrier: _release)\n", \
-                    __FILE__, __LINE__), exit(1); }
-
-#undef MISSING
-#define MISSING(name) \
-  fprintf(stderr, "Missing: %s\n", #name "_release")
-
-void test_atomic_release(void)
-{
-  AO_t x;
-  unsigned char b;
-  unsigned short s;
-  unsigned int zz;
-# if defined(AO_HAVE_test_and_set_release)
-    AO_TS_t z = AO_TS_INITIALIZER;
-# endif
-# if defined(AO_HAVE_double_t)
-    AO_double_t w;
-    w.AO_val1 = 0;
-    w.AO_val2 = 0;
-# endif
-
-# if defined(AO_HAVE_nop_release)
-    AO_nop_release();
-# else
-    MISSING(AO_nop);
-# endif
-# if defined(AO_HAVE_store_release)
-    AO_store_release(&x, 13);
-    TA_assert (x == 13);
-# else
-    MISSING(AO_store);
-    x = 13;
-# endif
-# if defined(AO_HAVE_load_release)
-    TA_assert(AO_load_release(&x) == 13);
-# else
-    MISSING(AO_load);
-# endif
-# if defined(AO_HAVE_test_and_set_release)
-    assert(AO_test_and_set_release(&z) == AO_TS_CLEAR);
-    assert(AO_test_and_set_release(&z) == AO_TS_SET);
-    assert(AO_test_and_set_release(&z) == AO_TS_SET);
-    AO_CLEAR(&z);
-# else
-    MISSING(AO_test_and_set);
-# endif
-# if defined(AO_HAVE_fetch_and_add_release)
-    TA_assert(AO_fetch_and_add_release(&x, 42) == 13);
-    TA_assert(AO_fetch_and_add_release(&x, -42) == 55);
-# else
-    MISSING(AO_fetch_and_add);
-# endif
-# if defined(AO_HAVE_fetch_and_add1_release)
-    TA_assert(AO_fetch_and_add1_release(&x) == 13);
-# else
-    MISSING(AO_fetch_and_add1);
-    ++x;
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_release)
-    TA_assert(AO_fetch_and_sub1_release(&x) == 14);
-# else
-    MISSING(AO_fetch_and_sub1);
-    --x;
-# endif
-# if defined(AO_HAVE_short_store_release)
-    AO_short_store_release(&s, 13);
-# else
-    MISSING(AO_short_store);
-    s = 13;
-# endif
-# if defined(AO_HAVE_short_load_release)
-    TA_assert(AO_short_load(&s) == 13);
-# else
-    MISSING(AO_short_load);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add_release)
-    TA_assert(AO_short_fetch_and_add_release(&s, 42) == 13);
-    TA_assert(AO_short_fetch_and_add_release(&s, -42) == 55);
-# else
-    MISSING(AO_short_fetch_and_add);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add1_release)
-    TA_assert(AO_short_fetch_and_add1_release(&s) == 13);
-# else
-    MISSING(AO_short_fetch_and_add1);
-    ++s;
-# endif
-# if defined(AO_HAVE_short_fetch_and_sub1_release)
-    TA_assert(AO_short_fetch_and_sub1_release(&s) == 14);
-# else
-    MISSING(AO_short_fetch_and_sub1);
-    --s;
-# endif
-# if defined(AO_HAVE_char_store_release)
-    AO_char_store_release(&b, 13);
-# else
-    MISSING(AO_char_store);
-    b = 13;
-# endif
-# if defined(AO_HAVE_char_load_release)
-    TA_assert(AO_char_load(&b) == 13);
-# else
-    MISSING(AO_char_load);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add_release)
-    TA_assert(AO_char_fetch_and_add_release(&b, 42) == 13);
-    TA_assert(AO_char_fetch_and_add_release(&b, -42) == 55);
-# else
-    MISSING(AO_char_fetch_and_add);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add1_release)
-    TA_assert(AO_char_fetch_and_add1_release(&b) == 13);
-# else
-    MISSING(AO_char_fetch_and_add1);
-    ++b;
-# endif
-# if defined(AO_HAVE_char_fetch_and_sub1_release)
-    TA_assert(AO_char_fetch_and_sub1_release(&b) == 14);
-# else
-    MISSING(AO_char_fetch_and_sub1);
-    --b;
-# endif
-# if defined(AO_HAVE_int_store_release)
-    AO_int_store_release(&zz, 13);
-# else
-    MISSING(AO_int_store);
-    zz = 13;
-# endif
-# if defined(AO_HAVE_int_load_release)
-    TA_assert(AO_int_load(&zz) == 13);
-# else
-    MISSING(AO_int_load);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add_release)
-    TA_assert(AO_int_fetch_and_add_release(&zz, 42) == 13);
-    TA_assert(AO_int_fetch_and_add_release(&zz, -42) == 55);
-# else
-    MISSING(AO_int_fetch_and_add);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add1_release)
-    TA_assert(AO_int_fetch_and_add1_release(&zz) == 13);
-# else
-    MISSING(AO_int_fetch_and_add1);
-    ++zz;
-# endif
-# if defined(AO_HAVE_int_fetch_and_sub1_release)
-    TA_assert(AO_int_fetch_and_sub1_release(&zz) == 14);
-# else
-    MISSING(AO_int_fetch_and_sub1);
-    --zz;
-# endif
-# if defined(AO_HAVE_compare_and_swap_release)
-    TA_assert(!AO_compare_and_swap_release(&x, 14, 42));
-    TA_assert(x == 13);
-    TA_assert(AO_compare_and_swap_release(&x, 13, 42));
-    TA_assert(x == 42);
-# else
-    MISSING(AO_compare_and_swap);
-# endif
-# if defined(AO_HAVE_or_release)
-    AO_or_release(&x, 66);
-    TA_assert(x == 106);
-# else
-    MISSING(AO_or);
-    x |= 66;
-# endif
-# if defined(AO_HAVE_xor_release)
-    AO_xor_release(&x, 181);
-    TA_assert(x == 223);
-# else
-    MISSING(AO_xor);
-    x ^= 181;
-# endif
-# if defined(AO_HAVE_and_release)
-    AO_and_release(&x, 57);
-    TA_assert(x == 25);
-# else
-    MISSING(AO_and);
-    x &= 57;
-# endif
-# if defined(AO_HAVE_compare_double_and_swap_double_release)
-    TA_assert(!AO_compare_double_and_swap_double_release(&w, 17, 42, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_double_and_swap_double_release(&w, 0, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_double_and_swap_double_release(&w, 12, 13, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-    w.AO_val1 = 0; w.AO_val2 = 0;
-# else
-    MISSING(AO_compare_double_and_swap_double);
-# endif
-# if defined(AO_HAVE_compare_and_swap_double_release)
-    TA_assert(!AO_compare_and_swap_double_release(&w, 17, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_and_swap_double_release(&w, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_and_swap_double_release(&w, 12, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-# else
-    MISSING(AO_compare_and_swap_double);
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* Some basic sanity tests.  These do not test the barrier semantics. */
-
-#undef TA_assert
-#define TA_assert(e) \
-  if (!(e)) { fprintf(stderr, "Assertion failed %s:%d (barrier: _acquire)\n", \
-                    __FILE__, __LINE__), exit(1); }
-
-#undef MISSING
-#define MISSING(name) \
-  fprintf(stderr, "Missing: %s\n", #name "_acquire")
-
-void test_atomic_acquire(void)
-{
-  AO_t x;
-  unsigned char b;
-  unsigned short s;
-  unsigned int zz;
-# if defined(AO_HAVE_test_and_set_acquire)
-    AO_TS_t z = AO_TS_INITIALIZER;
-# endif
-# if defined(AO_HAVE_double_t)
-    AO_double_t w;
-    w.AO_val1 = 0;
-    w.AO_val2 = 0;
-# endif
-
-# if defined(AO_HAVE_nop_acquire)
-    AO_nop_acquire();
-# else
-    MISSING(AO_nop);
-# endif
-# if defined(AO_HAVE_store_acquire)
-    AO_store_acquire(&x, 13);
-    TA_assert (x == 13);
-# else
-    MISSING(AO_store);
-    x = 13;
-# endif
-# if defined(AO_HAVE_load_acquire)
-    TA_assert(AO_load_acquire(&x) == 13);
-# else
-    MISSING(AO_load);
-# endif
-# if defined(AO_HAVE_test_and_set_acquire)
-    assert(AO_test_and_set_acquire(&z) == AO_TS_CLEAR);
-    assert(AO_test_and_set_acquire(&z) == AO_TS_SET);
-    assert(AO_test_and_set_acquire(&z) == AO_TS_SET);
-    AO_CLEAR(&z);
-# else
-    MISSING(AO_test_and_set);
-# endif
-# if defined(AO_HAVE_fetch_and_add_acquire)
-    TA_assert(AO_fetch_and_add_acquire(&x, 42) == 13);
-    TA_assert(AO_fetch_and_add_acquire(&x, -42) == 55);
-# else
-    MISSING(AO_fetch_and_add);
-# endif
-# if defined(AO_HAVE_fetch_and_add1_acquire)
-    TA_assert(AO_fetch_and_add1_acquire(&x) == 13);
-# else
-    MISSING(AO_fetch_and_add1);
-    ++x;
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_acquire)
-    TA_assert(AO_fetch_and_sub1_acquire(&x) == 14);
-# else
-    MISSING(AO_fetch_and_sub1);
-    --x;
-# endif
-# if defined(AO_HAVE_short_store_acquire)
-    AO_short_store_acquire(&s, 13);
-# else
-    MISSING(AO_short_store);
-    s = 13;
-# endif
-# if defined(AO_HAVE_short_load_acquire)
-    TA_assert(AO_short_load(&s) == 13);
-# else
-    MISSING(AO_short_load);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add_acquire)
-    TA_assert(AO_short_fetch_and_add_acquire(&s, 42) == 13);
-    TA_assert(AO_short_fetch_and_add_acquire(&s, -42) == 55);
-# else
-    MISSING(AO_short_fetch_and_add);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add1_acquire)
-    TA_assert(AO_short_fetch_and_add1_acquire(&s) == 13);
-# else
-    MISSING(AO_short_fetch_and_add1);
-    ++s;
-# endif
-# if defined(AO_HAVE_short_fetch_and_sub1_acquire)
-    TA_assert(AO_short_fetch_and_sub1_acquire(&s) == 14);
-# else
-    MISSING(AO_short_fetch_and_sub1);
-    --s;
-# endif
-# if defined(AO_HAVE_char_store_acquire)
-    AO_char_store_acquire(&b, 13);
-# else
-    MISSING(AO_char_store);
-    b = 13;
-# endif
-# if defined(AO_HAVE_char_load_acquire)
-    TA_assert(AO_char_load(&b) == 13);
-# else
-    MISSING(AO_char_load);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add_acquire)
-    TA_assert(AO_char_fetch_and_add_acquire(&b, 42) == 13);
-    TA_assert(AO_char_fetch_and_add_acquire(&b, -42) == 55);
-# else
-    MISSING(AO_char_fetch_and_add);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add1_acquire)
-    TA_assert(AO_char_fetch_and_add1_acquire(&b) == 13);
-# else
-    MISSING(AO_char_fetch_and_add1);
-    ++b;
-# endif
-# if defined(AO_HAVE_char_fetch_and_sub1_acquire)
-    TA_assert(AO_char_fetch_and_sub1_acquire(&b) == 14);
-# else
-    MISSING(AO_char_fetch_and_sub1);
-    --b;
-# endif
-# if defined(AO_HAVE_int_store_acquire)
-    AO_int_store_acquire(&zz, 13);
-# else
-    MISSING(AO_int_store);
-    zz = 13;
-# endif
-# if defined(AO_HAVE_int_load_acquire)
-    TA_assert(AO_int_load(&zz) == 13);
-# else
-    MISSING(AO_int_load);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add_acquire)
-    TA_assert(AO_int_fetch_and_add_acquire(&zz, 42) == 13);
-    TA_assert(AO_int_fetch_and_add_acquire(&zz, -42) == 55);
-# else
-    MISSING(AO_int_fetch_and_add);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add1_acquire)
-    TA_assert(AO_int_fetch_and_add1_acquire(&zz) == 13);
-# else
-    MISSING(AO_int_fetch_and_add1);
-    ++zz;
-# endif
-# if defined(AO_HAVE_int_fetch_and_sub1_acquire)
-    TA_assert(AO_int_fetch_and_sub1_acquire(&zz) == 14);
-# else
-    MISSING(AO_int_fetch_and_sub1);
-    --zz;
-# endif
-# if defined(AO_HAVE_compare_and_swap_acquire)
-    TA_assert(!AO_compare_and_swap_acquire(&x, 14, 42));
-    TA_assert(x == 13);
-    TA_assert(AO_compare_and_swap_acquire(&x, 13, 42));
-    TA_assert(x == 42);
-# else
-    MISSING(AO_compare_and_swap);
-# endif
-# if defined(AO_HAVE_or_acquire)
-    AO_or_acquire(&x, 66);
-    TA_assert(x == 106);
-# else
-    MISSING(AO_or);
-    x |= 66;
-# endif
-# if defined(AO_HAVE_xor_acquire)
-    AO_xor_acquire(&x, 181);
-    TA_assert(x == 223);
-# else
-    MISSING(AO_xor);
-    x ^= 181;
-# endif
-# if defined(AO_HAVE_and_acquire)
-    AO_and_acquire(&x, 57);
-    TA_assert(x == 25);
-# else
-    MISSING(AO_and);
-    x &= 57;
-# endif
-# if defined(AO_HAVE_compare_double_and_swap_double_acquire)
-    TA_assert(!AO_compare_double_and_swap_double_acquire(&w, 17, 42, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_double_and_swap_double_acquire(&w, 0, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_double_and_swap_double_acquire(&w, 12, 13, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-    w.AO_val1 = 0; w.AO_val2 = 0;
-# else
-    MISSING(AO_compare_double_and_swap_double);
-# endif
-# if defined(AO_HAVE_compare_and_swap_double_acquire)
-    TA_assert(!AO_compare_and_swap_double_acquire(&w, 17, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_and_swap_double_acquire(&w, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_and_swap_double_acquire(&w, 12, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-# else
-    MISSING(AO_compare_and_swap_double);
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* Some basic sanity tests.  These do not test the barrier semantics. */
-
-#undef TA_assert
-#define TA_assert(e) \
-  if (!(e)) { fprintf(stderr, "Assertion failed %s:%d (barrier: _read)\n", \
-                    __FILE__, __LINE__), exit(1); }
-
-#undef MISSING
-#define MISSING(name) \
-  fprintf(stderr, "Missing: %s\n", #name "_read")
-
-void test_atomic_read(void)
-{
-  AO_t x;
-  unsigned char b;
-  unsigned short s;
-  unsigned int zz;
-# if defined(AO_HAVE_test_and_set_read)
-    AO_TS_t z = AO_TS_INITIALIZER;
-# endif
-# if defined(AO_HAVE_double_t)
-    AO_double_t w;
-    w.AO_val1 = 0;
-    w.AO_val2 = 0;
-# endif
-
-# if defined(AO_HAVE_nop_read)
-    AO_nop_read();
-# else
-    MISSING(AO_nop);
-# endif
-# if defined(AO_HAVE_store_read)
-    AO_store_read(&x, 13);
-    TA_assert (x == 13);
-# else
-    MISSING(AO_store);
-    x = 13;
-# endif
-# if defined(AO_HAVE_load_read)
-    TA_assert(AO_load_read(&x) == 13);
-# else
-    MISSING(AO_load);
-# endif
-# if defined(AO_HAVE_test_and_set_read)
-    assert(AO_test_and_set_read(&z) == AO_TS_CLEAR);
-    assert(AO_test_and_set_read(&z) == AO_TS_SET);
-    assert(AO_test_and_set_read(&z) == AO_TS_SET);
-    AO_CLEAR(&z);
-# else
-    MISSING(AO_test_and_set);
-# endif
-# if defined(AO_HAVE_fetch_and_add_read)
-    TA_assert(AO_fetch_and_add_read(&x, 42) == 13);
-    TA_assert(AO_fetch_and_add_read(&x, -42) == 55);
-# else
-    MISSING(AO_fetch_and_add);
-# endif
-# if defined(AO_HAVE_fetch_and_add1_read)
-    TA_assert(AO_fetch_and_add1_read(&x) == 13);
-# else
-    MISSING(AO_fetch_and_add1);
-    ++x;
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_read)
-    TA_assert(AO_fetch_and_sub1_read(&x) == 14);
-# else
-    MISSING(AO_fetch_and_sub1);
-    --x;
-# endif
-# if defined(AO_HAVE_short_store_read)
-    AO_short_store_read(&s, 13);
-# else
-    MISSING(AO_short_store);
-    s = 13;
-# endif
-# if defined(AO_HAVE_short_load_read)
-    TA_assert(AO_short_load(&s) == 13);
-# else
-    MISSING(AO_short_load);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add_read)
-    TA_assert(AO_short_fetch_and_add_read(&s, 42) == 13);
-    TA_assert(AO_short_fetch_and_add_read(&s, -42) == 55);
-# else
-    MISSING(AO_short_fetch_and_add);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add1_read)
-    TA_assert(AO_short_fetch_and_add1_read(&s) == 13);
-# else
-    MISSING(AO_short_fetch_and_add1);
-    ++s;
-# endif
-# if defined(AO_HAVE_short_fetch_and_sub1_read)
-    TA_assert(AO_short_fetch_and_sub1_read(&s) == 14);
-# else
-    MISSING(AO_short_fetch_and_sub1);
-    --s;
-# endif
-# if defined(AO_HAVE_char_store_read)
-    AO_char_store_read(&b, 13);
-# else
-    MISSING(AO_char_store);
-    b = 13;
-# endif
-# if defined(AO_HAVE_char_load_read)
-    TA_assert(AO_char_load(&b) == 13);
-# else
-    MISSING(AO_char_load);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add_read)
-    TA_assert(AO_char_fetch_and_add_read(&b, 42) == 13);
-    TA_assert(AO_char_fetch_and_add_read(&b, -42) == 55);
-# else
-    MISSING(AO_char_fetch_and_add);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add1_read)
-    TA_assert(AO_char_fetch_and_add1_read(&b) == 13);
-# else
-    MISSING(AO_char_fetch_and_add1);
-    ++b;
-# endif
-# if defined(AO_HAVE_char_fetch_and_sub1_read)
-    TA_assert(AO_char_fetch_and_sub1_read(&b) == 14);
-# else
-    MISSING(AO_char_fetch_and_sub1);
-    --b;
-# endif
-# if defined(AO_HAVE_int_store_read)
-    AO_int_store_read(&zz, 13);
-# else
-    MISSING(AO_int_store);
-    zz = 13;
-# endif
-# if defined(AO_HAVE_int_load_read)
-    TA_assert(AO_int_load(&zz) == 13);
-# else
-    MISSING(AO_int_load);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add_read)
-    TA_assert(AO_int_fetch_and_add_read(&zz, 42) == 13);
-    TA_assert(AO_int_fetch_and_add_read(&zz, -42) == 55);
-# else
-    MISSING(AO_int_fetch_and_add);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add1_read)
-    TA_assert(AO_int_fetch_and_add1_read(&zz) == 13);
-# else
-    MISSING(AO_int_fetch_and_add1);
-    ++zz;
-# endif
-# if defined(AO_HAVE_int_fetch_and_sub1_read)
-    TA_assert(AO_int_fetch_and_sub1_read(&zz) == 14);
-# else
-    MISSING(AO_int_fetch_and_sub1);
-    --zz;
-# endif
-# if defined(AO_HAVE_compare_and_swap_read)
-    TA_assert(!AO_compare_and_swap_read(&x, 14, 42));
-    TA_assert(x == 13);
-    TA_assert(AO_compare_and_swap_read(&x, 13, 42));
-    TA_assert(x == 42);
-# else
-    MISSING(AO_compare_and_swap);
-# endif
-# if defined(AO_HAVE_or_read)
-    AO_or_read(&x, 66);
-    TA_assert(x == 106);
-# else
-    MISSING(AO_or);
-    x |= 66;
-# endif
-# if defined(AO_HAVE_xor_read)
-    AO_xor_read(&x, 181);
-    TA_assert(x == 223);
-# else
-    MISSING(AO_xor);
-    x ^= 181;
-# endif
-# if defined(AO_HAVE_and_read)
-    AO_and_read(&x, 57);
-    TA_assert(x == 25);
-# else
-    MISSING(AO_and);
-    x &= 57;
-# endif
-# if defined(AO_HAVE_compare_double_and_swap_double_read)
-    TA_assert(!AO_compare_double_and_swap_double_read(&w, 17, 42, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_double_and_swap_double_read(&w, 0, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_double_and_swap_double_read(&w, 12, 13, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-    w.AO_val1 = 0; w.AO_val2 = 0;
-# else
-    MISSING(AO_compare_double_and_swap_double);
-# endif
-# if defined(AO_HAVE_compare_and_swap_double_read)
-    TA_assert(!AO_compare_and_swap_double_read(&w, 17, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_and_swap_double_read(&w, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_and_swap_double_read(&w, 12, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-# else
-    MISSING(AO_compare_and_swap_double);
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* Some basic sanity tests.  These do not test the barrier semantics. */
-
-#undef TA_assert
-#define TA_assert(e) \
-  if (!(e)) { fprintf(stderr, "Assertion failed %s:%d (barrier: _write)\n", \
-                    __FILE__, __LINE__), exit(1); }
-
-#undef MISSING
-#define MISSING(name) \
-  fprintf(stderr, "Missing: %s\n", #name "_write")
-
-void test_atomic_write(void)
-{
-  AO_t x;
-  unsigned char b;
-  unsigned short s;
-  unsigned int zz;
-# if defined(AO_HAVE_test_and_set_write)
-    AO_TS_t z = AO_TS_INITIALIZER;
-# endif
-# if defined(AO_HAVE_double_t)
-    AO_double_t w;
-    w.AO_val1 = 0;
-    w.AO_val2 = 0;
-# endif
-
-# if defined(AO_HAVE_nop_write)
-    AO_nop_write();
-# else
-    MISSING(AO_nop);
-# endif
-# if defined(AO_HAVE_store_write)
-    AO_store_write(&x, 13);
-    TA_assert (x == 13);
-# else
-    MISSING(AO_store);
-    x = 13;
-# endif
-# if defined(AO_HAVE_load_write)
-    TA_assert(AO_load_write(&x) == 13);
-# else
-    MISSING(AO_load);
-# endif
-# if defined(AO_HAVE_test_and_set_write)
-    assert(AO_test_and_set_write(&z) == AO_TS_CLEAR);
-    assert(AO_test_and_set_write(&z) == AO_TS_SET);
-    assert(AO_test_and_set_write(&z) == AO_TS_SET);
-    AO_CLEAR(&z);
-# else
-    MISSING(AO_test_and_set);
-# endif
-# if defined(AO_HAVE_fetch_and_add_write)
-    TA_assert(AO_fetch_and_add_write(&x, 42) == 13);
-    TA_assert(AO_fetch_and_add_write(&x, -42) == 55);
-# else
-    MISSING(AO_fetch_and_add);
-# endif
-# if defined(AO_HAVE_fetch_and_add1_write)
-    TA_assert(AO_fetch_and_add1_write(&x) == 13);
-# else
-    MISSING(AO_fetch_and_add1);
-    ++x;
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_write)
-    TA_assert(AO_fetch_and_sub1_write(&x) == 14);
-# else
-    MISSING(AO_fetch_and_sub1);
-    --x;
-# endif
-# if defined(AO_HAVE_short_store_write)
-    AO_short_store_write(&s, 13);
-# else
-    MISSING(AO_short_store);
-    s = 13;
-# endif
-# if defined(AO_HAVE_short_load_write)
-    TA_assert(AO_short_load(&s) == 13);
-# else
-    MISSING(AO_short_load);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add_write)
-    TA_assert(AO_short_fetch_and_add_write(&s, 42) == 13);
-    TA_assert(AO_short_fetch_and_add_write(&s, -42) == 55);
-# else
-    MISSING(AO_short_fetch_and_add);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add1_write)
-    TA_assert(AO_short_fetch_and_add1_write(&s) == 13);
-# else
-    MISSING(AO_short_fetch_and_add1);
-    ++s;
-# endif
-# if defined(AO_HAVE_short_fetch_and_sub1_write)
-    TA_assert(AO_short_fetch_and_sub1_write(&s) == 14);
-# else
-    MISSING(AO_short_fetch_and_sub1);
-    --s;
-# endif
-# if defined(AO_HAVE_char_store_write)
-    AO_char_store_write(&b, 13);
-# else
-    MISSING(AO_char_store);
-    b = 13;
-# endif
-# if defined(AO_HAVE_char_load_write)
-    TA_assert(AO_char_load(&b) == 13);
-# else
-    MISSING(AO_char_load);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add_write)
-    TA_assert(AO_char_fetch_and_add_write(&b, 42) == 13);
-    TA_assert(AO_char_fetch_and_add_write(&b, -42) == 55);
-# else
-    MISSING(AO_char_fetch_and_add);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add1_write)
-    TA_assert(AO_char_fetch_and_add1_write(&b) == 13);
-# else
-    MISSING(AO_char_fetch_and_add1);
-    ++b;
-# endif
-# if defined(AO_HAVE_char_fetch_and_sub1_write)
-    TA_assert(AO_char_fetch_and_sub1_write(&b) == 14);
-# else
-    MISSING(AO_char_fetch_and_sub1);
-    --b;
-# endif
-# if defined(AO_HAVE_int_store_write)
-    AO_int_store_write(&zz, 13);
-# else
-    MISSING(AO_int_store);
-    zz = 13;
-# endif
-# if defined(AO_HAVE_int_load_write)
-    TA_assert(AO_int_load(&zz) == 13);
-# else
-    MISSING(AO_int_load);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add_write)
-    TA_assert(AO_int_fetch_and_add_write(&zz, 42) == 13);
-    TA_assert(AO_int_fetch_and_add_write(&zz, -42) == 55);
-# else
-    MISSING(AO_int_fetch_and_add);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add1_write)
-    TA_assert(AO_int_fetch_and_add1_write(&zz) == 13);
-# else
-    MISSING(AO_int_fetch_and_add1);
-    ++zz;
-# endif
-# if defined(AO_HAVE_int_fetch_and_sub1_write)
-    TA_assert(AO_int_fetch_and_sub1_write(&zz) == 14);
-# else
-    MISSING(AO_int_fetch_and_sub1);
-    --zz;
-# endif
-# if defined(AO_HAVE_compare_and_swap_write)
-    TA_assert(!AO_compare_and_swap_write(&x, 14, 42));
-    TA_assert(x == 13);
-    TA_assert(AO_compare_and_swap_write(&x, 13, 42));
-    TA_assert(x == 42);
-# else
-    MISSING(AO_compare_and_swap);
-# endif
-# if defined(AO_HAVE_or_write)
-    AO_or_write(&x, 66);
-    TA_assert(x == 106);
-# else
-    MISSING(AO_or);
-    x |= 66;
-# endif
-# if defined(AO_HAVE_xor_write)
-    AO_xor_write(&x, 181);
-    TA_assert(x == 223);
-# else
-    MISSING(AO_xor);
-    x ^= 181;
-# endif
-# if defined(AO_HAVE_and_write)
-    AO_and_write(&x, 57);
-    TA_assert(x == 25);
-# else
-    MISSING(AO_and);
-    x &= 57;
-# endif
-# if defined(AO_HAVE_compare_double_and_swap_double_write)
-    TA_assert(!AO_compare_double_and_swap_double_write(&w, 17, 42, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_double_and_swap_double_write(&w, 0, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_double_and_swap_double_write(&w, 12, 13, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-    w.AO_val1 = 0; w.AO_val2 = 0;
-# else
-    MISSING(AO_compare_double_and_swap_double);
-# endif
-# if defined(AO_HAVE_compare_and_swap_double_write)
-    TA_assert(!AO_compare_and_swap_double_write(&w, 17, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_and_swap_double_write(&w, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_and_swap_double_write(&w, 12, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-# else
-    MISSING(AO_compare_and_swap_double);
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* Some basic sanity tests.  These do not test the barrier semantics. */
-
-#undef TA_assert
-#define TA_assert(e) \
-  if (!(e)) { fprintf(stderr, "Assertion failed %s:%d (barrier: _full)\n", \
-                    __FILE__, __LINE__), exit(1); }
-
-#undef MISSING
-#define MISSING(name) \
-  fprintf(stderr, "Missing: %s\n", #name "_full")
-
-void test_atomic_full(void)
-{
-  AO_t x;
-  unsigned char b;
-  unsigned short s;
-  unsigned int zz;
-# if defined(AO_HAVE_test_and_set_full)
-    AO_TS_t z = AO_TS_INITIALIZER;
-# endif
-# if defined(AO_HAVE_double_t)
-    AO_double_t w;
-    w.AO_val1 = 0;
-    w.AO_val2 = 0;
-# endif
-
-# if defined(AO_HAVE_nop_full)
-    AO_nop_full();
-# else
-    MISSING(AO_nop);
-# endif
-# if defined(AO_HAVE_store_full)
-    AO_store_full(&x, 13);
-    TA_assert (x == 13);
-# else
-    MISSING(AO_store);
-    x = 13;
-# endif
-# if defined(AO_HAVE_load_full)
-    TA_assert(AO_load_full(&x) == 13);
-# else
-    MISSING(AO_load);
-# endif
-# if defined(AO_HAVE_test_and_set_full)
-    assert(AO_test_and_set_full(&z) == AO_TS_CLEAR);
-    assert(AO_test_and_set_full(&z) == AO_TS_SET);
-    assert(AO_test_and_set_full(&z) == AO_TS_SET);
-    AO_CLEAR(&z);
-# else
-    MISSING(AO_test_and_set);
-# endif
-# if defined(AO_HAVE_fetch_and_add_full)
-    TA_assert(AO_fetch_and_add_full(&x, 42) == 13);
-    TA_assert(AO_fetch_and_add_full(&x, -42) == 55);
-# else
-    MISSING(AO_fetch_and_add);
-# endif
-# if defined(AO_HAVE_fetch_and_add1_full)
-    TA_assert(AO_fetch_and_add1_full(&x) == 13);
-# else
-    MISSING(AO_fetch_and_add1);
-    ++x;
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_full)
-    TA_assert(AO_fetch_and_sub1_full(&x) == 14);
-# else
-    MISSING(AO_fetch_and_sub1);
-    --x;
-# endif
-# if defined(AO_HAVE_short_store_full)
-    AO_short_store_full(&s, 13);
-# else
-    MISSING(AO_short_store);
-    s = 13;
-# endif
-# if defined(AO_HAVE_short_load_full)
-    TA_assert(AO_short_load(&s) == 13);
-# else
-    MISSING(AO_short_load);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add_full)
-    TA_assert(AO_short_fetch_and_add_full(&s, 42) == 13);
-    TA_assert(AO_short_fetch_and_add_full(&s, -42) == 55);
-# else
-    MISSING(AO_short_fetch_and_add);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add1_full)
-    TA_assert(AO_short_fetch_and_add1_full(&s) == 13);
-# else
-    MISSING(AO_short_fetch_and_add1);
-    ++s;
-# endif
-# if defined(AO_HAVE_short_fetch_and_sub1_full)
-    TA_assert(AO_short_fetch_and_sub1_full(&s) == 14);
-# else
-    MISSING(AO_short_fetch_and_sub1);
-    --s;
-# endif
-# if defined(AO_HAVE_char_store_full)
-    AO_char_store_full(&b, 13);
-# else
-    MISSING(AO_char_store);
-    b = 13;
-# endif
-# if defined(AO_HAVE_char_load_full)
-    TA_assert(AO_char_load(&b) == 13);
-# else
-    MISSING(AO_char_load);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add_full)
-    TA_assert(AO_char_fetch_and_add_full(&b, 42) == 13);
-    TA_assert(AO_char_fetch_and_add_full(&b, -42) == 55);
-# else
-    MISSING(AO_char_fetch_and_add);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add1_full)
-    TA_assert(AO_char_fetch_and_add1_full(&b) == 13);
-# else
-    MISSING(AO_char_fetch_and_add1);
-    ++b;
-# endif
-# if defined(AO_HAVE_char_fetch_and_sub1_full)
-    TA_assert(AO_char_fetch_and_sub1_full(&b) == 14);
-# else
-    MISSING(AO_char_fetch_and_sub1);
-    --b;
-# endif
-# if defined(AO_HAVE_int_store_full)
-    AO_int_store_full(&zz, 13);
-# else
-    MISSING(AO_int_store);
-    zz = 13;
-# endif
-# if defined(AO_HAVE_int_load_full)
-    TA_assert(AO_int_load(&zz) == 13);
-# else
-    MISSING(AO_int_load);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add_full)
-    TA_assert(AO_int_fetch_and_add_full(&zz, 42) == 13);
-    TA_assert(AO_int_fetch_and_add_full(&zz, -42) == 55);
-# else
-    MISSING(AO_int_fetch_and_add);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add1_full)
-    TA_assert(AO_int_fetch_and_add1_full(&zz) == 13);
-# else
-    MISSING(AO_int_fetch_and_add1);
-    ++zz;
-# endif
-# if defined(AO_HAVE_int_fetch_and_sub1_full)
-    TA_assert(AO_int_fetch_and_sub1_full(&zz) == 14);
-# else
-    MISSING(AO_int_fetch_and_sub1);
-    --zz;
-# endif
-# if defined(AO_HAVE_compare_and_swap_full)
-    TA_assert(!AO_compare_and_swap_full(&x, 14, 42));
-    TA_assert(x == 13);
-    TA_assert(AO_compare_and_swap_full(&x, 13, 42));
-    TA_assert(x == 42);
-# else
-    MISSING(AO_compare_and_swap);
-# endif
-# if defined(AO_HAVE_or_full)
-    AO_or_full(&x, 66);
-    TA_assert(x == 106);
-# else
-    MISSING(AO_or);
-    x |= 66;
-# endif
-# if defined(AO_HAVE_xor_full)
-    AO_xor_full(&x, 181);
-    TA_assert(x == 223);
-# else
-    MISSING(AO_xor);
-    x ^= 181;
-# endif
-# if defined(AO_HAVE_and_full)
-    AO_and_full(&x, 57);
-    TA_assert(x == 25);
-# else
-    MISSING(AO_and);
-    x &= 57;
-# endif
-# if defined(AO_HAVE_compare_double_and_swap_double_full)
-    TA_assert(!AO_compare_double_and_swap_double_full(&w, 17, 42, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_double_and_swap_double_full(&w, 0, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_double_and_swap_double_full(&w, 12, 13, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-    w.AO_val1 = 0; w.AO_val2 = 0;
-# else
-    MISSING(AO_compare_double_and_swap_double);
-# endif
-# if defined(AO_HAVE_compare_and_swap_double_full)
-    TA_assert(!AO_compare_and_swap_double_full(&w, 17, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_and_swap_double_full(&w, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_and_swap_double_full(&w, 12, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-# else
-    MISSING(AO_compare_and_swap_double);
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* Some basic sanity tests.  These do not test the barrier semantics. */
-
-#undef TA_assert
-#define TA_assert(e) \
-  if (!(e)) { fprintf(stderr, "Assertion failed %s:%d (barrier: _release_write)\n", \
-                    __FILE__, __LINE__), exit(1); }
-
-#undef MISSING
-#define MISSING(name) \
-  fprintf(stderr, "Missing: %s\n", #name "_release_write")
-
-void test_atomic_release_write(void)
-{
-  AO_t x;
-  unsigned char b;
-  unsigned short s;
-  unsigned int zz;
-# if defined(AO_HAVE_test_and_set_release_write)
-    AO_TS_t z = AO_TS_INITIALIZER;
-# endif
-# if defined(AO_HAVE_double_t)
-    AO_double_t w;
-    w.AO_val1 = 0;
-    w.AO_val2 = 0;
-# endif
-
-# if defined(AO_HAVE_nop_release_write)
-    AO_nop_release_write();
-# else
-    MISSING(AO_nop);
-# endif
-# if defined(AO_HAVE_store_release_write)
-    AO_store_release_write(&x, 13);
-    TA_assert (x == 13);
-# else
-    MISSING(AO_store);
-    x = 13;
-# endif
-# if defined(AO_HAVE_load_release_write)
-    TA_assert(AO_load_release_write(&x) == 13);
-# else
-    MISSING(AO_load);
-# endif
-# if defined(AO_HAVE_test_and_set_release_write)
-    assert(AO_test_and_set_release_write(&z) == AO_TS_CLEAR);
-    assert(AO_test_and_set_release_write(&z) == AO_TS_SET);
-    assert(AO_test_and_set_release_write(&z) == AO_TS_SET);
-    AO_CLEAR(&z);
-# else
-    MISSING(AO_test_and_set);
-# endif
-# if defined(AO_HAVE_fetch_and_add_release_write)
-    TA_assert(AO_fetch_and_add_release_write(&x, 42) == 13);
-    TA_assert(AO_fetch_and_add_release_write(&x, -42) == 55);
-# else
-    MISSING(AO_fetch_and_add);
-# endif
-# if defined(AO_HAVE_fetch_and_add1_release_write)
-    TA_assert(AO_fetch_and_add1_release_write(&x) == 13);
-# else
-    MISSING(AO_fetch_and_add1);
-    ++x;
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_release_write)
-    TA_assert(AO_fetch_and_sub1_release_write(&x) == 14);
-# else
-    MISSING(AO_fetch_and_sub1);
-    --x;
-# endif
-# if defined(AO_HAVE_short_store_release_write)
-    AO_short_store_release_write(&s, 13);
-# else
-    MISSING(AO_short_store);
-    s = 13;
-# endif
-# if defined(AO_HAVE_short_load_release_write)
-    TA_assert(AO_short_load(&s) == 13);
-# else
-    MISSING(AO_short_load);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add_release_write)
-    TA_assert(AO_short_fetch_and_add_release_write(&s, 42) == 13);
-    TA_assert(AO_short_fetch_and_add_release_write(&s, -42) == 55);
-# else
-    MISSING(AO_short_fetch_and_add);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add1_release_write)
-    TA_assert(AO_short_fetch_and_add1_release_write(&s) == 13);
-# else
-    MISSING(AO_short_fetch_and_add1);
-    ++s;
-# endif
-# if defined(AO_HAVE_short_fetch_and_sub1_release_write)
-    TA_assert(AO_short_fetch_and_sub1_release_write(&s) == 14);
-# else
-    MISSING(AO_short_fetch_and_sub1);
-    --s;
-# endif
-# if defined(AO_HAVE_char_store_release_write)
-    AO_char_store_release_write(&b, 13);
-# else
-    MISSING(AO_char_store);
-    b = 13;
-# endif
-# if defined(AO_HAVE_char_load_release_write)
-    TA_assert(AO_char_load(&b) == 13);
-# else
-    MISSING(AO_char_load);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add_release_write)
-    TA_assert(AO_char_fetch_and_add_release_write(&b, 42) == 13);
-    TA_assert(AO_char_fetch_and_add_release_write(&b, -42) == 55);
-# else
-    MISSING(AO_char_fetch_and_add);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add1_release_write)
-    TA_assert(AO_char_fetch_and_add1_release_write(&b) == 13);
-# else
-    MISSING(AO_char_fetch_and_add1);
-    ++b;
-# endif
-# if defined(AO_HAVE_char_fetch_and_sub1_release_write)
-    TA_assert(AO_char_fetch_and_sub1_release_write(&b) == 14);
-# else
-    MISSING(AO_char_fetch_and_sub1);
-    --b;
-# endif
-# if defined(AO_HAVE_int_store_release_write)
-    AO_int_store_release_write(&zz, 13);
-# else
-    MISSING(AO_int_store);
-    zz = 13;
-# endif
-# if defined(AO_HAVE_int_load_release_write)
-    TA_assert(AO_int_load(&zz) == 13);
-# else
-    MISSING(AO_int_load);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add_release_write)
-    TA_assert(AO_int_fetch_and_add_release_write(&zz, 42) == 13);
-    TA_assert(AO_int_fetch_and_add_release_write(&zz, -42) == 55);
-# else
-    MISSING(AO_int_fetch_and_add);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add1_release_write)
-    TA_assert(AO_int_fetch_and_add1_release_write(&zz) == 13);
-# else
-    MISSING(AO_int_fetch_and_add1);
-    ++zz;
-# endif
-# if defined(AO_HAVE_int_fetch_and_sub1_release_write)
-    TA_assert(AO_int_fetch_and_sub1_release_write(&zz) == 14);
-# else
-    MISSING(AO_int_fetch_and_sub1);
-    --zz;
-# endif
-# if defined(AO_HAVE_compare_and_swap_release_write)
-    TA_assert(!AO_compare_and_swap_release_write(&x, 14, 42));
-    TA_assert(x == 13);
-    TA_assert(AO_compare_and_swap_release_write(&x, 13, 42));
-    TA_assert(x == 42);
-# else
-    MISSING(AO_compare_and_swap);
-# endif
-# if defined(AO_HAVE_or_release_write)
-    AO_or_release_write(&x, 66);
-    TA_assert(x == 106);
-# else
-    MISSING(AO_or);
-    x |= 66;
-# endif
-# if defined(AO_HAVE_xor_release_write)
-    AO_xor_release_write(&x, 181);
-    TA_assert(x == 223);
-# else
-    MISSING(AO_xor);
-    x ^= 181;
-# endif
-# if defined(AO_HAVE_and_release_write)
-    AO_and_release_write(&x, 57);
-    TA_assert(x == 25);
-# else
-    MISSING(AO_and);
-    x &= 57;
-# endif
-# if defined(AO_HAVE_compare_double_and_swap_double_release_write)
-    TA_assert(!AO_compare_double_and_swap_double_release_write(&w, 17, 42, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_double_and_swap_double_release_write(&w, 0, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_double_and_swap_double_release_write(&w, 12, 13, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-    w.AO_val1 = 0; w.AO_val2 = 0;
-# else
-    MISSING(AO_compare_double_and_swap_double);
-# endif
-# if defined(AO_HAVE_compare_and_swap_double_release_write)
-    TA_assert(!AO_compare_and_swap_double_release_write(&w, 17, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_and_swap_double_release_write(&w, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_and_swap_double_release_write(&w, 12, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-# else
-    MISSING(AO_compare_and_swap_double);
-# endif
-}
-/*
- * Copyright (c) 2003 by Hewlett-Packard Company.  All rights reserved.
- *
- * This file is covered by the GNU general public license, version 2.
- * see COPYING for details.
- */
-
-/* Some basic sanity tests.  These do not test the barrier semantics. */
-
-#undef TA_assert
-#define TA_assert(e) \
-  if (!(e)) { fprintf(stderr, "Assertion failed %s:%d (barrier: _acquire_read)\n", \
-                    __FILE__, __LINE__), exit(1); }
-
-#undef MISSING
-#define MISSING(name) \
-  fprintf(stderr, "Missing: %s\n", #name "_acquire_read")
-
-void test_atomic_acquire_read(void)
-{
-  AO_t x;
-  unsigned char b;
-  unsigned short s;
-  unsigned int zz;
-# if defined(AO_HAVE_test_and_set_acquire_read)
-    AO_TS_t z = AO_TS_INITIALIZER;
-# endif
-# if defined(AO_HAVE_double_t)
-    AO_double_t w;
-    w.AO_val1 = 0;
-    w.AO_val2 = 0;
-# endif
-
-# if defined(AO_HAVE_nop_acquire_read)
-    AO_nop_acquire_read();
-# else
-    MISSING(AO_nop);
-# endif
-# if defined(AO_HAVE_store_acquire_read)
-    AO_store_acquire_read(&x, 13);
-    TA_assert (x == 13);
-# else
-    MISSING(AO_store);
-    x = 13;
-# endif
-# if defined(AO_HAVE_load_acquire_read)
-    TA_assert(AO_load_acquire_read(&x) == 13);
-# else
-    MISSING(AO_load);
-# endif
-# if defined(AO_HAVE_test_and_set_acquire_read)
-    assert(AO_test_and_set_acquire_read(&z) == AO_TS_CLEAR);
-    assert(AO_test_and_set_acquire_read(&z) == AO_TS_SET);
-    assert(AO_test_and_set_acquire_read(&z) == AO_TS_SET);
-    AO_CLEAR(&z);
-# else
-    MISSING(AO_test_and_set);
-# endif
-# if defined(AO_HAVE_fetch_and_add_acquire_read)
-    TA_assert(AO_fetch_and_add_acquire_read(&x, 42) == 13);
-    TA_assert(AO_fetch_and_add_acquire_read(&x, -42) == 55);
-# else
-    MISSING(AO_fetch_and_add);
-# endif
-# if defined(AO_HAVE_fetch_and_add1_acquire_read)
-    TA_assert(AO_fetch_and_add1_acquire_read(&x) == 13);
-# else
-    MISSING(AO_fetch_and_add1);
-    ++x;
-# endif
-# if defined(AO_HAVE_fetch_and_sub1_acquire_read)
-    TA_assert(AO_fetch_and_sub1_acquire_read(&x) == 14);
-# else
-    MISSING(AO_fetch_and_sub1);
-    --x;
-# endif
-# if defined(AO_HAVE_short_store_acquire_read)
-    AO_short_store_acquire_read(&s, 13);
-# else
-    MISSING(AO_short_store);
-    s = 13;
-# endif
-# if defined(AO_HAVE_short_load_acquire_read)
-    TA_assert(AO_short_load(&s) == 13);
-# else
-    MISSING(AO_short_load);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add_acquire_read)
-    TA_assert(AO_short_fetch_and_add_acquire_read(&s, 42) == 13);
-    TA_assert(AO_short_fetch_and_add_acquire_read(&s, -42) == 55);
-# else
-    MISSING(AO_short_fetch_and_add);
-# endif
-# if defined(AO_HAVE_short_fetch_and_add1_acquire_read)
-    TA_assert(AO_short_fetch_and_add1_acquire_read(&s) == 13);
-# else
-    MISSING(AO_short_fetch_and_add1);
-    ++s;
-# endif
-# if defined(AO_HAVE_short_fetch_and_sub1_acquire_read)
-    TA_assert(AO_short_fetch_and_sub1_acquire_read(&s) == 14);
-# else
-    MISSING(AO_short_fetch_and_sub1);
-    --s;
-# endif
-# if defined(AO_HAVE_char_store_acquire_read)
-    AO_char_store_acquire_read(&b, 13);
-# else
-    MISSING(AO_char_store);
-    b = 13;
-# endif
-# if defined(AO_HAVE_char_load_acquire_read)
-    TA_assert(AO_char_load(&b) == 13);
-# else
-    MISSING(AO_char_load);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add_acquire_read)
-    TA_assert(AO_char_fetch_and_add_acquire_read(&b, 42) == 13);
-    TA_assert(AO_char_fetch_and_add_acquire_read(&b, -42) == 55);
-# else
-    MISSING(AO_char_fetch_and_add);
-# endif
-# if defined(AO_HAVE_char_fetch_and_add1_acquire_read)
-    TA_assert(AO_char_fetch_and_add1_acquire_read(&b) == 13);
-# else
-    MISSING(AO_char_fetch_and_add1);
-    ++b;
-# endif
-# if defined(AO_HAVE_char_fetch_and_sub1_acquire_read)
-    TA_assert(AO_char_fetch_and_sub1_acquire_read(&b) == 14);
-# else
-    MISSING(AO_char_fetch_and_sub1);
-    --b;
-# endif
-# if defined(AO_HAVE_int_store_acquire_read)
-    AO_int_store_acquire_read(&zz, 13);
-# else
-    MISSING(AO_int_store);
-    zz = 13;
-# endif
-# if defined(AO_HAVE_int_load_acquire_read)
-    TA_assert(AO_int_load(&zz) == 13);
-# else
-    MISSING(AO_int_load);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add_acquire_read)
-    TA_assert(AO_int_fetch_and_add_acquire_read(&zz, 42) == 13);
-    TA_assert(AO_int_fetch_and_add_acquire_read(&zz, -42) == 55);
-# else
-    MISSING(AO_int_fetch_and_add);
-# endif
-# if defined(AO_HAVE_int_fetch_and_add1_acquire_read)
-    TA_assert(AO_int_fetch_and_add1_acquire_read(&zz) == 13);
-# else
-    MISSING(AO_int_fetch_and_add1);
-    ++zz;
-# endif
-# if defined(AO_HAVE_int_fetch_and_sub1_acquire_read)
-    TA_assert(AO_int_fetch_and_sub1_acquire_read(&zz) == 14);
-# else
-    MISSING(AO_int_fetch_and_sub1);
-    --zz;
-# endif
-# if defined(AO_HAVE_compare_and_swap_acquire_read)
-    TA_assert(!AO_compare_and_swap_acquire_read(&x, 14, 42));
-    TA_assert(x == 13);
-    TA_assert(AO_compare_and_swap_acquire_read(&x, 13, 42));
-    TA_assert(x == 42);
-# else
-    MISSING(AO_compare_and_swap);
-# endif
-# if defined(AO_HAVE_or_acquire_read)
-    AO_or_acquire_read(&x, 66);
-    TA_assert(x == 106);
-# else
-    MISSING(AO_or);
-    x |= 66;
-# endif
-# if defined(AO_HAVE_xor_acquire_read)
-    AO_xor_acquire_read(&x, 181);
-    TA_assert(x == 223);
-# else
-    MISSING(AO_xor);
-    x ^= 181;
-# endif
-# if defined(AO_HAVE_and_acquire_read)
-    AO_and_acquire_read(&x, 57);
-    TA_assert(x == 25);
-# else
-    MISSING(AO_and);
-    x &= 57;
-# endif
-# if defined(AO_HAVE_compare_double_and_swap_double_acquire_read)
-    TA_assert(!AO_compare_double_and_swap_double_acquire_read(&w, 17, 42, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_double_and_swap_double_acquire_read(&w, 0, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_double_and_swap_double_acquire_read(&w, 12, 13, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-    w.AO_val1 = 0; w.AO_val2 = 0;
-# else
-    MISSING(AO_compare_double_and_swap_double);
-# endif
-# if defined(AO_HAVE_compare_and_swap_double_acquire_read)
-    TA_assert(!AO_compare_and_swap_double_acquire_read(&w, 17, 12, 13));
-    TA_assert(w.AO_val1 == 0 && w.AO_val2 == 0);
-    TA_assert(AO_compare_and_swap_double_acquire_read(&w, 0, 12, 13));
-    TA_assert(w.AO_val1 == 12 && w.AO_val2 == 13);
-    TA_assert(AO_compare_and_swap_double_acquire_read(&w, 12, 17, 42));
-    TA_assert(w.AO_val1 == 17 && w.AO_val2 == 42);
-# else
-    MISSING(AO_compare_and_swap_double);
-# endif
-}