git: df1ea5887326 - main - tests: Test libexecinfo backtrace call througth signal trampoline
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Fri, 28 Jul 2023 09:10:48 UTC
The branch main has been updated by dchagin:
URL: https://cgit.FreeBSD.org/src/commit/?id=df1ea5887326103f0cc1445ab42fce528b474030
commit df1ea5887326103f0cc1445ab42fce528b474030
Author: Dmitry Chagin <dchagin@FreeBSD.org>
AuthorDate: 2023-07-28 09:10:27 +0000
Commit: Dmitry Chagin <dchagin@FreeBSD.org>
CommitDate: 2023-07-28 09:10:27 +0000
tests: Test libexecinfo backtrace call througth signal trampoline
It should fails on Aarch64 until https://reviews.llvm.org/D155066
is not merged.
Reviewed by:
Differential Revision: https://reviews.freebsd.org/D41129
---
lib/libexecinfo/tests/Makefile | 3 ++
lib/libexecinfo/tests/sigtramp_test.c | 75 +++++++++++++++++++++++++++++++++++
2 files changed, 78 insertions(+)
diff --git a/lib/libexecinfo/tests/Makefile b/lib/libexecinfo/tests/Makefile
index da34964c5005..7b90029fe354 100644
--- a/lib/libexecinfo/tests/Makefile
+++ b/lib/libexecinfo/tests/Makefile
@@ -14,7 +14,10 @@ STRIP=
# so that doesn't seem useful.
NETBSD_ATF_TESTS_C+= backtrace_test
+ATF_TESTS_C+= sigtramp_test
+
LIBADD.backtrace_test+= execinfo
+LIBADD.sigtramp_test+= execinfo
.include <netbsd-tests.test.mk>
diff --git a/lib/libexecinfo/tests/sigtramp_test.c b/lib/libexecinfo/tests/sigtramp_test.c
new file mode 100644
index 000000000000..cd3b3cc418de
--- /dev/null
+++ b/lib/libexecinfo/tests/sigtramp_test.c
@@ -0,0 +1,75 @@
+/*-
+ * Copyright (c) 2023 Dmitry Chagin <dchagin@FreeBSD.org>
+ *
+ * SPDX-License-Identifier: BSD-2-Clause
+ */
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#include <sys/param.h>
+#include <sys/wait.h>
+
+#include <execinfo.h>
+#include <signal.h>
+#include <stdio.h>
+#include <string.h>
+#include <unistd.h>
+
+#include <atf-c.h>
+
+#define BT_FUNCTIONS 10
+
+void handler(int);
+
+__noinline void
+handler(int signum __unused)
+{
+ void *addresses[BT_FUNCTIONS];
+ char **symbols;
+ size_t n, i, match;
+
+ n = backtrace(addresses, nitems(addresses));
+ ATF_REQUIRE(n > 1);
+ symbols = backtrace_symbols(addresses, n);
+ ATF_REQUIRE(symbols != NULL);
+
+ match = -1;
+ for (i = 0; i < n; i++) {
+ printf("%zu: %p, %s\n", i, addresses[i], symbols[i]);
+ if (strstr(symbols[i], "<main+") != NULL)
+ match = i;
+ }
+ ATF_REQUIRE(match > 0);
+ printf("match at %zu, symbols %zu\n", match, n);
+
+}
+
+ATF_TC_WITHOUT_HEAD(test_backtrace_sigtramp);
+ATF_TC_BODY(test_backtrace_sigtramp, tc)
+{
+ struct sigaction act;
+ pid_t child;
+ int status;
+
+ memset(&act, 0, sizeof(act));
+ act.sa_handler = handler;
+ sigemptyset(&act.sa_mask);
+ sigaction(SIGUSR1, &act, NULL);
+
+ child = fork();
+ ATF_REQUIRE(child != -1);
+
+ if (child == 0) {
+ kill(getppid(), SIGUSR1);
+ _exit(0);
+ } else
+ wait(&status);
+}
+
+ATF_TP_ADD_TCS(tp)
+{
+
+ ATF_TP_ADD_TC(tp, test_backtrace_sigtramp);
+
+ return (atf_no_error());
+}