Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/tests/lib/libc/sys Refactor code in ATF ptrace(2) tests
details: https://anonhg.NetBSD.org/src/rev/cbdbb045fb1b
branches: trunk
changeset: 832479:cbdbb045fb1b
user: kamil <kamil%NetBSD.org@localhost>
date: Sun May 13 23:01:25 2018 +0000
description:
Refactor code in ATF ptrace(2) tests
Move the can_we_set_dbregs() auxiliary function from t_ptrace_x86_wait.h
to a common file t_ptrace_wait.h. This allows using this function for
checking whether the DBREGS set operations in ptrace(2) are accessible for
a user.
Sponsored by <The NetBSD Foundation>
diffstat:
tests/lib/libc/sys/t_ptrace_wait.h | 31 ++++++++++++++++++++++++++++++-
tests/lib/libc/sys/t_ptrace_x86_wait.h | 29 +----------------------------
2 files changed, 31 insertions(+), 29 deletions(-)
diffs (88 lines):
diff -r f6bc7fc59c4e -r cbdbb045fb1b tests/lib/libc/sys/t_ptrace_wait.h
--- a/tests/lib/libc/sys/t_ptrace_wait.h Sun May 13 22:58:58 2018 +0000
+++ b/tests/lib/libc/sys/t_ptrace_wait.h Sun May 13 23:01:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: t_ptrace_wait.h,v 1.3 2018/04/28 17:56:55 kamil Exp $ */
+/* $NetBSD: t_ptrace_wait.h,v 1.4 2018/05/13 23:01:25 kamil Exp $ */
/*-
* Copyright (c) 2016 The NetBSD Foundation, Inc.
@@ -409,6 +409,35 @@
}
}
+#if defined(HAVE_DBREGS)
+static bool
+can_we_set_dbregs(void)
+{
+ static long euid = -1;
+ static int user_set_dbregs = -1;
+ size_t user_set_dbregs_len = sizeof(user_set_dbregs);
+
+ if (euid == -1)
+ euid = geteuid();
+
+ if (euid == 0)
+ return true;
+
+ if (user_set_dbregs == -1) {
+ if (sysctlbyname("security.models.extensions.user_set_dbregs",
+ &user_set_dbregs, &user_set_dbregs_len, NULL, 0)
+ == -1) {
+ return false;
+ }
+ }
+
+ if (user_set_dbregs > 0)
+ return true;
+ else
+ return false;
+}
+#endif
+
#if defined(TWAIT_HAVE_PID)
#define ATF_TP_ADD_TC_HAVE_PID(a,b) ATF_TP_ADD_TC(a,b)
#else
diff -r f6bc7fc59c4e -r cbdbb045fb1b tests/lib/libc/sys/t_ptrace_x86_wait.h
--- a/tests/lib/libc/sys/t_ptrace_x86_wait.h Sun May 13 22:58:58 2018 +0000
+++ b/tests/lib/libc/sys/t_ptrace_x86_wait.h Sun May 13 23:01:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: t_ptrace_x86_wait.h,v 1.5 2018/04/08 17:20:18 kamil Exp $ */
+/* $NetBSD: t_ptrace_x86_wait.h,v 1.6 2018/05/13 23:01:25 kamil Exp $ */
/*-
* Copyright (c) 2016 The NetBSD Foundation, Inc.
@@ -57,33 +57,6 @@
} bits;
};
-static bool
-can_we_set_dbregs(void)
-{
- static long euid = -1;
- static int user_set_dbregs = -1;
- size_t user_set_dbregs_len = sizeof(user_set_dbregs);
-
- if (euid == -1)
- euid = geteuid();
-
- if (euid == 0)
- return true;
-
- if (user_set_dbregs == -1) {
- if (sysctlbyname("security.models.extensions.user_set_dbregs",
- &user_set_dbregs, &user_set_dbregs_len, NULL, 0)
- == -1) {
- return false;
- }
- }
-
- if (user_set_dbregs > 0)
- return true;
- else
- return false;
-}
-
ATF_TC(dbregs_print);
ATF_TC_HEAD(dbregs_print, tc)
{
Home |
Main Index |
Thread Index |
Old Index