CVS commit: src/tests/lib/libc/membar

2022-08-12 Thread Taylor R Campbell
Module Name:src
Committed By:   riastradh
Date:   Fri Aug 12 11:21:44 UTC 2022

Modified Files:
src/tests/lib/libc/membar: t_spinlock.c

Log Message:
membar(3): Fix t_spinlock for machines with hash-locked atomics.

Regular stores don't participate in the hash-locking scheme, so use
atomic_swap instead of a regular store here.


To generate a diff of this commit:
cvs rdiff -u -r1.3 -r1.4 src/tests/lib/libc/membar/t_spinlock.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.



CVS commit: src/tests/lib/libc/membar

2022-08-12 Thread Taylor R Campbell
Module Name:src
Committed By:   riastradh
Date:   Fri Aug 12 11:21:44 UTC 2022

Modified Files:
src/tests/lib/libc/membar: t_spinlock.c

Log Message:
membar(3): Fix t_spinlock for machines with hash-locked atomics.

Regular stores don't participate in the hash-locking scheme, so use
atomic_swap instead of a regular store here.


To generate a diff of this commit:
cvs rdiff -u -r1.3 -r1.4 src/tests/lib/libc/membar/t_spinlock.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/tests/lib/libc/membar/t_spinlock.c
diff -u src/tests/lib/libc/membar/t_spinlock.c:1.3 src/tests/lib/libc/membar/t_spinlock.c:1.4
--- src/tests/lib/libc/membar/t_spinlock.c:1.3	Sun Apr 10 11:36:32 2022
+++ src/tests/lib/libc/membar/t_spinlock.c	Fri Aug 12 11:21:44 2022
@@ -1,4 +1,4 @@
-/*	$NetBSD: t_spinlock.c,v 1.3 2022/04/10 11:36:32 riastradh Exp $	*/
+/*	$NetBSD: t_spinlock.c,v 1.4 2022/08/12 11:21:44 riastradh Exp $	*/
 
 /*-
  * Copyright (c) 2022 The NetBSD Foundation, Inc.
@@ -27,7 +27,9 @@
  */
 
 #include 
-__RCSID("$NetBSD: t_spinlock.c,v 1.3 2022/04/10 11:36:32 riastradh Exp $");
+__RCSID("$NetBSD: t_spinlock.c,v 1.4 2022/08/12 11:21:44 riastradh Exp $");
+
+#include 
 
 #include 
 #include 
@@ -76,7 +78,11 @@ unlock(void)
 {
 
 	membar_release();
+#ifdef __HAVE_HASHLOCKED_ATOMICS
+	(void)atomic_cas_uint(, 1, 0);
+#else
 	lockbit = 0;
+#endif
 }
 
 static void *



CVS commit: src/tests/lib/libc/membar

2022-04-10 Thread Taylor R Campbell
Module Name:src
Committed By:   riastradh
Date:   Sun Apr 10 11:36:32 UTC 2022

Modified Files:
src/tests/lib/libc/membar: t_dekker.c t_seqlock.c t_spinlock.c

Log Message:
membar_ops(3): Simplify alarm handling in membar tests.


To generate a diff of this commit:
cvs rdiff -u -r1.2 -r1.3 src/tests/lib/libc/membar/t_dekker.c \
src/tests/lib/libc/membar/t_spinlock.c
cvs rdiff -u -r1.1 -r1.2 src/tests/lib/libc/membar/t_seqlock.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/tests/lib/libc/membar/t_dekker.c
diff -u src/tests/lib/libc/membar/t_dekker.c:1.2 src/tests/lib/libc/membar/t_dekker.c:1.3
--- src/tests/lib/libc/membar/t_dekker.c:1.2	Sat Apr  9 23:32:53 2022
+++ src/tests/lib/libc/membar/t_dekker.c	Sun Apr 10 11:36:32 2022
@@ -1,4 +1,4 @@
-/*	$NetBSD: t_dekker.c,v 1.2 2022/04/09 23:32:53 riastradh Exp $	*/
+/*	$NetBSD: t_dekker.c,v 1.3 2022/04/10 11:36:32 riastradh Exp $	*/
 
 /*-
  * Copyright (c) 2022 The NetBSD Foundation, Inc.
@@ -27,7 +27,7 @@
  */
 
 #include 
-__RCSID("$NetBSD: t_dekker.c,v 1.2 2022/04/09 23:32:53 riastradh Exp $");
+__RCSID("$NetBSD: t_dekker.c,v 1.3 2022/04/10 11:36:32 riastradh Exp $");
 
 #include 
 #include 
@@ -39,7 +39,6 @@ __RCSID("$NetBSD: t_dekker.c,v 1.2 2022/
 #include 
 #include 
 #include 
-#include 
 #include 
 #include 
 #include 
@@ -95,14 +94,6 @@ unlock(unsigned me)
 	membar_producer();
 }
 
