summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLaxmikant Rashinkar <LK.Rashinkar@gmail.com>2013-09-03 19:44:20 -0700
committerLaxmikant Rashinkar <LK.Rashinkar@gmail.com>2013-09-03 19:44:20 -0700
commitece8f1fb47c584a63160fc2a339ebc015185f878 (patch)
tree6fbc6f9696c5db22ae5123d58f78730739207159
parent829c494fb9b62c68d1079251ca1c97de84c09c70 (diff)
downloadxrdp-proprietary-ece8f1fb47c584a63160fc2a339ebc015185f878.tar.gz
xrdp-proprietary-ece8f1fb47c584a63160fc2a339ebc015185f878.zip
gracefully handle segfaults in chansrv code
-rw-r--r--common/os_calls.c11
-rw-r--r--sesman/chansrv/chansrv.c12
2 files changed, 22 insertions, 1 deletions
diff --git a/common/os_calls.c b/common/os_calls.c
index 1939ddc9..c5a15bb0 100644
--- a/common/os_calls.c
+++ b/common/os_calls.c
@@ -2501,6 +2501,17 @@ g_signal_child_stop(void (*func)(int))
}
/*****************************************************************************/
+
+void APP_CC
+g_signal_segfault(void (*func)(int))
+{
+#if defined(_WIN32)
+#else
+ signal(SIGSEGV, func);
+#endif
+}
+
+/*****************************************************************************/
/* does not work in win32 */
void APP_CC
g_signal_hang_up(void (*func)(int))
diff --git a/sesman/chansrv/chansrv.c b/sesman/chansrv/chansrv.c
index 26d4182e..d81c488d 100644
--- a/sesman/chansrv/chansrv.c
+++ b/sesman/chansrv/chansrv.c
@@ -1044,7 +1044,7 @@ child_signal_handler(int sig)
{
int i1;
- LOG(10, ("child_signal_handler:"));
+ LOG(0, ("child_signal_handler:"));
do
{
@@ -1061,6 +1061,14 @@ child_signal_handler(int sig)
while (i1 >= 0);
}
+void DEFAULT_CC
+segfault_signal_handler(int sig)
+{
+ LOG(0, ("segfault_signal_handler: entered......."));
+ xfuse_deinit();
+ exit(0);
+}
+
/*****************************************************************************/
static int APP_CC
get_display_num_from_display(char *display_text)
@@ -1272,6 +1280,8 @@ main(int argc, char **argv)
g_signal_user_interrupt(term_signal_handler); /* SIGINT */
g_signal_pipe(nil_signal_handler); /* SIGPIPE */
g_signal_child_stop(child_signal_handler); /* SIGCHLD */
+ g_signal_segfault(segfault_signal_handler);
+
display_text = g_getenv("DISPLAY");
LOGM((LOG_LEVEL_INFO, "main: DISPLAY env var set to %s", display_text));
get_display_num_from_display(display_text);