aboutsummaryrefslogtreecommitdiff
path: root/nptl/sysdeps/unix
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2003-06-08 16:30:17 +0000
committerUlrich Drepper <drepper@redhat.com>2003-06-08 16:30:17 +0000
commitecf7955d551d9527b2b6bf0a489b236f9da763b9 (patch)
treec8c3b252cfdf40b0f94cb791066e2407538817cf /nptl/sysdeps/unix
parent3e36c37d35827f060ee432712ba7fc0945e95a5b (diff)
downloadglibc-ecf7955d551d9527b2b6bf0a489b236f9da763b9.tar
glibc-ecf7955d551d9527b2b6bf0a489b236f9da763b9.tar.gz
glibc-ecf7955d551d9527b2b6bf0a489b236f9da763b9.tar.bz2
glibc-ecf7955d551d9527b2b6bf0a489b236f9da763b9.zip
Update.
* sysdeps/unix/sysv/linux/s390/sem_wait.c (__new_sem_wait): Make cancelable. * sysdeps/unix/sysv/linux/s390/sem_timedwait.c (__sem_timedwait): Likewise.
Diffstat (limited to 'nptl/sysdeps/unix')
-rw-r--r--nptl/sysdeps/unix/sysv/linux/s390/sem_timedwait.c32
-rw-r--r--nptl/sysdeps/unix/sysv/linux/s390/sem_wait.c30
2 files changed, 41 insertions, 21 deletions
diff --git a/nptl/sysdeps/unix/sysv/linux/s390/sem_timedwait.c b/nptl/sysdeps/unix/sysv/linux/s390/sem_timedwait.c
index 273b54164a..e43afdfc8b 100644
--- a/nptl/sysdeps/unix/sysv/linux/s390/sem_timedwait.c
+++ b/nptl/sysdeps/unix/sysv/linux/s390/sem_timedwait.c
@@ -23,6 +23,7 @@
#include <internaltypes.h>
#include <semaphore.h>
+#include <pthreadP.h>
#include <shlib-compat.h>
@@ -31,12 +32,18 @@ sem_timedwait (sem, abstime)
sem_t *sem;
const struct timespec *abstime;
{
- int oldval, newval;
+ /* First check for cancellation. */
+ CANCELLATION_P (THREAD_SELF);
- while (1)
+ int *futex = (int *) sem;
+ int oldval;
+ int newval;
+ int err;
+
+ do
{
/* Atomically decrement semaphore counter if it is > 0. */
- lll_compare_and_swap ((int *) sem, oldval, newval,
+ lll_compare_and_swap (futex, oldval, newval,
"ltr %2,%1; jnp 1f; ahi %2,-1");
/* oldval != newval if the semaphore count has been decremented. */
if (oldval != newval)
@@ -69,8 +76,14 @@ sem_timedwait (sem, abstime)
return -1;
}
+ /* Enable asynchronous cancellation. Required by the standard. */
+ int oldtype = __pthread_enable_asynccancel ();
+
/* Do wait. */
- int err = lll_futex_timed_wait ((int *) sem, 0, &rt);
+ err = lll_futex_timed_wait (futex, 0, &rt);
+
+ /* Disable asynchronous cancellation. */
+ __pthread_disable_asynccancel (oldtype);
/* Returned after timing out? */
if (err == -ETIMEDOUT)
@@ -78,12 +91,9 @@ sem_timedwait (sem, abstime)
__set_errno (ETIMEDOUT);
return -1;
}
-
- /* Handle EINTR. */
- if (err != 0 && err != -EWOULDBLOCK)
- {
- __set_errno (-err);
- return -1;
- }
}
+ while (err == 0 || err == -EWOULDBLOCK)
+
+ __set_errno (-err);
+ return -1;
}
diff --git a/nptl/sysdeps/unix/sysv/linux/s390/sem_wait.c b/nptl/sysdeps/unix/sysv/linux/s390/sem_wait.c
index a56e1e0a60..2be1dbbac4 100644
--- a/nptl/sysdeps/unix/sysv/linux/s390/sem_wait.c
+++ b/nptl/sysdeps/unix/sysv/linux/s390/sem_wait.c
@@ -23,35 +23,45 @@
#include <internaltypes.h>
#include <semaphore.h>
+#include <pthreadP.h>
#include <shlib-compat.h>
int
__new_sem_wait (sem_t *sem)
{
- while (1)
+ /* First check for cancellation. */
+ CANCELLATION_P (THREAD_SELF);
+
+ int *futex = (int *) sem;
+ int err;
+
+ do
{
int oldval;
int newval;
/* Atomically decrement semaphore counter if it is > 0. */
- lll_compare_and_swap ((int *) sem, oldval, newval,
+ lll_compare_and_swap (futex, oldval, newval,
"ltr %2,%1; jnp 1f; ahi %2,-1");
/* oldval != newval if the semaphore count has been decremented. */
if (oldval != newval)
return 0;
+ /* Enable asynchronous cancellation. Required by the standard. */
+ int oldtype = __pthread_enable_asynccancel ();
+
/* Do wait. */
- int err = lll_futex_wait ((int *) sem, 0);
-
- /* Handle EINTR. */
- if (err != 0 && err != -EWOULDBLOCK)
- {
- __set_errno (-err);
- return -1;
- }
+ err = lll_futex_wait (futex, 0);
+
+ /* Disable asynchronous cancellation. */
+ __pthread_disable_asynccancel (oldtype);
}
+ while (err == 0 || err == -EWOULDBLOCK);
+
+ __set_errno (-err);
+ return -1;
}
versioned_symbol (libpthread, __new_sem_wait, sem_wait, GLIBC_2_1);