mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-12 12:07:12 +08:00
c795f356aa
2003-06-20 Richard Henderson <rth@redhat.com> * sysdeps/unix/alpha/sysdep.h (INLINE_SYSCALL1): Use __builtin_expect. * sysdeps/unix/sysv/linux/kernel-features.h (__ASSUME_ST_INO_64_BIT) Unset for alpha. (__ASSUME_TIMEVAL64): Set for alpha. * sysdeps/unix/sysv/linux/alpha/Makefile (sysdep_routines): Remove adjtimex, osf_sigprocmask, old_adjtimex. * sysdeps/unix/sysv/linux/alpha/adjtime.c: Use INLINE_SYSCALL, __ASSUME_TIMEVAL64. Reorg tv64 functions to avoid uninit variable. * sysdeps/unix/sysv/linux/alpha/getitimer.S: Use __ASSUME_TIMEVAL64. * sysdeps/unix/sysv/linux/alpha/getrusage.S: Likewise. * sysdeps/unix/sysv/linux/alpha/gettimeofday.S: Likewise. * sysdeps/unix/sysv/linux/alpha/select.S: Likewise. * sysdeps/unix/sysv/linux/alpha/setitimer.S: Likewise. * sysdeps/unix/sysv/linux/alpha/settimeofday.S: Likewise. * sysdeps/unix/sysv/linux/alpha/utimes.S: Likewise. * sysdeps/unix/sysv/linux/alpha/wait4.S: Likewise. * sysdeps/unix/sysv/linux/alpha/ieee_get_fp_control.S: Streamline PIC code sequence. * sysdeps/unix/sysv/linux/alpha/ieee_set_fp_control.S: Likewise. * sysdeps/unix/sysv/linux/alpha/sigaction.c: New file. * sysdeps/unix/sysv/linux/alpha/sigprocmask.c: Use INLINE_SYSCALL. * sysdeps/unix/sysv/linux/alpha/ustat.c: Likewise. * sysdeps/unix/sysv/linux/alpha/xmknod.c: Likewise. * sysdeps/unix/sysv/linux/alpha/syscalls.list: Remove osf_sigprocmask, sys_ustat, sys_mknod, adjtimex, old_adjtimex. * sysdeps/unix/sysv/linux/alpha/sysdep.h (INLINE_SYSCALL): Don't defer to __syscall_name; error for rt_sigaction. * sysdeps/unix/sysv/linux/alpha/xstatconv.c: Include kernel_stat.h.
59 lines
1.8 KiB
C
59 lines
1.8 KiB
C
/* Copyright (C) 1993, 1995, 1997, 2003 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
Contributed by David Mosberger (davidm@azstarnet.com).
|
|
|
|
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, write to the Free
|
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
02111-1307 USA. */
|
|
|
|
#include <errno.h>
|
|
#include <sysdep.h>
|
|
#include <signal.h>
|
|
|
|
/* When there is kernel support for more than 64 signals, we'll have to
|
|
switch to a new system call convention here. */
|
|
|
|
int
|
|
__sigprocmask (int how, const sigset_t *set, sigset_t *oset)
|
|
{
|
|
unsigned long int setval;
|
|
long result;
|
|
|
|
if (set)
|
|
setval = set->__val[0];
|
|
else
|
|
{
|
|
setval = 0;
|
|
how = SIG_BLOCK; /* ensure blocked mask doesn't get changed */
|
|
}
|
|
|
|
result = INLINE_SYSCALL (osf_sigprocmask, 2, how, setval);
|
|
if (result == -1)
|
|
/* If there are ever more than 63 signals, we need to recode this
|
|
in assembler since we wouldn't be able to distinguish a mask of
|
|
all 1s from -1, but for now, we're doing just fine... */
|
|
return result;
|
|
|
|
if (oset)
|
|
{
|
|
oset->__val[0] = result;
|
|
result = _SIGSET_NWORDS;
|
|
while (--result > 0)
|
|
oset->__val[result] = 0;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
weak_alias (__sigprocmask, sigprocmask);
|