svn commit: trunk/busybox/runit
vda at busybox.net
vda at busybox.net
Fri Feb 2 17:47:56 PST 2007
Author: vda
Date: 2007-02-02 17:47:56 -0800 (Fri, 02 Feb 2007)
New Revision: 17732
Log:
sigset_t blocked_sigset is too big for static (128 bytes)
Modified:
trunk/busybox/runit/svlogd.c
Changeset:
Modified: trunk/busybox/runit/svlogd.c
===================================================================
--- trunk/busybox/runit/svlogd.c 2007-02-03 00:53:43 UTC (rev 17731)
+++ trunk/busybox/runit/svlogd.c 2007-02-03 01:47:56 UTC (rev 17732)
@@ -54,7 +54,7 @@
static char repl;
static const char *replace = "";
-sigset_t blocked_sigset;
+static sigset_t *blocked_sigset;
static iopause_fd input;
static int fl_flag_0;
@@ -646,9 +646,9 @@
}
while (1) {
- sigprocmask(SIG_UNBLOCK, &blocked_sigset, NULL);
+ sigprocmask(SIG_UNBLOCK, blocked_sigset, NULL);
iopause(&input, 1, &trotate, now);
- sigprocmask(SIG_BLOCK, &blocked_sigset, NULL);
+ sigprocmask(SIG_BLOCK, blocked_sigset, NULL);
i = ndelay_read(fd, s, len);
if (i >= 0) break;
if (errno != EAGAIN) {
@@ -748,6 +748,7 @@
int svlogd_main(int argc, char **argv)
{
+ sigset_t ss;
char *r,*l,*b;
ssize_t stdin_cnt = 0;
int i;
@@ -801,12 +802,13 @@
* with the same stdin */
fl_flag_0 = fcntl(0, F_GETFL, 0);
- sigemptyset(&blocked_sigset);
- sigaddset(&blocked_sigset, SIGTERM);
- sigaddset(&blocked_sigset, SIGCHLD);
- sigaddset(&blocked_sigset, SIGALRM);
- sigaddset(&blocked_sigset, SIGHUP);
- sigprocmask(SIG_BLOCK, &blocked_sigset, NULL);
+ blocked_sigset = &ss;
+ sigemptyset(&ss);
+ sigaddset(&ss, SIGTERM);
+ sigaddset(&ss, SIGCHLD);
+ sigaddset(&ss, SIGALRM);
+ sigaddset(&ss, SIGHUP);
+ sigprocmask(SIG_BLOCK, &ss, NULL);
sig_catch(SIGTERM, sig_term_handler);
sig_catch(SIGCHLD, sig_child_handler);
sig_catch(SIGALRM, sig_alarm_handler);
More information about the busybox-cvs
mailing list