glibc/sysdeps/mach/hurd/wait4.c
Samuel Thibault 09effdc9b0 hurd: make wait4 a cancellation point
and add _nocancel variant.

* sysdeps/mach/hurd/Makefile [io] (sysdep_routines): Add wait4_nocancel.
* sysdeps/mach/hurd/wait4.c: Include <sysdep-cancel.h>
(__wait4): Surround __proc_wait with enabling async cancel, and use
__USEPORT_CANCEL instead of __USEPORT.
* sysdeps/mach/hurd/wait4_nocancel.c: New file, contains previous
implementation of __wait4.
* sysdeps/mach/hurd/not-cancel.h (__waitpid_nocancel): Replace macro with
__wait4_nocancel declaration with hidden proto, and make
__waitpid_nocancel call __wait4_nocancel.
2020-06-28 18:04:27 +00:00

59 lines
1.9 KiB
C

/* Copyright (C) 1993-2020 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with the GNU C Library; if not, see
<https://www.gnu.org/licenses/>. */
#include <sys/types.h>
#include <sys/wait.h>
#include <errno.h>
#include <hurd.h>
#include <hurd/port.h>
#include <sysdep-cancel.h>
pid_t
__wait4 (pid_t pid, int *stat_loc, int options, struct rusage *usage)
{
pid_t dead;
error_t err;
struct rusage ignored;
int sigcode;
int dummy;
int cancel_oldtype;
cancel_oldtype = LIBC_CANCEL_ASYNC();
err = __USEPORT_CANCEL (PROC, __proc_wait (port, pid, options,
stat_loc ?: &dummy, &sigcode,
usage ?: &ignored, &dead));
LIBC_CANCEL_RESET (cancel_oldtype);
switch (err)
{
case 0: /* Got a child. */
return dead;
case EAGAIN:
/* The RPC returns this error when the WNOHANG flag is set and no
selected children are dead (but some are living). In that
situation, our return value is zero. (The RPC can't return zero
for DEAD without also returning some garbage for the other out
parameters, so an error return is much more natural here. Hence
the difference between the RPC and the POSIX.1 interface. */
return (pid_t) 0;
default:
return (pid_t) __hurd_fail (err);
}
}
libc_hidden_def (__wait4)
weak_alias (__wait4, wait4)