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