if (!schedule->is_locked)
SILC_SCHEDULE_LOCK(schedule);
+ /* Deliver signals if any has been set to be called */
+ if (schedule->signal_tasks) {
+ SILC_SCHEDULE_UNLOCK(schedule);
+ silc_schedule_internal_signals_call(schedule->internal, schedule);
+ schedule->signal_tasks = FALSE;
+ SILC_SCHEDULE_LOCK(schedule);
+ }
+
/* If the task queues aren't initialized or we aren't valid anymore
we will return */
if ((!schedule->fd_queue && !schedule->timeout_queue
SILC_SCHEDULE_UNLOCK(schedule);
- /* Deliver signals if any has been set to be called */
- if (schedule->signal_tasks) {
- silc_schedule_internal_signals_call(schedule->internal, schedule);
- schedule->signal_tasks = FALSE;
- }
-
/* This is the main select(). The program blocks here until some
of the selected file descriptors change status or the selected
timeout expires. */
SilcUnixScheduler internal = (SilcUnixScheduler)context;
int i;
+ sigprocmask(SIG_BLOCK, &internal->signals, &internal->signals_blocked);
+
for (i = 0; i < SIGNAL_COUNT; i++) {
if (!internal->signal_call[i].signal) {
internal->signal_call[i].signal = signal;
internal->signal_call[i].callback = callback;
internal->signal_call[i].context = callback_context;
internal->signal_call[i].call = FALSE;
+ break;
}
}
+ sigprocmask(SIG_SETMASK, &internal->signals_blocked, NULL);
sigaddset(&internal->signals, signal);
}
SilcUnixScheduler internal = (SilcUnixScheduler)context;
int i;
+ sigprocmask(SIG_BLOCK, &internal->signals, &internal->signals_blocked);
+
for (i = 0; i < SIGNAL_COUNT; i++) {
if (internal->signal_call[i].signal == signal &&
internal->signal_call[i].callback == callback &&
}
}
+ sigprocmask(SIG_SETMASK, &internal->signals_blocked, NULL);
sigdelset(&internal->signals, signal);
}
SilcUnixScheduler internal = (SilcUnixScheduler)context;
int i;
+ sigprocmask(SIG_BLOCK, &internal->signals, &internal->signals_blocked);
+
for (i = 0; i < SIGNAL_COUNT; i++) {
if (internal->signal_call[i].signal == signal)
internal->signal_call[i].call = TRUE;
}
+
+ sigprocmask(SIG_SETMASK, &internal->signals_blocked, NULL);
}
/* Call all signals */
SilcUnixScheduler internal = (SilcUnixScheduler)context;
int i;
+ sigprocmask(SIG_BLOCK, &internal->signals, &internal->signals_blocked);
+
for (i = 0; i < SIGNAL_COUNT; i++) {
if (internal->signal_call[i].call &&
internal->signal_call[i].callback) {
internal->signal_call[i].call = FALSE;
}
}
+
+ sigprocmask(SIG_SETMASK, &internal->signals_blocked, NULL);
}
/* Block registered signals in scheduler. */