1*043036a2SApple OSS Distributions #include <signal.h>
2*043036a2SApple OSS Distributions #include <stdio.h>
3*043036a2SApple OSS Distributions #include <stdlib.h>
4*043036a2SApple OSS Distributions #include <unistd.h>
5*043036a2SApple OSS Distributions #include <errno.h>
6*043036a2SApple OSS Distributions
7*043036a2SApple OSS Distributions #include <darwintest.h>
8*043036a2SApple OSS Distributions
9*043036a2SApple OSS Distributions T_GLOBAL_META(
10*043036a2SApple OSS Distributions T_META_RUN_CONCURRENTLY(true),
11*043036a2SApple OSS Distributions T_META_CHECK_LEAKS(false),
12*043036a2SApple OSS Distributions T_META_TAG_VM_PREFERRED,
13*043036a2SApple OSS Distributions T_META_RADAR_COMPONENT_NAME("xnu"),
14*043036a2SApple OSS Distributions T_META_RADAR_COMPONENT_VERSION("signals"));
15*043036a2SApple OSS Distributions
16*043036a2SApple OSS Distributions static uint64_t stack_base, stack_end;
17*043036a2SApple OSS Distributions
18*043036a2SApple OSS Distributions static void
signal_handler(int __unused signum,struct __siginfo * __unused info,void * __unused uap)19*043036a2SApple OSS Distributions signal_handler(int __unused signum, struct __siginfo * __unused info, void * __unused uap)
20*043036a2SApple OSS Distributions {
21*043036a2SApple OSS Distributions T_LOG("In signal handler\n");
22*043036a2SApple OSS Distributions uint64_t signal_stack = (uint64_t)__builtin_frame_address(0);
23*043036a2SApple OSS Distributions T_ASSERT_LE(stack_base, signal_stack, NULL);
24*043036a2SApple OSS Distributions T_ASSERT_LE(signal_stack, stack_end, NULL);
25*043036a2SApple OSS Distributions T_END;
26*043036a2SApple OSS Distributions }
27*043036a2SApple OSS Distributions
28*043036a2SApple OSS Distributions T_DECL(signalstack, "Check that the signal stack is set up correctly", T_META_ASROOT(YES), T_META_TAG_VM_PREFERRED)
29*043036a2SApple OSS Distributions {
30*043036a2SApple OSS Distributions void* stack_allocation = malloc(SIGSTKSZ);
31*043036a2SApple OSS Distributions
32*043036a2SApple OSS Distributions stack_base = (uint64_t)stack_allocation;
33*043036a2SApple OSS Distributions stack_end = stack_base + SIGSTKSZ;
34*043036a2SApple OSS Distributions
35*043036a2SApple OSS Distributions T_LOG("stack base = 0x%llx\n", stack_base);
36*043036a2SApple OSS Distributions T_LOG("stack end = 0x%llx\n", stack_end);
37*043036a2SApple OSS Distributions
38*043036a2SApple OSS Distributions stack_t alt_stack;
39*043036a2SApple OSS Distributions alt_stack.ss_sp = stack_allocation;
40*043036a2SApple OSS Distributions alt_stack.ss_size = SIGSTKSZ;
41*043036a2SApple OSS Distributions alt_stack.ss_flags = 0;
42*043036a2SApple OSS Distributions
43*043036a2SApple OSS Distributions if (sigaltstack(&alt_stack, NULL) < 0) {
44*043036a2SApple OSS Distributions T_FAIL("error: sigaltstack failed\n");
45*043036a2SApple OSS Distributions }
46*043036a2SApple OSS Distributions
47*043036a2SApple OSS Distributions sigset_t signal_mask;
48*043036a2SApple OSS Distributions sigemptyset(&signal_mask);
49*043036a2SApple OSS Distributions
50*043036a2SApple OSS Distributions struct sigaction sig_action;
51*043036a2SApple OSS Distributions sig_action.sa_sigaction = signal_handler;
52*043036a2SApple OSS Distributions sig_action.sa_mask = signal_mask;
53*043036a2SApple OSS Distributions sig_action.sa_flags = SA_ONSTACK;
54*043036a2SApple OSS Distributions
55*043036a2SApple OSS Distributions if (sigaction(SIGUSR1, &sig_action, NULL) != 0) {
56*043036a2SApple OSS Distributions T_FAIL("error: sigaction failed\n");
57*043036a2SApple OSS Distributions }
58*043036a2SApple OSS Distributions
59*043036a2SApple OSS Distributions T_LOG("Sending a SIGUSR1\n");
60*043036a2SApple OSS Distributions kill(getpid(), SIGUSR1);
61*043036a2SApple OSS Distributions
62*043036a2SApple OSS Distributions return;
63*043036a2SApple OSS Distributions }
64