mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-27 14:36:16 +01:00
gmain: Consolidate UNIX signal init state handling
For a future signalfd() patch, it will be easier to handle if we don't separate initialization from watching for a particular signal. https://bugzilla.gnome.org/show_bug.cgi?id=651725
This commit is contained in:
parent
6ea274bca4
commit
c34a6a66e7
61
glib/gmain.c
61
glib/gmain.c
@ -373,8 +373,8 @@ static gboolean g_child_watch_dispatch (GSource *source,
|
|||||||
GSourceFunc callback,
|
GSourceFunc callback,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
#ifdef G_OS_UNIX
|
#ifdef G_OS_UNIX
|
||||||
|
static gpointer unix_signal_helper_thread (gpointer data) G_GNUC_NORETURN;
|
||||||
static void g_unix_signal_handler (int signum);
|
static void g_unix_signal_handler (int signum);
|
||||||
static void init_unix_signal_wakeup_state_unlocked (void);
|
|
||||||
static gboolean g_unix_signal_watch_prepare (GSource *source,
|
static gboolean g_unix_signal_watch_prepare (GSource *source,
|
||||||
gint *timeout);
|
gint *timeout);
|
||||||
static gboolean g_unix_signal_watch_check (GSource *source);
|
static gboolean g_unix_signal_watch_check (GSource *source);
|
||||||
@ -4390,6 +4390,32 @@ static void
|
|||||||
ensure_unix_signal_handler_installed_unlocked (int signum)
|
ensure_unix_signal_handler_installed_unlocked (int signum)
|
||||||
{
|
{
|
||||||
struct sigaction action;
|
struct sigaction action;
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
|
if (unix_signal_init_state == UNIX_SIGNAL_UNINITIALIZED
|
||||||
|
|| unix_signal_init_state == UNIX_SIGNAL_INITIALIZED_SINGLE)
|
||||||
|
{
|
||||||
|
if (!g_thread_supported ())
|
||||||
|
{
|
||||||
|
/* There is nothing to do for initializing in the non-threaded
|
||||||
|
* case.
|
||||||
|
*/
|
||||||
|
if (unix_signal_init_state == UNIX_SIGNAL_UNINITIALIZED)
|
||||||
|
unix_signal_init_state = UNIX_SIGNAL_INITIALIZED_SINGLE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (!g_unix_open_pipe (unix_signal_wake_up_pipe, FD_CLOEXEC, &error))
|
||||||
|
g_error ("Cannot create UNIX signal wake up pipe: %s\n", error->message);
|
||||||
|
g_unix_set_fd_nonblocking (unix_signal_wake_up_pipe[1], TRUE, NULL);
|
||||||
|
|
||||||
|
/* We create a helper thread that polls on the wakeup pipe indefinitely */
|
||||||
|
if (g_thread_create (unix_signal_helper_thread, NULL, FALSE, &error) == NULL)
|
||||||
|
g_error ("Cannot create a thread to monitor UNIX signals: %s\n", error->message);
|
||||||
|
|
||||||
|
unix_signal_init_state = UNIX_SIGNAL_INITIALIZED_THREADED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch (signum)
|
switch (signum)
|
||||||
{
|
{
|
||||||
@ -4414,8 +4440,6 @@ ensure_unix_signal_handler_installed_unlocked (int signum)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
init_unix_signal_wakeup_state_unlocked ();
|
|
||||||
|
|
||||||
action.sa_handler = g_unix_signal_handler;
|
action.sa_handler = g_unix_signal_handler;
|
||||||
sigemptyset (&action.sa_mask);
|
sigemptyset (&action.sa_mask);
|
||||||
action.sa_flags = SA_RESTART | SA_NOCLDSTOP;
|
action.sa_flags = SA_RESTART | SA_NOCLDSTOP;
|
||||||
@ -4549,8 +4573,6 @@ deliver_unix_signal (int signum)
|
|||||||
G_UNLOCK (unix_signal_lock);
|
G_UNLOCK (unix_signal_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gpointer unix_signal_helper_thread (gpointer data) G_GNUC_NORETURN;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This thread is created whenever anything in GLib needs
|
* This thread is created whenever anything in GLib needs
|
||||||
* to deal with UNIX signals; at present, just SIGCHLD
|
* to deal with UNIX signals; at present, just SIGCHLD
|
||||||
@ -4619,35 +4641,6 @@ unix_signal_helper_thread (gpointer data)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
init_unix_signal_wakeup_state_unlocked (void)
|
|
||||||
{
|
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
if (!g_thread_supported ())
|
|
||||||
{
|
|
||||||
/* There is nothing to do for initializing in the non-threaded
|
|
||||||
* case.
|
|
||||||
*/
|
|
||||||
if (unix_signal_init_state == UNIX_SIGNAL_UNINITIALIZED)
|
|
||||||
unix_signal_init_state = UNIX_SIGNAL_INITIALIZED_SINGLE;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (unix_signal_init_state == UNIX_SIGNAL_INITIALIZED_THREADED)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (!g_unix_open_pipe (unix_signal_wake_up_pipe, FD_CLOEXEC, &error))
|
|
||||||
g_error ("Cannot create UNIX signal wake up pipe: %s\n", error->message);
|
|
||||||
g_unix_set_fd_nonblocking (unix_signal_wake_up_pipe[1], TRUE, NULL);
|
|
||||||
|
|
||||||
/* We create a helper thread that polls on the wakeup pipe indefinitely */
|
|
||||||
if (g_thread_create (unix_signal_helper_thread, NULL, FALSE, &error) == NULL)
|
|
||||||
g_error ("Cannot create a thread to monitor UNIX signals: %s\n", error->message);
|
|
||||||
|
|
||||||
unix_signal_init_state = UNIX_SIGNAL_INITIALIZED_THREADED;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
g_child_watch_source_init (void)
|
g_child_watch_source_init (void)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user