From 90b65e2d06b900f3d282515d2d0f7113a56eca99 Mon Sep 17 00:00:00 2001 From: Jeff Johnston Date: Mon, 26 Aug 2002 18:56:09 +0000 Subject: 2002-08-26 Jeff Johnston * Makefile.am(LIBC_OBJECTLISTS): Add STDIO64_OBJECTLIST. * Makefile.in: Regenerated. * acinclude.m4: Add support for --enable-newlib-elix-level option. * aclocal.m4: Regenerated. * configure: Ditto. * configure.host: Add code to define _ELIX_LEVEL if --enable-newlib-elix-level option is used. * configure.in: * libc/aclocal.m4: Regenerated. * libc/configure: Ditto. * libc/argz/Makefile.am: Add EL/IX level checking. * libc/argz/Makefile.in: Regenerated. * libc/argz/dummy.c: New file. * libc/ctype/Makefile.am: Add EL/IX level checking. * libc/ctype/Makefile.in: Regenerated. * libc/locale/Makefile.am: Add EL/IX level checking. * libc/locale/Makefile.in: Regenerated. * libc/posix/Makefile.am: Add EL/IX level checking. * libc/posix/Makefile.in: Regenerated. * libc/posix/telldir.c: Add EL/IX level checking. * libc/reent/Makefile.am: Ditto. * libc/reent/fstat64r.c: Ditto. * libc/reent/lseek64r.c: Ditto. * libc/reent/open64r.c: Ditto. * libc/reent/Makefile.in: Regenerated. * libc/search/Makefile.am: Add EL/IX level checking. * libc/search/Makefile.in: Regenerated. * libc/stdio/Makefile.am: Add EL/IX level checking. * libc/stdio/Makefile.in: Regenerated. * libc/stdio64/Makefile.am: Add EL/IX level checking. * libc/stdio64/Makefile.in: Regenerated. * libc/stdio64/dummy.c: New file. * libc/stdio64/fgetpos64.c: Fix so _LARGEFILE_64 macro is checked after first include. * libc/stdio64/fopen64.c: Ditto. * libc/stdio64/freopen64.c: Ditto. * libc/stdio64/fseeko64.c: Ditto. * libc/stdio64/fsetpos64.c: Ditto. * libc/stdio64/ftello64.c: Ditto. * libc/stdio64/tmpfile64.c: Ditto. * libc/stdlib/Makefile.am: Add EL/IX level checking. * libc/stdlib/Makefile.in: Regenerated. * libc/stdlib/mstats.c: Add EL/IX level checking. * libc/string/Makefile.am: Ditto. * libc/string/Makefile.in: Regenerated. * libc/sys/linux/Makefile.am: Add EL/IX level checking. * libc/sys/linux/Makefile.in: Regenerated. * libc/sys/linux/aclocal.m4: Ditto. * libc/sys/linux/configure: Ditto. * libc/sys/linux/aio.c: Add EL/IX level checking. * libc/sys/linux/ftok.c: Ditto. * libc/sys/linux/getdate.c: Ditto. * libc/sys/linux/ids.c: Ditto. * libc/sys/linux/inode.c: Ditto. * libc/sys/linux/io.c: Ditto. * libc/sys/linux/process.c: Ditto. * libc/sys/linux/resource.c: Ditto. * libc/sys/linux/sched.c: Ditto. * libc/sys/linux/sig.c: Ditto. * libc/sys/linux/termios.c: Ditto. * libc/sys/linux/wait.c: Ditto plus add __waitpid and __libc___waitpid weak aliases. * libc/sys/linux/machine/i386/syscall.h: Add new _base macros that generate the code for a syscall, but do not create a weak alias. * libc/syscalls/Makefile.am: Add EL/IX level checking. * libc/syscalls/Makefile.in: Regenerated. * libc/time/tzset_r.c: Change to replace strdup with equivalent functionality. * libc/unix/Makefile.am: Add EL/IX level checking. * libc/unix/Makefile.in: Regenerated. --- newlib/libc/sys/linux/sig.c | 28 ++++++++++++++++------------ 1 file changed, 16 insertions(+), 12 deletions(-) (limited to 'newlib/libc/sys/linux/sig.c') diff --git a/newlib/libc/sys/linux/sig.c b/newlib/libc/sys/linux/sig.c index d083b1744..6e22873ee 100644 --- a/newlib/libc/sys/linux/sig.c +++ b/newlib/libc/sys/linux/sig.c @@ -21,8 +21,6 @@ _syscall2(__sighandler_t,signal,int,signum,__sighandler_t,handler) _syscall0(int,pause) _syscall1(unsigned int,alarm,unsigned int,seconds) -static _syscall0(int,__sgetmask) -static _syscall1(int,__ssetmask,int,newmask) static _syscall2(int,__rt_sigpending,sigset_t *,set,size_t,size) static _syscall4(int,__rt_sigprocmask,int,how,const sigset_t *,set,sigset_t *,oldset,size_t,size) static _syscall2(int,__rt_sigsuspend,const sigset_t *,mask,size_t,size) @@ -34,21 +32,11 @@ int __sigsuspend (const sigset_t *mask) } weak_alias(__sigsuspend,sigsuspend) -int sigsetmask(int newmask) /* BSD */ -{ - return __ssetmask(newmask); -} - int sigmask(int signum) /* BSD */ { return 1 << signum; } -int sigblock(int mask) /* BSD */ -{ - return __ssetmask(mask | __sgetmask()); -} - int __libc_raise(int sig) { return kill(getpid(),sig); @@ -78,6 +66,22 @@ int sigwaitinfo(const sigset_t *set, siginfo_t *info) return __rt_sigtimedwait(set, info, NULL, NSIG/8); } +#if !defined(_ELIX_LEVEL) || _ELIX_LEVEL >= 4 + +static _syscall1(int,__ssetmask,int,newmask) +static _syscall0(int,__sgetmask) + +int sigblock(int mask) /* BSD */ +{ + return __ssetmask(mask | __sgetmask()); +} + +int sigsetmask(int newmask) /* BSD */ +{ + return __ssetmask(newmask); +} +#endif + const char *const sys_siglist[] = { #include "siglist.inc" }; -- cgit v1.2.3