From 17f83c4e08b9c092c51087adc4b23faba914da8d Mon Sep 17 00:00:00 2001 From: Bernhard Reutner-Fischer Date: Mon, 6 Oct 2008 08:56:48 +0000 Subject: - Fallback waitid impl (Peter S. Mazinger) --- libc/sysdeps/linux/common/waitid.c | 45 +++++++++++++++++++++++++++++++++----- 1 file changed, 40 insertions(+), 5 deletions(-) (limited to 'libc/sysdeps') diff --git a/libc/sysdeps/linux/common/waitid.c b/libc/sysdeps/linux/common/waitid.c index b8d2f70ba..ce3d5dc05 100644 --- a/libc/sysdeps/linux/common/waitid.c +++ b/libc/sysdeps/linux/common/waitid.c @@ -5,12 +5,47 @@ * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball. */ -#include +#include #if defined __USE_SVID || defined __USE_XOPEN -#include -#include -#include +# include +# include +# include +# ifdef __NR_waitid +_syscall4(int, waitid, idtype_t, idtype, id_t, id, siginfo_t*, infop, int, options) +# else +# include +libc_hidden_proto(waitpid) +int waitid(idtype_t idtype, id_t id, siginfo_t *infop, int options) +{ + switch (idtype) { + case P_PID: + if (id <= 0) + goto invalid; + break; + case P_PGID: + if (id < 0 || id == 1) + goto invalid; + id = -id; + break; + case P_ALL: + id = -1; + break; + default: + invalid: + __set_errno(EINVAL); + return -1; + } -_syscall4(int, waitid, idtype_t, idtype, id_t, id, siginfo_t*, infop, int, options); + memset(infop, 0, sizeof *infop); + infop->si_pid = waitpid(id, &infop->si_status, options +# ifdef WEXITED + &~ WEXITED +# endif + ); + if (infop->si_pid < 0) + return infop->si_pid; + return 0; +} +# endif #endif -- cgit v1.2.3