6 int disable_buffer = 0;
7 +pid_t callmgr_pid = 0;
9 struct in_addr get_ip_address(char *name);
10 int open_callmgr(struct in_addr inetaddr, char *phonenr, int argc,char **argv,char **envp, int pty_fd, int gre_fd);
11 @@ -115,6 +116,8 @@ sigjmp_buf env;
12 /*** signal handler ***********************************************************/
13 void sighandler(int sig)
15 + fprintf(stderr, "Got signal, pid=%d\n", callmgr_pid);
20 @@ -330,6 +333,14 @@ int main(int argc, char **argv, char **e
21 parent_pid = 0; /* don't kill pppd */
24 + if (sigsetjmp(env, 1)!= 0) goto shutdown;
26 + signal(SIGINT, sighandler);
27 + signal(SIGTERM, sighandler);
28 + signal(SIGKILL, sighandler);
29 + signal(SIGCHLD, sighandler);
30 + signal(SIGUSR1, sigstats);
34 * Open connection to call manager (Launch call manager if necessary.)
35 @@ -360,13 +371,6 @@ int main(int argc, char **argv, char **e
36 if (rc != 0) perror("prctl");
38 inststr(argc, argv, envp, buf);
39 - if (sigsetjmp(env, 1)!= 0) goto shutdown;
41 - signal(SIGINT, sighandler);
42 - signal(SIGTERM, sighandler);
43 - signal(SIGKILL, sighandler);
44 - signal(SIGCHLD, sighandler);
45 - signal(SIGUSR1, sigstats);
47 /* Do GRE copy until close. */
48 pptp_gre_copy(call_id, peer_call_id, pty_fd, gre_fd);
49 @@ -375,6 +379,8 @@ shutdown:
50 /* on close, kill all. */
52 kill(parent_pid, SIGTERM);
54 + kill(callmgr_pid, SIGTERM);
58 @@ -407,7 +413,7 @@ int open_callmgr(struct in_addr inetaddr
59 struct sockaddr_un where;
60 const int NUM_TRIES = 3;
66 if ((fd = socket(AF_UNIX, SOCK_STREAM, 0)) < 0) {
67 @@ -434,6 +440,7 @@ int open_callmgr(struct in_addr inetaddr
68 launch_callmgr(inetaddr, phonenr, argc, argv, envp);
72 waitpid(pid, &status, 0);
74 fatal("Call manager exited with error %d", status);