Module Name: src
Committed By: isaki
Date: Sun Feb 17 12:24:17 UTC 2019
Modified Files:
src/distrib/sets/lists/tests: mi
src/etc/mtree: NetBSD.dist.tests
src/tests/lib/libc: Makefile
Added Files:
src/tests/lib/libc/atomic: Makefile t_atomic_add.c t_atomic_and.c
t_atomic_cas.c t_atomic_dec.c t_atomic_inc.c t_atomic_or.c
t_atomic_swap.c
Log Message:
Add ATF tests for atomic_ops(3).
To generate a diff of this commit:
cvs rdiff -u -r1.806 -r1.807 src/distrib/sets/lists/tests/mi
cvs rdiff -u -r1.154 -r1.155 src/etc/mtree/NetBSD.dist.tests
cvs rdiff -u -r1.48 -r1.49 src/tests/lib/libc/Makefile
cvs rdiff -u -r0 -r1.1 src/tests/lib/libc/atomic/Makefile \
src/tests/lib/libc/atomic/t_atomic_add.c \
src/tests/lib/libc/atomic/t_atomic_and.c \
src/tests/lib/libc/atomic/t_atomic_cas.c \
src/tests/lib/libc/atomic/t_atomic_dec.c \
src/tests/lib/libc/atomic/t_atomic_inc.c \
src/tests/lib/libc/atomic/t_atomic_or.c \
src/tests/lib/libc/atomic/t_atomic_swap.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/distrib/sets/lists/tests/mi
diff -u src/distrib/sets/lists/tests/mi:1.806 src/distrib/sets/lists/tests/mi:1.807
--- src/distrib/sets/lists/tests/mi:1.806 Sat Feb 9 00:14:43 2019
+++ src/distrib/sets/lists/tests/mi Sun Feb 17 12:24:17 2019
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.806 2019/02/09 00:14:43 mrg Exp $
+# $NetBSD: mi,v 1.807 2019/02/17 12:24:17 isaki Exp $
#
# Note: don't delete entries from here - mark them as "obsolete" instead.
#
@@ -2442,6 +2442,15 @@
./usr/tests/lib/libc tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/Atffile tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/Kyuafile tests-lib-tests compattestfile,atf,kyua
+./usr/tests/lib/libc/atomic tests-lib-tests compattestfile,atf
+./usr/tests/lib/libc/atomic/Atffile tests-lib-tests compattestfile,atf
+./usr/tests/lib/libc/atomic/t_atomic_add tests-lib-tests compattestfile,atf
+./usr/tests/lib/libc/atomic/t_atomic_and tests-lib-tests compattestfile,atf
+./usr/tests/lib/libc/atomic/t_atomic_cas tests-lib-tests compattestfile,atf
+./usr/tests/lib/libc/atomic/t_atomic_dec tests-lib-tests compattestfile,atf
+./usr/tests/lib/libc/atomic/t_atomic_inc tests-lib-tests compattestfile,atf
+./usr/tests/lib/libc/atomic/t_atomic_or tests-lib-tests compattestfile,atf
+./usr/tests/lib/libc/atomic/t_atomic_swap tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/c063 tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/c063/Atffile tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/c063/Kyuafile tests-lib-tests compattestfile,atf,kyua
Index: src/etc/mtree/NetBSD.dist.tests
diff -u src/etc/mtree/NetBSD.dist.tests:1.154 src/etc/mtree/NetBSD.dist.tests:1.155
--- src/etc/mtree/NetBSD.dist.tests:1.154 Sun Dec 23 15:43:42 2018
+++ src/etc/mtree/NetBSD.dist.tests Sun Feb 17 12:24:17 2019
@@ -1,4 +1,4 @@
-# $NetBSD: NetBSD.dist.tests,v 1.154 2018/12/23 15:43:42 jakllsch Exp $
+# $NetBSD: NetBSD.dist.tests,v 1.155 2019/02/17 12:24:17 isaki Exp $
./usr/libdata/debug/usr/tests
./usr/libdata/debug/usr/tests/atf
@@ -259,6 +259,7 @@
./usr/tests/lib/csu
./usr/tests/lib/libbluetooth
./usr/tests/lib/libc
+./usr/tests/lib/libc/atomic
./usr/tests/lib/libc/c063
./usr/tests/lib/libc/db
./usr/tests/lib/libc/gen
Index: src/tests/lib/libc/Makefile
diff -u src/tests/lib/libc/Makefile:1.48 src/tests/lib/libc/Makefile:1.49
--- src/tests/lib/libc/Makefile:1.48 Fri Aug 3 04:24:41 2018
+++ src/tests/lib/libc/Makefile Sun Feb 17 12:24:17 2019
@@ -1,10 +1,11 @@
-# $NetBSD: Makefile,v 1.48 2018/08/03 04:24:41 kamil Exp $
+# $NetBSD: Makefile,v 1.49 2019/02/17 12:24:17 isaki Exp $
.include "Makefile.inc"
.include <bsd.own.mk>
SUBDIR+= tls_dso .WAIT sync
+TESTS_SUBDIRS+= atomic
TESTS_SUBDIRS+= c063 db gen hash inet locale misc net regex rpc setjmp stdlib
TESTS_SUBDIRS+= stdio string sys termios time tls ttyio
Added files:
Index: src/tests/lib/libc/atomic/Makefile
diff -u /dev/null src/tests/lib/libc/atomic/Makefile:1.1
--- /dev/null Sun Feb 17 12:24:17 2019
+++ src/tests/lib/libc/atomic/Makefile Sun Feb 17 12:24:17 2019
@@ -0,0 +1,19 @@
+# $NetBSD: Makefile,v 1.1 2019/02/17 12:24:17 isaki Exp $
+
+.include <bsd.own.mk>
+
+TESTSDIR= ${TESTSBASE}/lib/libc/atomic
+
+TESTS_C+= t_atomic_add
+TESTS_C+= t_atomic_and
+TESTS_C+= t_atomic_cas
+TESTS_C+= t_atomic_dec
+TESTS_C+= t_atomic_inc
+TESTS_C+= t_atomic_or
+TESTS_C+= t_atomic_swap
+
+MKMAN=no
+
+BINDIR= ${TESTSDIR}
+
+.include <bsd.test.mk>
Index: src/tests/lib/libc/atomic/t_atomic_add.c
diff -u /dev/null src/tests/lib/libc/atomic/t_atomic_add.c:1.1
--- /dev/null Sun Feb 17 12:24:17 2019
+++ src/tests/lib/libc/atomic/t_atomic_add.c Sun Feb 17 12:24:17 2019
@@ -0,0 +1,125 @@
+/* $NetBSD: t_atomic_add.c,v 1.1 2019/02/17 12:24:17 isaki Exp $ */
+
+/*
+ * Copyright (C) 2019 Tetsuya Isaki. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: t_atomic_add.c,v 1.1 2019/02/17 12:24:17 isaki Exp $");
+
+#include <atf-c.h>
+#include <inttypes.h>
+#include <sys/atomic.h>
+
+/*
+ * These tests don't examine the atomicity.
+ */
+
+#define DST (0x1122334455667788UL)
+#define SRC (0xf0e0d0c0b0a09081UL)
+#define EXPECT (0x0203040506070809UL)
+
+/*
+ * atomic_add_*()
+ */
+#define atf_add(NAME, DTYPE, STYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile DTYPE val; \
+ STYPE src; \
+ DTYPE exp; \
+ val = (DTYPE)DST; \
+ src = (STYPE)SRC; \
+ exp = (DTYPE)EXPECT; \
+ NAME(&val, src); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects " FMT " but " FMT, exp, val); \
+}
+
+atf_add(atomic_add_32, uint32_t, int32_t, "0x%" PRIx32);
+atf_add(atomic_add_int, unsigned int, int, "0x%x");
+atf_add(atomic_add_long, unsigned long, long, "0x%lx");
+atf_add(atomic_add_ptr, void *, ssize_t, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_add(atomic_add_64, uint64_t, int64_t, "0x%" PRIx64);
+#endif
+
+/*
+ * atomic_add_*_nv()
+ */
+#define atf_add_nv(NAME, DTYPE, STYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile DTYPE val; \
+ STYPE src; \
+ DTYPE res; \
+ DTYPE exp; \
+ val = (DTYPE)DST; \
+ src = (STYPE)SRC; \
+ exp = (DTYPE)EXPECT; \
+ res = NAME(&val, src); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects " FMT " but " FMT, exp, val); \
+ ATF_REQUIRE_MSG(res == exp, \
+ "res expects " FMT " but " FMT, exp, res); \
+}
+
+atf_add_nv(atomic_add_32_nv, uint32_t, int32_t, "0x%" PRIx32);
+atf_add_nv(atomic_add_int_nv, unsigned int, int, "0x%x");
+atf_add_nv(atomic_add_long_nv, unsigned long, long, "0x%lx");
+atf_add_nv(atomic_add_ptr_nv, void *, ssize_t, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_add_nv(atomic_add_64_nv, uint64_t, int64_t, "0x%" PRIx64);
+#endif
+
+ATF_TP_ADD_TCS(tp)
+{
+ ATF_TP_ADD_TC(tp, atomic_add_32);
+ ATF_TP_ADD_TC(tp, atomic_add_int);
+ ATF_TP_ADD_TC(tp, atomic_add_long);
+ ATF_TP_ADD_TC(tp, atomic_add_ptr);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_add_64);
+#endif
+
+ ATF_TP_ADD_TC(tp, atomic_add_32_nv);
+ ATF_TP_ADD_TC(tp, atomic_add_int_nv);
+ ATF_TP_ADD_TC(tp, atomic_add_long_nv);
+ ATF_TP_ADD_TC(tp, atomic_add_ptr_nv);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_add_64_nv);
+#endif
+
+ return atf_no_error();
+}
Index: src/tests/lib/libc/atomic/t_atomic_and.c
diff -u /dev/null src/tests/lib/libc/atomic/t_atomic_and.c:1.1
--- /dev/null Sun Feb 17 12:24:17 2019
+++ src/tests/lib/libc/atomic/t_atomic_and.c Sun Feb 17 12:24:17 2019
@@ -0,0 +1,121 @@
+/* $NetBSD: t_atomic_and.c,v 1.1 2019/02/17 12:24:17 isaki Exp $ */
+
+/*
+ * Copyright (C) 2019 Tetsuya Isaki. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: t_atomic_and.c,v 1.1 2019/02/17 12:24:17 isaki Exp $");
+
+#include <atf-c.h>
+#include <inttypes.h>
+#include <sys/atomic.h>
+
+/*
+ * These tests don't examine the atomicity.
+ */
+
+#define DST (0x1122334455667788UL)
+#define SRC (0xf0f0f0f0f0f0f0f0UL)
+#define EXPECT (0x1020304050607080UL)
+
+/*
+ * atomic_and_*()
+ */
+#define atf_and(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE src; \
+ TYPE exp; \
+ val = (TYPE)DST; \
+ src = (TYPE)SRC; \
+ exp = (TYPE)EXPECT; \
+ NAME(&val, src); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects 0x%" FMT " but 0x%" FMT, exp, val); \
+}
+
+atf_and(atomic_and_32, uint32_t, PRIx32);
+atf_and(atomic_and_uint, unsigned int, "x");
+atf_and(atomic_and_ulong, unsigned long, "lx");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_and(atomic_and_64, uint64_t, PRIx64);
+#endif
+
+/*
+ * atomic_and_*_nv()
+ */
+#define atf_and_nv(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE src; \
+ TYPE res; \
+ TYPE exp; \
+ val = (TYPE)DST; \
+ src = (TYPE)SRC; \
+ exp = (TYPE)EXPECT; \
+ res = NAME(&val, src); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects 0x%" FMT " but 0x%" FMT, exp, val); \
+ ATF_REQUIRE_MSG(res == exp, \
+ "res expects 0x%" FMT " but 0x%" FMT, exp, res); \
+}
+
+atf_and_nv(atomic_and_32_nv, uint32_t, PRIx32);
+atf_and_nv(atomic_and_uint_nv, unsigned int, "x");
+atf_and_nv(atomic_and_ulong_nv, unsigned long, "lx");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_and_nv(atomic_and_64_nv, uint64_t, PRIx64);
+#endif
+
+ATF_TP_ADD_TCS(tp)
+{
+ ATF_TP_ADD_TC(tp, atomic_and_32);
+ ATF_TP_ADD_TC(tp, atomic_and_uint);
+ ATF_TP_ADD_TC(tp, atomic_and_ulong);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_and_64);
+#endif
+
+ ATF_TP_ADD_TC(tp, atomic_and_32_nv);
+ ATF_TP_ADD_TC(tp, atomic_and_uint_nv);
+ ATF_TP_ADD_TC(tp, atomic_and_ulong_nv);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_and_64_nv);
+#endif
+
+ return atf_no_error();
+}
Index: src/tests/lib/libc/atomic/t_atomic_cas.c
diff -u /dev/null src/tests/lib/libc/atomic/t_atomic_cas.c:1.1
--- /dev/null Sun Feb 17 12:24:17 2019
+++ src/tests/lib/libc/atomic/t_atomic_cas.c Sun Feb 17 12:24:17 2019
@@ -0,0 +1,118 @@
+/* $NetBSD: t_atomic_cas.c,v 1.1 2019/02/17 12:24:17 isaki Exp $ */
+
+/*
+ * Copyright (C) 2019 Tetsuya Isaki. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: t_atomic_cas.c,v 1.1 2019/02/17 12:24:17 isaki Exp $");
+
+#include <atf-c.h>
+#include <inttypes.h>
+#include <sys/atomic.h>
+
+/*
+ * These tests don't examine the atomicity.
+ */
+
+#define OLDVAL (0x1122334455667788UL)
+#define NEWVAL (0x8090a0b0c0d0e0f0UL)
+
+/*
+ * atomic_cas_*{,_ni}()
+ */
+#define atf_cas(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE oldval; \
+ TYPE newval; \
+ TYPE expval; \
+ TYPE expres; \
+ TYPE res; \
+ /* If successful */ \
+ val = (TYPE)OLDVAL; \
+ oldval = (TYPE)OLDVAL; \
+ newval = (TYPE)NEWVAL; \
+ expval = (TYPE)NEWVAL; \
+ expres = (TYPE)OLDVAL; \
+ res = NAME(&val, oldval, newval); \
+ ATF_REQUIRE_MSG(val == expval, \
+ "successful case: val expects " FMT " but " FMT, expval, val); \
+ ATF_REQUIRE_MSG(res == expres, \
+ "successful case: res expects " FMT " but " FMT, expres, res); \
+ /* If failure */ \
+ val = (TYPE)OLDVAL; \
+ oldval = (TYPE)(OLDVAL + 1); \
+ newval = (TYPE)NEWVAL; \
+ expval = (TYPE)OLDVAL; \
+ expres = (TYPE)OLDVAL; \
+ res = NAME(&val, oldval, newval); \
+ ATF_REQUIRE_MSG(val == expval, \
+ "failure case: val expects " FMT " but " FMT, expval, val); \
+ ATF_REQUIRE_MSG(res == expres, \
+ "failure case: res expects " FMT " but " FMT, expres, res); \
+}
+
+atf_cas(atomic_cas_32, uint32_t, "0x%" PRIx32);
+atf_cas(atomic_cas_uint, unsigned int, "0x%x");
+atf_cas(atomic_cas_ulong, unsigned long, "0x%lx");
+atf_cas(atomic_cas_ptr, void *, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_cas(atomic_cas_64, uint64_t, "0x%" PRIx64);
+#endif
+
+atf_cas(atomic_cas_32_ni, uint32_t, "0x%" PRIx32);
+atf_cas(atomic_cas_uint_ni, unsigned int, "0x%x");
+atf_cas(atomic_cas_ulong_ni, unsigned long, "0x%lx");
+atf_cas(atomic_cas_ptr_ni, void *, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_cas(atomic_cas_64_ni, uint64_t, "0x%" PRIx64);
+#endif
+
+ATF_TP_ADD_TCS(tp)
+{
+ ATF_TP_ADD_TC(tp, atomic_cas_32);
+ ATF_TP_ADD_TC(tp, atomic_cas_uint);
+ ATF_TP_ADD_TC(tp, atomic_cas_ulong);
+ ATF_TP_ADD_TC(tp, atomic_cas_ptr);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_cas_64);
+#endif
+
+ ATF_TP_ADD_TC(tp, atomic_cas_32_ni);
+ ATF_TP_ADD_TC(tp, atomic_cas_uint_ni);
+ ATF_TP_ADD_TC(tp, atomic_cas_ulong_ni);
+ ATF_TP_ADD_TC(tp, atomic_cas_ptr_ni);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_cas_64_ni);
+#endif
+
+ return atf_no_error();
+}
Index: src/tests/lib/libc/atomic/t_atomic_dec.c
diff -u /dev/null src/tests/lib/libc/atomic/t_atomic_dec.c:1.1
--- /dev/null Sun Feb 17 12:24:17 2019
+++ src/tests/lib/libc/atomic/t_atomic_dec.c Sun Feb 17 12:24:17 2019
@@ -0,0 +1,120 @@
+/* $NetBSD: t_atomic_dec.c,v 1.1 2019/02/17 12:24:17 isaki Exp $ */
+
+/*
+ * Copyright (C) 2019 Tetsuya Isaki. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: t_atomic_dec.c,v 1.1 2019/02/17 12:24:17 isaki Exp $");
+
+#include <atf-c.h>
+#include <inttypes.h>
+#include <sys/atomic.h>
+
+/*
+ * These tests don't examine the atomicity.
+ */
+
+#define VAL (0x1122334455667788UL)
+#define EXPECT (0x1122334455667787UL)
+
+/*
+ * atomic_dec_*()
+ */
+#define atf_dec(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE exp; \
+ val = (TYPE)VAL; \
+ exp = (TYPE)EXPECT; \
+ NAME(&val); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects " FMT " but " FMT, exp, val); \
+}
+
+atf_dec(atomic_dec_32, uint32_t, "0x%" PRIx32);
+atf_dec(atomic_dec_uint, unsigned int, "0x%x");
+atf_dec(atomic_dec_ulong, unsigned long, "0x%lx");
+atf_dec(atomic_dec_ptr, void *, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_dec(atomic_dec_64, uint64_t, "0x%" PRIx64);
+#endif
+
+/*
+ * atomic_dec_*_nv()
+ */
+#define atf_dec_nv(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE res; \
+ TYPE exp; \
+ val = (TYPE)VAL; \
+ exp = (TYPE)EXPECT; \
+ res = NAME(&val); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects " FMT " but " FMT, exp, val); \
+ ATF_REQUIRE_MSG(res == exp, \
+ "res expects " FMT " but " FMT, exp, res); \
+}
+
+atf_dec_nv(atomic_dec_32_nv, uint32_t, "0x%" PRIx32);
+atf_dec_nv(atomic_dec_uint_nv, unsigned int, "0x%x");
+atf_dec_nv(atomic_dec_ulong_nv, unsigned long, "0x%lx");
+atf_dec_nv(atomic_dec_ptr_nv, void *, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_dec_nv(atomic_dec_64_nv, uint64_t, "0x%" PRIx64);
+#endif
+
+ATF_TP_ADD_TCS(tp)
+{
+ ATF_TP_ADD_TC(tp, atomic_dec_32);
+ ATF_TP_ADD_TC(tp, atomic_dec_uint);
+ ATF_TP_ADD_TC(tp, atomic_dec_ulong);
+ ATF_TP_ADD_TC(tp, atomic_dec_ptr);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_dec_64);
+#endif
+
+ ATF_TP_ADD_TC(tp, atomic_dec_32_nv);
+ ATF_TP_ADD_TC(tp, atomic_dec_uint_nv);
+ ATF_TP_ADD_TC(tp, atomic_dec_ulong_nv);
+ ATF_TP_ADD_TC(tp, atomic_dec_ptr_nv);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_dec_64_nv);
+#endif
+
+ return atf_no_error();
+}
Index: src/tests/lib/libc/atomic/t_atomic_inc.c
diff -u /dev/null src/tests/lib/libc/atomic/t_atomic_inc.c:1.1
--- /dev/null Sun Feb 17 12:24:17 2019
+++ src/tests/lib/libc/atomic/t_atomic_inc.c Sun Feb 17 12:24:17 2019
@@ -0,0 +1,120 @@
+/* $NetBSD: t_atomic_inc.c,v 1.1 2019/02/17 12:24:17 isaki Exp $ */
+
+/*
+ * Copyright (C) 2019 Tetsuya Isaki. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: t_atomic_inc.c,v 1.1 2019/02/17 12:24:17 isaki Exp $");
+
+#include <atf-c.h>
+#include <inttypes.h>
+#include <sys/atomic.h>
+
+/*
+ * These tests don't examine the atomicity.
+ */
+
+#define VAL (0x1122334455667788UL)
+#define EXPECT (0x1122334455667789UL)
+
+/*
+ * atomic_inc_*()
+ */
+#define atf_inc(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE exp; \
+ val = (TYPE)VAL; \
+ exp = (TYPE)EXPECT; \
+ NAME(&val); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects " FMT " but " FMT, exp, val); \
+}
+
+atf_inc(atomic_inc_32, uint32_t, "0x%" PRIx32);
+atf_inc(atomic_inc_uint, unsigned int, "0x%x");
+atf_inc(atomic_inc_ulong, unsigned long, "0x%lx");
+atf_inc(atomic_inc_ptr, void *, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_inc(atomic_inc_64, uint64_t, "0x%" PRIx64);
+#endif
+
+/*
+ * atomic_inc_*_nv()
+ */
+#define atf_inc_nv(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE res; \
+ TYPE exp; \
+ val = (TYPE)VAL; \
+ exp = (TYPE)EXPECT; \
+ res = NAME(&val); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects " FMT " but " FMT, exp, val); \
+ ATF_REQUIRE_MSG(res == exp, \
+ "res expects " FMT " but " FMT, exp, res); \
+}
+
+atf_inc_nv(atomic_inc_32_nv, uint32_t, "0x%" PRIx32);
+atf_inc_nv(atomic_inc_uint_nv, unsigned int, "0x%x");
+atf_inc_nv(atomic_inc_ulong_nv, unsigned long, "0x%lx");
+atf_inc_nv(atomic_inc_ptr_nv, void *, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_inc_nv(atomic_inc_64_nv, uint64_t, "0x%" PRIx64);
+#endif
+
+ATF_TP_ADD_TCS(tp)
+{
+ ATF_TP_ADD_TC(tp, atomic_inc_32);
+ ATF_TP_ADD_TC(tp, atomic_inc_uint);
+ ATF_TP_ADD_TC(tp, atomic_inc_ulong);
+ ATF_TP_ADD_TC(tp, atomic_inc_ptr);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_inc_64);
+#endif
+
+ ATF_TP_ADD_TC(tp, atomic_inc_32_nv);
+ ATF_TP_ADD_TC(tp, atomic_inc_uint_nv);
+ ATF_TP_ADD_TC(tp, atomic_inc_ulong_nv);
+ ATF_TP_ADD_TC(tp, atomic_inc_ptr_nv);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_inc_64_nv);
+#endif
+
+ return atf_no_error();
+}
Index: src/tests/lib/libc/atomic/t_atomic_or.c
diff -u /dev/null src/tests/lib/libc/atomic/t_atomic_or.c:1.1
--- /dev/null Sun Feb 17 12:24:17 2019
+++ src/tests/lib/libc/atomic/t_atomic_or.c Sun Feb 17 12:24:17 2019
@@ -0,0 +1,121 @@
+/* $NetBSD: t_atomic_or.c,v 1.1 2019/02/17 12:24:17 isaki Exp $ */
+
+/*
+ * Copyright (C) 2019 Tetsuya Isaki. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: t_atomic_or.c,v 1.1 2019/02/17 12:24:17 isaki Exp $");
+
+#include <atf-c.h>
+#include <inttypes.h>
+#include <sys/atomic.h>
+
+/*
+ * These tests don't examine the atomicity.
+ */
+
+#define DST (0x1122334455667788UL)
+#define SRC (0xf0f0f0f0f0f0f0f0UL)
+#define EXPECT (0xf1f2f3f4f5f6f7f8UL)
+
+/*
+ * atomic_or_*()
+ */
+#define atf_or(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE src; \
+ TYPE exp; \
+ val = (TYPE)DST; \
+ src = (TYPE)SRC; \
+ exp = (TYPE)EXPECT; \
+ NAME(&val, src); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects 0x%" FMT " but 0x%" FMT, exp, val); \
+}
+
+atf_or(atomic_or_32, uint32_t, PRIx32);
+atf_or(atomic_or_uint, unsigned int, "x");
+atf_or(atomic_or_ulong, unsigned long, "lx");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_or(atomic_or_64, uint64_t, PRIx64);
+#endif
+
+/*
+ * atomic_or_*_nv()
+ */
+#define atf_or_nv(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE src; \
+ TYPE res; \
+ TYPE exp; \
+ val = (TYPE)DST; \
+ src = (TYPE)SRC; \
+ exp = (TYPE)EXPECT; \
+ res = NAME(&val, src); \
+ ATF_REQUIRE_MSG(val == exp, \
+ "val expects 0x%" FMT " but 0x%" FMT, exp, val); \
+ ATF_REQUIRE_MSG(res == exp, \
+ "res expects 0x%" FMT " but 0x%" FMT, exp, res); \
+}
+
+atf_or_nv(atomic_or_32_nv, uint32_t, PRIx32);
+atf_or_nv(atomic_or_uint_nv, unsigned int, "x");
+atf_or_nv(atomic_or_ulong_nv, unsigned long, "lx");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_or_nv(atomic_or_64_nv, uint64_t, PRIx64);
+#endif
+
+ATF_TP_ADD_TCS(tp)
+{
+ ATF_TP_ADD_TC(tp, atomic_or_32);
+ ATF_TP_ADD_TC(tp, atomic_or_uint);
+ ATF_TP_ADD_TC(tp, atomic_or_ulong);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_or_64);
+#endif
+
+ ATF_TP_ADD_TC(tp, atomic_or_32_nv);
+ ATF_TP_ADD_TC(tp, atomic_or_uint_nv);
+ ATF_TP_ADD_TC(tp, atomic_or_ulong_nv);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_or_64_nv);
+#endif
+
+ return atf_no_error();
+}
Index: src/tests/lib/libc/atomic/t_atomic_swap.c
diff -u /dev/null src/tests/lib/libc/atomic/t_atomic_swap.c:1.1
--- /dev/null Sun Feb 17 12:24:17 2019
+++ src/tests/lib/libc/atomic/t_atomic_swap.c Sun Feb 17 12:24:17 2019
@@ -0,0 +1,88 @@
+/* $NetBSD: t_atomic_swap.c,v 1.1 2019/02/17 12:24:17 isaki Exp $ */
+
+/*
+ * Copyright (C) 2019 Tetsuya Isaki. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: t_atomic_swap.c,v 1.1 2019/02/17 12:24:17 isaki Exp $");
+
+#include <atf-c.h>
+#include <inttypes.h>
+#include <sys/atomic.h>
+
+/*
+ * These tests don't examine the atomicity.
+ */
+
+#define OLDVAL (0x1122334455667788UL)
+#define NEWVAL (0x8090a0b0c0d0e0f0UL)
+
+/*
+ * atomic_swap_*()
+ */
+#define atf_swap(NAME, TYPE, FMT) \
+ATF_TC(NAME); \
+ATF_TC_HEAD(NAME, tc) \
+{ \
+ atf_tc_set_md_var(tc, "descr", #NAME); \
+} \
+ATF_TC_BODY(NAME, tc) \
+{ \
+ volatile TYPE val; \
+ TYPE newval; \
+ TYPE expval; \
+ TYPE expres; \
+ TYPE res; \
+ val = (TYPE)OLDVAL; \
+ newval = (TYPE)NEWVAL; \
+ expval = (TYPE)NEWVAL; \
+ expres = (TYPE)OLDVAL; \
+ res = NAME(&val, newval); \
+ ATF_REQUIRE_MSG(val == expval, \
+ "val expects " FMT " but " FMT, expval, val); \
+ ATF_REQUIRE_MSG(res == expres, \
+ "res expects " FMT " but " FMT, expres, res); \
+}
+
+atf_swap(atomic_swap_32, uint32_t, "0x%" PRIx32);
+atf_swap(atomic_swap_uint, unsigned int, "0x%x");
+atf_swap(atomic_swap_ulong, unsigned long, "0x%lx");
+atf_swap(atomic_swap_ptr, void *, "%p");
+#if defined(__HAVE_ATOMIC64_OPS)
+atf_swap(atomic_swap_64, uint64_t, "0x%" PRIx64);
+#endif
+
+ATF_TP_ADD_TCS(tp)
+{
+ ATF_TP_ADD_TC(tp, atomic_swap_32);
+ ATF_TP_ADD_TC(tp, atomic_swap_uint);
+ ATF_TP_ADD_TC(tp, atomic_swap_ulong);
+ ATF_TP_ADD_TC(tp, atomic_swap_ptr);
+#if defined(__HAVE_ATOMIC64_OPS)
+ ATF_TP_ADD_TC(tp, atomic_swap_64);
+#endif
+
+ return atf_no_error();
+}