-static void
-alarm_handler(int signo)
-{
-
-	(void)signo;
-	times_up = 1;
-}
-
 static void *
 thread(void *cookie)
 {
@@ -135,21 +126,22 @@ ATF_TC_BODY(dekker, tc)
 	size_t ncpulen = sizeof(ncpu);
 	int error;
 
+	alarm(10);
+
 	if (sysctlbyname("hw.ncpu", , , NULL, 0) == -1)
 		atf_tc_fail("hw.ncpu: (%d) %s", errno, strerror(errno));
 	assert(ncpulen == sizeof(ncpu));
 	if (ncpu == 1)
 		atf_tc_skip("membar tests are only for multicore systems");
 
-	if (signal(SIGALRM, alarm_handler) == SIG_ERR)
-		err(1, "signal(SIGALRM");
-	alarm(5);
 	for (i = 0; i < 2; i++) {
 		error = pthread_create([i], NULL, ,
 		(void *)(uintptr_t)i);
 		if (error)
 			errc(1, error, "pthread_create");
 	}
+	sleep(5);
+	times_up = 1;
 	for (i = 0; i < 2; i++) {
 		error = pthread_join(t[i], NULL);
 		if (error)
Index: src/tests/lib/libc/membar/t_spinlock.c
diff -u src/tests/lib/libc/membar/t_spinlock.c:1.2 src/tests/lib/libc/membar/t_spinlock.c:1.3
--- src/tests/lib/libc/membar/t_spinlock.c:1.2	Sat Apr  9 23:32:53 2022
+++ src/tests/lib/libc/membar/t_spinlock.c	Sun Apr 10 11:36:32 2022
@@ -1,4 +1,4 @@
-/*	$NetBSD: t_spinlock.c,v 1.2 2022/04/09 23:32:53 riastradh Exp $	*/
+/*	$NetBSD: t_spinlock.c,v 1.3 2022/04/10 11:36:32 riastradh Exp $	*/
 
 /*-
  * Copyright (c) 2022 The NetBSD Foundation, Inc.
@@ -27,7 +27,7 @@
  */
 
 #include 
-__RCSID("$NetBSD: t_spinlock.c,v 1.2 2022/04/09 23:32:53 riastradh Exp $");
+__RCSID("$NetBSD: t_spinlock.c,v 1.3 2022/04/10 11:36:32 riastradh Exp $");
 
 #include 
 #include 
@@ -39,7 +39,6 @@ __RCSID("$NetBSD: t_spinlock.c,v 1.2 202
 #include 
 #include 
 #include 
-#include 
 #include 
 #include 
 #include 
@@ -80,14 +79,6 @@ unlock(void)
 	lockbit = 0;
 }
 
-static void
-alarm_handler(int signo)
-{
-
-	(void)signo;
-	times_up = 1;
-}
-
 static void *
 thread(void *cookie)
 {
@@ -125,21 +116,22 @@ ATF_TC_BODY(spinlock, tc)
 	size_t ncpulen = sizeof(ncpu);
 	int error;
 
+	alarm(10);
+
 	if (sysctlbyname("hw.ncpu", , , NULL, 0) == -1)
 		atf_tc_fail("hw.ncpu: (%d) %s", errno, strerror(errno));
 	assert(ncpulen == sizeof(ncpu));
 	if (ncpu == 1)
 		atf_tc_skip("membar tests are only for multicore systems");
 
-	if (signal(SIGALRM, alarm_handler) == SIG_ERR)
-		err(1, "signal(SIGALRM");
-	alarm(5);
 	for (i = 0; i < 2; i++) {
 		error = pthread_create([i], NULL, ,
 		(void *)(uintptr_t)i);
 		if (error)
 			errc(1, error, "pthread_create");
 	}
+	sleep(5);
+	times_up = 1;
 	for (i = 0; i < 2; i++) {
 		error = pthread_join(t[i], NULL);
 		if (error)

Index: src/tests/lib/libc/membar/t_seqlock.c
diff -u src/tests/lib/libc/membar/t_seqlock.c:1.1 src/tests/lib/libc/membar/t_seqlock.c:1.2
--- src/tests/lib/libc/membar/t_seqlock.c:1.1	Fri Apr  8 23:35:52 2022
+++ src/tests/lib/libc/membar/t_seqlock.c	Sun Apr 10 11:36:32 2022
@@ -1,4 +1,4 @@
-/*	$NetBSD: t_seqlock.c,v 1.1 2022/04/08 23:35:52 riastradh Exp $	*/
+/*	$NetBSD: t_seqlock.c,v 1.2 2022/04/10 11:36:32 riastradh Exp $	*/
 
 /*-
  * Copyright (c) 2022 The NetBSD Foundation, Inc.
@@ -27,7 +27,7 @@
  */
 
 #include 
-__RCSID("$NetBSD: t_seqlock.c,v 1.1 2022/04/08 23:35:52 riastradh Exp $");
+__RCSID("$NetBSD: t_seqlock.c,v 1.2 2022/04/10 11:36:32 riastradh Exp $");
 
 #include 
 #include 
@@ -39,7 +39,6 @@ __RCSID("$NetBSD: t_seqlock.c,v 1.1 2022
 #include 
 #include 
 #include 
-#include 
 #include 
 #include 
 #include 
@@ -64,14 +63,6 @@ volatile struct {
 
 uint64_t results[2];
 
-static void
-alarm_handler(int signo)
-{
-
-	(void)signo;
-	times_up = 1;
-}
-
 static void *
 

CVS commit: src/tests/lib/libc/membar

2022-04-10 Thread Taylor R Campbell
Module Name:src
Committed By:   riastradh
Date:   Sun Apr 10 11:36:32 UTC 2022

Modified Files:
src/tests/lib/libc/membar: t_dekker.c t_seqlock.c t_spinlock.c

Log Message:
membar_ops(3): Simplify alarm handling in membar tests.


To generate a diff of this commit:
cvs rdiff -u -r1.2 -r1.3 src/tests/lib/libc/membar/t_dekker.c \
src/tests/lib/libc/membar/t_spinlock.c
cvs rdiff -u -r1.1 -r1.2 src/tests/lib/libc/membar/t_seqlock.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.