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