blob: 38fec33a50fbd1947d65422f0be88bae4b9eadae [file] [log] [blame]
sewardj2342c972002-05-22 23:34:20 +00001
2
3#include <stdio.h>
mueller535cc6e2004-01-03 14:18:02 +00004#include <stdlib.h>
sewardj2342c972002-05-22 23:34:20 +00005#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;
sewardj89551b32005-11-17 13:04:46 +000018 char *stk = (char *)mmap(0, size, PROT_READ|PROT_WRITE|PROT_EXEC,
19 MAP_ANON|MAP_PRIVATE, -1, 0);
fitzhardingef0f911c2003-11-09 09:51:33 +000020 sigstk.ss_sp = stk;
sewardj2342c972002-05-22 23:34:20 +000021
fitzhardingef0f911c2003-11-09 09:51:33 +000022 sigstk.ss_size = size;
sewardj2342c972002-05-22 23:34:20 +000023 sigstk.ss_flags = 0;
24 fprintf(stderr, "calling sigaltstack, stack base is %p\n", sigstk.ss_sp);
25 if (sigaltstack(&sigstk,0)<0) perror("sigaltstack");
26
27 fprintf(stderr,"setting sigaction\n");
28 act.sa_flags=SA_ONSTACK;
29 act.sa_handler=&sig_handler;
fitzhardinge98abfc72003-12-16 02:05:15 +000030 sigemptyset(&act.sa_mask);
sewardj2342c972002-05-22 23:34:20 +000031 res = sigaction(SIGUSR1,&act,0);
32 fprintf(stderr, "res = %d\n", res);
33 fprintf(stderr, "raising the signal\n");
34 raise(SIGUSR1);
35
36 /* Loop long enough so valgrind has a forced context switch and
37 actually delivers the signal before the thread exits. */
38 for (i = 0; i < 1000000; i++) ;
39
40 fprintf(stderr, "done\n");
41 return 0;
42}