Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src Add KCOV_LOAD() and KCOV_STORE() - new helper macros
details: https://anonhg.NetBSD.org/src/rev/e2b1c07bfe2e
branches: trunk
changeset: 449173:e2b1c07bfe2e
user: kamil <kamil%NetBSD.org@localhost>
date: Sun Feb 24 21:14:43 2019 +0000
description:
Add KCOV_LOAD() and KCOV_STORE() - new helper macros
New macros prefer 64-bit atomic operations whenever accessible.
As a fallback they use volatile move operations that are not known
to have negative effect in KCOV even if interrupted in the middle of
operation.
Enable kcov_basic and kcov_thread tests on targets without
__HAVE_ATOMIC64_OPS.
diffstat:
sys/sys/kcov.h | 21 ++++++++++++++++++++-
tests/modules/t_kcov.c | 10 ++++------
2 files changed, 24 insertions(+), 7 deletions(-)
diffs (78 lines):
diff -r 1845a56400b2 -r e2b1c07bfe2e sys/sys/kcov.h
--- a/sys/sys/kcov.h Sun Feb 24 21:07:59 2019 +0000
+++ b/sys/sys/kcov.h Sun Feb 24 21:14:43 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: kcov.h,v 1.1 2019/02/23 03:10:06 kamil Exp $ */
+/* $NetBSD: kcov.h,v 1.2 2019/02/24 21:14:43 kamil Exp $ */
/*
* Copyright (c) 2019 The NetBSD Foundation, Inc.
@@ -32,6 +32,10 @@
#ifndef _SYS_KCOV_H_
#define _SYS_KCOV_H_
+#include <sys/param.h>
+#include <sys/types.h>
+#include <sys/atomic.h>
+
#define KCOV_IOC_SETBUFSIZE _IOW('K', 1, uint64_t)
#define KCOV_IOC_ENABLE _IO('K', 2)
#define KCOV_IOC_DISABLE _IO('K', 3)
@@ -39,4 +43,19 @@
typedef volatile uint64_t kcov_int_t;
#define KCOV_ENTRY_SIZE sizeof(kcov_int_t)
+/*
+ * Always prefer 64-bit atomic operations whenever accessible.
+ *
+ * As a fallback keep regular volatile move operation that it's not known
+ * to have negative effect in KCOV even if interrupted in the middle of
+ * operation.
+ */
+#ifdef __HAVE_ATOMIC64_OPS
+#define KCOV_STORE(x,v) __atomic_store_n(&(x), (v), __ATOMIC_RELAXED)
+#define KCOV_LOAD(x) __atomic_load_n(&(x), __ATOMIC_RELAXED)
+#else
+#define KCOV_STORE(x,v) (x) = (y)
+#define KCOV_LOAD(x) (x)
+#endif
+
#endif /* !_SYS_KCOV_H_ */
diff -r 1845a56400b2 -r e2b1c07bfe2e tests/modules/t_kcov.c
--- a/tests/modules/t_kcov.c Sun Feb 24 21:07:59 2019 +0000
+++ b/tests/modules/t_kcov.c Sun Feb 24 21:14:43 2019 +0000
@@ -254,10 +254,10 @@
ATF_REQUIRE_MSG(ioctl(fd, KCOV_IOC_ENABLE) == 0,
"Unable to enable kcov ");
- __atomic_store_n(&buf[0], 0 , __ATOMIC_RELAXED);
+ KCOV_STORE(&buf[0], 0);
sleep(0);
- ATF_REQUIRE_MSG(__atomic_load_n(&buf[0], __ATOMIC_RELAXED) != 0, "No records found");
+ ATF_REQUIRE_MSG(KCOV_LOAD(&buf[0]) != 0, "No records found");
ATF_REQUIRE_MSG(ioctl(fd, KCOV_IOC_DISABLE) == 0,
"Unable to disable kcov");
@@ -270,9 +270,9 @@
{
kcov_int_t *buf = ptr;
- __atomic_store_n(&buf[0], 0, __ATOMIC_RELAXED);
+ KCOV_STORE(&buf[0], 0);
sleep(0);
- ATF_REQUIRE_MSG(__atomic_load_n(&buf[0], __ATOMIC_RELAXED) == 0,
+ ATF_REQUIRE_MSG(KCOV_LOAD(&buf[0]) == 0,
"Records changed in blocked thread");
return NULL;
@@ -311,9 +311,7 @@
ATF_TP_ADD_TC(tp, kcov_enable_no_disable);
ATF_TP_ADD_TC(tp, kcov_enable_no_disable_no_close);
ATF_TP_ADD_TC(tp, kcov_mmap_enable_thread_close);
-#ifdef __HAVE_ATOMIC64_OPS
ATF_TP_ADD_TC(tp, kcov_basic);
ATF_TP_ADD_TC(tp, kcov_thread);
-#endif
return atf_no_error();
}
Home |
Main Index |
Thread Index |
Old Index