Mercurial > audlegacy
annotate src/audacious/signals.c @ 4662:8a783f826316
Added some debugging / startup messages (visible via 'audacious -N') to make
it easier to see where things go wrong, if they do.
author | Matti Hamalainen <ccr@tnsp.org> |
---|---|
date | Fri, 27 Jun 2008 17:58:45 +0300 |
parents | 55262ebeba2d |
children | cd1e4d4aa0b9 |
rev | line source |
---|---|
2313 | 1 /* |
2892
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
2 * Audacious |
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
3 * Copyright (c) 2005-2007 Yoshiki Yazawa |
2313 | 4 * |
2892
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
5 * This program is free software; you can redistribute it and/or modify |
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
6 * it under the terms of the GNU General Public License as published by |
3121
3b6d316f8b09
GPL3 relicensing.
William Pitcock <nenolod@atheme-project.org>
parents:
2892
diff
changeset
|
7 * the Free Software Foundation; under version 3 of the License. |
2313 | 8 * |
2892
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
9 * This program is distributed in the hope that it will be useful, |
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
12 * GNU General Public License for more details. |
2313 | 13 * |
2892
2f5e02538dfa
Backed out changeset 06858ea4b9d01dab0ce54891221bd1534a9c5ade
William Pitcock <nenolod@atheme.org>
parents:
2863
diff
changeset
|
14 * You should have received a copy of the GNU General Public License |
3121
3b6d316f8b09
GPL3 relicensing.
William Pitcock <nenolod@atheme-project.org>
parents:
2892
diff
changeset
|
15 * along with this program. If not, see <http://www.gnu.org/licenses>. |
3123
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3121
diff
changeset
|
16 * |
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3121
diff
changeset
|
17 * The Audacious team does not consider modular code linking to |
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3121
diff
changeset
|
18 * Audacious or using our public API to be a derived work. |
2313 | 19 */ |
20 | |
2677
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
21 //#define _XOPEN_SOURCE |
2666
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
22 #include <unistd.h> /* for signal_check_for_broken_impl() */ |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
23 |
2313 | 24 #include <glib.h> |
25 #include <glib/gi18n.h> | |
26 #include <config.h> | |
27 #include <stdlib.h> | |
2674
f3ee0b78150a
[svn] - use pthread_sigmask(SIG_BLOCK, ...) instead of of SIG_SETMASK
nenolod
parents:
2666
diff
changeset
|
28 #include <pthread.h> /* for pthread_sigmask() */ |
2313 | 29 #include <signal.h> |
30 | |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
31 #ifdef HAVE_EXECINFO_H |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
32 # include <execinfo.h> |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
33 #endif |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
34 |
2313 | 35 #include "main.h" |
36 #include "signals.h" | |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
37 #include "build_stamp.h" |
4492
55262ebeba2d
Conditional support for SM (libeggsmclient).
Matti Hamalainen <ccr@tnsp.org>
parents:
4449
diff
changeset
|
38 #ifdef USE_EGGSM |
4315
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
39 #include "eggsmclient.h" |
4492
55262ebeba2d
Conditional support for SM (libeggsmclient).
Matti Hamalainen <ccr@tnsp.org>
parents:
4449
diff
changeset
|
40 #endif |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
41 |
2677
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
42 gint linuxthread_signal_number = 0; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
43 |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
44 static void |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
45 signal_process_segv(void) |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
46 { |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
47 g_printerr(_("\nAudacious has caught signal 11 (SIGSEGV).\n\n" |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
48 "We apologize for the inconvenience, but Audacious has crashed.\n" |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
49 "This is a bug in the program, and should never happen under normal circumstances.\n" |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
50 "Your current configuration has been saved and should not be damaged.\n\n" |
4431
6456eadfe0ca
Updated bugtracker URL and made the sig11 handler tiny bit more informative.
Matti Hamalainen <ccr@tnsp.org>
parents:
4412
diff
changeset
|
51 "You can help improve the quality of Audacious by filing a bug at http://bugzilla.atheme.org/\n" |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
52 "Please include the entire text of this message and a description of what you were doing when\n" |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
53 "this crash occured in order to quickly expedite the handling of your bug report:\n\n")); |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
54 |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
55 g_printerr("Program version: Audacious %s (buildid: %s)\n\n", VERSION, svn_stamp); |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
56 |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
57 #ifdef HAVE_EXECINFO_H |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
58 { |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
59 void *stack[20]; |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
60 size_t size; |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
61 char **strings; |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
62 size_t i; |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
63 |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
64 size = backtrace(stack, 20); |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
65 strings = backtrace_symbols(stack, size); |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
66 |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
67 g_printerr("Stacktrace (%zd frames):\n", size); |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
68 |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
69 for (i = 0; i < size; i++) |
2785 | 70 g_printerr(" %ld. %s\n", (long)i + 1, strings[i]); |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
71 |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
72 g_free(strings); |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
73 } |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
74 #else |
4431
6456eadfe0ca
Updated bugtracker URL and made the sig11 handler tiny bit more informative.
Matti Hamalainen <ccr@tnsp.org>
parents:
4412
diff
changeset
|
75 g_printerr(_("Stacktrace was unavailable. You might want to reproduce this " |
6456eadfe0ca
Updated bugtracker URL and made the sig11 handler tiny bit more informative.
Matti Hamalainen <ccr@tnsp.org>
parents:
4412
diff
changeset
|
76 "problem while running Audacious under GDB to get a proper backtrace.\n")); |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
77 #endif |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
78 |
4431
6456eadfe0ca
Updated bugtracker URL and made the sig11 handler tiny bit more informative.
Matti Hamalainen <ccr@tnsp.org>
parents:
4412
diff
changeset
|
79 g_printerr(_("\nBugs can be reported at http://bugzilla.atheme.org/ against " |
6456eadfe0ca
Updated bugtracker URL and made the sig11 handler tiny bit more informative.
Matti Hamalainen <ccr@tnsp.org>
parents:
4412
diff
changeset
|
80 "the Audacious or Audacious Plugins product.\n")); |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
81 |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
82 g_critical("Received SIGSEGV -- Audacious has crashed."); |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
83 |
4412
180996fcf12a
bmp_config_* -> aud_config_*
Matti Hamalainen <ccr@tnsp.org>
parents:
4345
diff
changeset
|
84 aud_config_save(); |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
85 abort(); |
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
86 } |
2313 | 87 |
2629 | 88 static void * |
89 signal_process_signals (void *data) | |
2313 | 90 { |
2629 | 91 sigset_t waitset; |
92 int sig; | |
93 | |
94 sigemptyset(&waitset); | |
95 sigaddset(&waitset, SIGPIPE); | |
96 sigaddset(&waitset, SIGSEGV); | |
97 sigaddset(&waitset, SIGINT); | |
98 sigaddset(&waitset, SIGTERM); | |
2313 | 99 |
2629 | 100 while(1) { |
101 sigwait(&waitset, &sig); | |
2313 | 102 |
2629 | 103 switch(sig){ |
104 case SIGPIPE: | |
105 /* | |
106 * do something. | |
107 */ | |
108 break; | |
2313 | 109 |
2629 | 110 case SIGSEGV: |
2661
f6c7271df7de
[svn] - use execinfo.h to provide more useful information about crashes
nenolod
parents:
2638
diff
changeset
|
111 signal_process_segv(); |
2629 | 112 break; |
2313 | 113 |
2629 | 114 case SIGINT: |
115 g_print("Audacious has received SIGINT and is shutting down.\n"); | |
4449
19e3f3c5fe7f
introduce function aud_quit(), which is basically mainwin_quit_cb(), but
mf0102 <0102@gmx.at>
parents:
4431
diff
changeset
|
116 aud_quit(); |
2629 | 117 break; |
118 | |
119 case SIGTERM: | |
120 g_print("Audacious has received SIGTERM and is shutting down.\n"); | |
4449
19e3f3c5fe7f
introduce function aud_quit(), which is basically mainwin_quit_cb(), but
mf0102 <0102@gmx.at>
parents:
4431
diff
changeset
|
121 aud_quit(); |
2629 | 122 break; |
123 } | |
2313 | 124 } |
125 | |
2629 | 126 return NULL; //dummy |
2313 | 127 } |
128 | |
2677
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
129 /********************************************************************************/ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
130 /* for linuxthread */ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
131 /********************************************************************************/ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
132 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
133 typedef void (*SignalHandler) (gint); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
134 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
135 static void * |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
136 signal_process_signals_linuxthread (void *data) |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
137 { |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
138 while(1) { |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
139 g_usleep(1000000); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
140 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
141 switch(linuxthread_signal_number){ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
142 case SIGPIPE: |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
143 /* |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
144 * do something. |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
145 */ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
146 linuxthread_signal_number = 0; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
147 break; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
148 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
149 case SIGSEGV: |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
150 signal_process_segv(); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
151 break; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
152 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
153 case SIGINT: |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
154 g_print("Audacious has received SIGINT and is shutting down.\n"); |
4449
19e3f3c5fe7f
introduce function aud_quit(), which is basically mainwin_quit_cb(), but
mf0102 <0102@gmx.at>
parents:
4431
diff
changeset
|
155 aud_quit(); |
2677
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
156 break; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
157 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
158 case SIGTERM: |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
159 g_print("Audacious has received SIGTERM and is shutting down.\n"); |
4449
19e3f3c5fe7f
introduce function aud_quit(), which is basically mainwin_quit_cb(), but
mf0102 <0102@gmx.at>
parents:
4431
diff
changeset
|
160 aud_quit(); |
2677
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
161 break; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
162 } |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
163 } |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
164 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
165 return NULL; //dummy |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
166 } |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
167 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
168 static void |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
169 linuxthread_handler (gint signal_number) |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
170 { |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
171 /* note: cannot manipulate mutex from signal handler */ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
172 linuxthread_signal_number = signal_number; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
173 } |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
174 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
175 static SignalHandler |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
176 signal_install_handler_full (gint signal_number, |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
177 SignalHandler handler, |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
178 gint *signals_to_block, |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
179 gsize n_signals) |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
180 { |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
181 struct sigaction action, old_action; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
182 gsize i; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
183 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
184 action.sa_handler = handler; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
185 action.sa_flags = SA_RESTART; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
186 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
187 sigemptyset (&action.sa_mask); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
188 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
189 for (i = 0; i < n_signals; i++) |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
190 sigaddset (&action.sa_mask, signals_to_block[i]); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
191 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
192 if (sigaction (signal_number, &action, &old_action) == -1) |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
193 { |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
194 g_message ("Failed to install handler for signal %d", signal_number); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
195 return NULL; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
196 } |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
197 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
198 return old_action.sa_handler; |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
199 } |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
200 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
201 /* |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
202 * A version of signal() that works more reliably across different |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
203 * platforms. It: |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
204 * a. restarts interrupted system calls |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
205 * b. does not reset the handler |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
206 * c. blocks the same signal within the handler |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
207 * |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
208 * (adapted from Unix Network Programming Vol. 1) |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
209 */ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
210 static SignalHandler |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
211 signal_install_handler (gint signal_number, |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
212 SignalHandler handler) |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
213 { |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
214 return signal_install_handler_full (signal_number, handler, NULL, 0); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
215 } |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
216 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
217 |
2664
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
218 /* sets up blocking signals for pthreads. |
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
219 * linuxthreads sucks and needs this to make sigwait(2) work |
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
220 * correctly. --nenolod |
2666
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
221 * |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
222 * correction -- this trick does not work on linuxthreads. |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
223 * going to keep it in it's own function though --nenolod |
2664
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
224 */ |
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
225 static void |
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
226 signal_initialize_blockers(void) |
2313 | 227 { |
2629 | 228 sigset_t blockset; |
2486 | 229 |
2629 | 230 sigemptyset(&blockset); |
231 sigaddset(&blockset, SIGPIPE); | |
232 sigaddset(&blockset, SIGSEGV); | |
233 sigaddset(&blockset, SIGINT); | |
234 sigaddset(&blockset, SIGTERM); | |
2313 | 235 |
2674
f3ee0b78150a
[svn] - use pthread_sigmask(SIG_BLOCK, ...) instead of of SIG_SETMASK
nenolod
parents:
2666
diff
changeset
|
236 if(pthread_sigmask(SIG_BLOCK, &blockset, NULL)) |
2664
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
237 g_print("pthread_sigmask() failed.\n"); |
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
238 } |
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
239 |
2666
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
240 static gboolean |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
241 signal_check_for_broken_impl(void) |
2664
1d9c5db3341d
[svn] - handle sigwait(2) brokenness on linuxthreads
nenolod
parents:
2661
diff
changeset
|
242 { |
2666
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
243 #ifdef _CS_GNU_LIBPTHREAD_VERSION |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
244 { |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
245 gchar str[1024]; |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
246 confstr(_CS_GNU_LIBPTHREAD_VERSION, str, sizeof(str)); |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
247 |
4069
b26a96a5da69
change code a bit to avoid using strncasecmp which gives a warning here
mf0102 <0102@gmx.at>
parents:
3123
diff
changeset
|
248 if (g_ascii_strncasecmp("linuxthreads", str, 12) == 0) |
2666
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
249 return TRUE; |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
250 } |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
251 #endif |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
252 |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
253 return FALSE; |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
254 } |
2313 | 255 |
4492
55262ebeba2d
Conditional support for SM (libeggsmclient).
Matti Hamalainen <ccr@tnsp.org>
parents:
4449
diff
changeset
|
256 #ifdef USE_EGGSM |
4315
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
257 static void |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
258 signal_session_quit_cb(EggSMClient *client, gpointer user_data) |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
259 { |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
260 g_print("Session quit requested. Saving state and shutting down.\n"); |
4449
19e3f3c5fe7f
introduce function aud_quit(), which is basically mainwin_quit_cb(), but
mf0102 <0102@gmx.at>
parents:
4431
diff
changeset
|
261 aud_quit(); |
4315
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
262 } |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
263 |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
264 static void |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
265 signal_session_save_cb(EggSMClient *client, const char *state_dir, gpointer user_data) |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
266 { |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
267 g_print("Session save requested. Saving state.\n"); |
4412
180996fcf12a
bmp_config_* -> aud_config_*
Matti Hamalainen <ccr@tnsp.org>
parents:
4345
diff
changeset
|
268 aud_config_save(); |
4315
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
269 } |
4492
55262ebeba2d
Conditional support for SM (libeggsmclient).
Matti Hamalainen <ccr@tnsp.org>
parents:
4449
diff
changeset
|
270 #endif |
4315
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
271 |
2666
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
272 void |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
273 signal_handlers_init(void) |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
274 { |
4492
55262ebeba2d
Conditional support for SM (libeggsmclient).
Matti Hamalainen <ccr@tnsp.org>
parents:
4449
diff
changeset
|
275 #ifdef USE_EGGSM |
4315
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
276 EggSMClient *client; |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
277 |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
278 client = egg_sm_client_get (); |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
279 if (client != NULL) |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
280 { |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
281 egg_sm_client_set_mode (EGG_SM_CLIENT_MODE_NORMAL); |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
282 g_signal_connect (client, "quit", |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
283 G_CALLBACK (signal_session_quit_cb), NULL); |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
284 g_signal_connect (client, "save-state", |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
285 G_CALLBACK (signal_session_save_cb), NULL); |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
286 |
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
287 } |
4492
55262ebeba2d
Conditional support for SM (libeggsmclient).
Matti Hamalainen <ccr@tnsp.org>
parents:
4449
diff
changeset
|
288 #endif |
4315
c942eaef7bc6
Implement session management.
Ivan N. Zlatev <contact@i-nz.net>
parents:
4069
diff
changeset
|
289 |
2666
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
290 if (signal_check_for_broken_impl() != TRUE) |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
291 { |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
292 signal_initialize_blockers(); |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
293 g_thread_create(signal_process_signals, NULL, FALSE, NULL); |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
294 } |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
295 else |
2677
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
296 { |
2666
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
297 g_printerr(_("Your signaling implementation is broken.\n" |
78a8b3095274
[svn] - do not use the signal handler at all on linuxthreads and hope for the best
nenolod
parents:
2665
diff
changeset
|
298 "Expect unusable crash reports.\n")); |
2677
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
299 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
300 /* install special handler which catches signals and forwards to the signal handling thread */ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
301 signal_install_handler(SIGPIPE, linuxthread_handler); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
302 signal_install_handler(SIGSEGV, linuxthread_handler); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
303 signal_install_handler(SIGINT, linuxthread_handler); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
304 signal_install_handler(SIGTERM, linuxthread_handler); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
305 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
306 /* create handler thread */ |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
307 g_thread_create(signal_process_signals_linuxthread, NULL, FALSE, NULL); |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
308 |
52785bdac597
[svn] - workaround for linuxthread's broken implementation of sigwait().
yaz
parents:
2674
diff
changeset
|
309 } |
2313 | 310 } |