summaryrefslogtreecommitdiff
path: root/libpthread/sysdeps/generic/raise.c
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2010-08-01 01:52:54 +0200
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2010-08-01 01:52:54 +0200
commitd3c289d5867fefd5340328b7bd8cec32ca726d92 (patch)
treeabd01dcff720ad69b0d5c105b4ea78b9fb9a9db5 /libpthread/sysdeps/generic/raise.c
parent5b293b7099ab66c8c60529655df513ce2e640c3c (diff)
parent68567b88ee8f9e395e0c1f0a565affe8a1d4d68b (diff)
Merge tag 'upstream/libpthread/20090404' into upstream-merged
Diffstat (limited to 'libpthread/sysdeps/generic/raise.c')
-rw-r--r--libpthread/sysdeps/generic/raise.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/libpthread/sysdeps/generic/raise.c b/libpthread/sysdeps/generic/raise.c
new file mode 100644
index 00000000..410f557d
--- /dev/null
+++ b/libpthread/sysdeps/generic/raise.c
@@ -0,0 +1,41 @@
+/* raise.c - Generic raise implementation.
+ Copyright (C) 2008 Free Software Foundation, Inc.
+ Written by Neal H. Walfield <neal@gnu.org>.
+
+ This file is part of the GNU Hurd.
+
+ The GNU Hurd 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 3 of
+ the License, or (at your option) any later version.
+
+ The GNU Hurd 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 this program. If not, see
+ <http://www.gnu.org/licenses/>. */
+
+#include "sig-internal.h"
+
+int
+raise (int signo)
+{
+ /* According to POSIX, if we implement threads (and we do), then
+ "the effect of the raise() function shall be equivalent to
+ calling: pthread_kill(pthread_self(), sig);" */
+
+debug (0, "");
+ int err = pthread_kill (pthread_self (), signo);
+debug (0, "");
+ if (err)
+ {
+ errno = err;
+ return -1;
+ }
+
+ return 0;
+}
+