summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/common/__rt_sigtimedwait.c
diff options
context:
space:
mode:
authorEric Andersen <andersen@codepoet.org>2004-01-21 23:27:48 +0000
committerEric Andersen <andersen@codepoet.org>2004-01-21 23:27:48 +0000
commit6334e558ab33ee1e54ed33740881a2798c5915c2 (patch)
tree5d3253d5928343d2a37cc55be7a9c35244b4ab42 /libc/sysdeps/linux/common/__rt_sigtimedwait.c
parent9bafaa6fe7ded400aac87526ce615f1875ce2673 (diff)
Split up syscalls.c, since it had grown to be quite large and ugly.
-Erik
Diffstat (limited to 'libc/sysdeps/linux/common/__rt_sigtimedwait.c')
-rw-r--r--libc/sysdeps/linux/common/__rt_sigtimedwait.c48
1 files changed, 48 insertions, 0 deletions
diff --git a/libc/sysdeps/linux/common/__rt_sigtimedwait.c b/libc/sysdeps/linux/common/__rt_sigtimedwait.c
new file mode 100644
index 000000000..c5020039e
--- /dev/null
+++ b/libc/sysdeps/linux/common/__rt_sigtimedwait.c
@@ -0,0 +1,48 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * __rt_sigtimedwait() for uClibc
+ *
+ * Copyright (C) 2000-2004 by Erik Andersen <andersen@codpoet.org>
+ *
+ * GNU Library General Public License (LGPL) version 2 or later.
+ */
+
+#include "syscalls.h"
+#include <signal.h>
+#define __need_NULL
+#include <stddef.h>
+#ifdef __NR_rt_sigtimedwait
+#define __NR___rt_sigtimedwait __NR_rt_sigtimedwait
+_syscall4(int, __rt_sigtimedwait, const sigset_t *, set, siginfo_t *, info,
+ const struct timespec *, timeout, size_t, setsize);
+
+int sigwaitinfo(const sigset_t * set, siginfo_t * info)
+{
+ return __rt_sigtimedwait(set, info, NULL, _NSIG / 8);
+}
+
+int sigtimedwait(const sigset_t * set, siginfo_t * info,
+ const struct timespec *timeout)
+{
+ return __rt_sigtimedwait(set, info, timeout, _NSIG / 8);
+}
+#else
+int sigwaitinfo(const sigset_t * set, siginfo_t * info)
+{
+ if (set == NULL)
+ __set_errno(EINVAL);
+ else
+ __set_errno(ENOSYS);
+ return -1;
+}
+
+int sigtimedwait(const sigset_t * set, siginfo_t * info,
+ const struct timespec *timeout)
+{
+ if (set == NULL)
+ __set_errno(EINVAL);
+ else
+ __set_errno(ENOSYS);
+ return -1;
+}
+#endif