No subject
Thu Oct 6 05:08:24 CDT 2011
DESCRIPTION
These functions are provided in glibc as a compatibility interface =
for
programs that make use of the historical System V signal API. This =
API
is obsolete: new applications should use the POSIX signal API (sig=
ac=E2=80=90
tion(2), sigprocmask(2), etc.)
Signed-off-by: Kamal Dasu <kdasu.kdev at gmail.com>
---
copy/xfs_copy.c | 17 ++++++++++++++---
1 files changed, 14 insertions(+), 3 deletions(-)
diff --git a/copy/xfs_copy.c b/copy/xfs_copy.c
index c01e0b9..69c85bd 100644
--- a/copy/xfs_copy.c
+++ b/copy/xfs_copy.c
@@ -71,6 +71,17 @@ xfs_off_t write_log_header(int fd, wbuf *w, xfs_mount_t =
*mp);
#define PRE 0x08 /* append strerror string */
#define LAST 0x10 /* final message we print */
=20
+
+void
+signal_maskfunc(int addset, int newset)=20
+{
+ sigset_t set;
+
+ sigemptyset(&set);
+ sigaddset(&set, addset);
+ sigprocmask(newset, &set, NULL);
+}
+
void
do_message(int flags, int code, const char *fmt, ...)
{
@@ -478,9 +489,9 @@ write_wbuf(void)
if (target[i].state !=3D INACTIVE)
pthread_mutex_unlock(&targ[i].wait); /* wake up */
=20
- sigrelse(SIGCHLD);
+ signal_maskfunc(SIGCHLD, SIG_UNBLOCK);
pthread_mutex_lock(&mainwait);
- sighold(SIGCHLD);
+ signal_maskfunc(SIGCHLD, SIG_BLOCK);
}
=20
=20
@@ -847,7 +858,7 @@ main(int argc, char **argv)
/* set up sigchild signal handler */
=20
signal(SIGCHLD, handler);
- sighold(SIGCHLD);
+ signal_maskfunc(SIGCHLD, SIG_BLOCK);
=20
/* make children */
=20
--=20
1.7.5.4
More information about the xfs
mailing list