blob: 279e315fb3d249e371b006d58c9ac4838d656458 [file] [log] [blame]
sewardj2342c972002-05-22 23:34:20 +00001
2
3#include <stdio.h>
4#include <malloc.h>
5#include <signal.h>
fitzhardingef0f911c2003-11-09 09:51:33 +00006#include <sys/mman.h>
sewardj2342c972002-05-22 23:34:20 +00007
8void sig_handler(int sig){
9 int var;
10 fprintf(stderr, "caught signal, local var is on %p\n", &var);
11}
12
sewardj2342c972002-05-22 23:34:20 +000013int main(int argv, char** argc) {
14 int res, i;
15 stack_t sigstk;
16 struct sigaction act;
fitzhardinge8e536782003-11-21 09:22:06 +000017 static const int size = SIGSTKSZ*2;
fitzhardingef0f911c2003-11-09 09:51:33 +000018 char *stk = (char *)mmap(0, size, PROT_READ|PROT_WRITE, MAP_ANONYMOUS|MAP_PRIVATE, -1, 0);
19 sigstk.ss_sp = stk;
sewardj2342c972002-05-22 23:34:20 +000020
fitzhardingef0f911c2003-11-09 09:51:33 +000021 sigstk.ss_size = size;
sewardj2342c972002-05-22 23:34:20 +000022 sigstk.ss_flags = 0;
23 fprintf(stderr, "calling sigaltstack, stack base is %p\n", sigstk.ss_sp);
24 if (sigaltstack(&sigstk,0)<0) perror("sigaltstack");
25
26 fprintf(stderr,"setting sigaction\n");
27 act.sa_flags=SA_ONSTACK;
28 act.sa_handler=&sig_handler;
fitzhardinge98abfc72003-12-16 02:05:15 +000029 sigemptyset(&act.sa_mask);
sewardj2342c972002-05-22 23:34:20 +000030 res = sigaction(SIGUSR1,&act,0);
31 fprintf(stderr, "res = %d\n", res);
32 fprintf(stderr, "raising the signal\n");
33 raise(SIGUSR1);
34
35 /* Loop long enough so valgrind has a forced context switch and
36 actually delivers the signal before the thread exits. */
37 for (i = 0; i < 1000000; i++) ;
38
39 fprintf(stderr, "done\n");
40 return 0;
41}