aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--nptl/ChangeLog4
-rw-r--r--nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.S11
-rw-r--r--nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.S7
-rw-r--r--nptl/tst-rwlock6.c23
4 files changed, 36 insertions, 9 deletions
diff --git a/nptl/ChangeLog b/nptl/ChangeLog
index 9dd21a739e..9219b2753d 100644
--- a/nptl/ChangeLog
+++ b/nptl/ChangeLog
@@ -1,3 +1,7 @@
+2003-03-16 Ulrich Drepper <drepper@redhat.com>
+
+ * tst-rwlock6.c: Add some more status output.
+
2003-03-15 Roland McGrath <roland@redhat.com>
* sysdeps/pthread/configure.in: New file.
diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.S
index fd04e116c7..b522f3c07e 100644
--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.S
+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.S
@@ -45,6 +45,7 @@
pthread_rwlock_timedrdlock:
pushq %r12
pushq %r13
+ pushq %r14
subq $16, %rsp
movq %rdi, %r12
@@ -76,14 +77,14 @@ pthread_rwlock_timedrdlock:
incl READERS_QUEUED(%r12)
je 4f
- movl READERS_WAKEUP(%r12), %edx
+ movl READERS_WAKEUP(%r12), %r14d
/* Unlock. */
LOCK
#if MUTEX == 0
- subl $1, (%r12)
+ decl (%r12)
#else
- subl $1, MUTEX(%r12)
+ decl MUTEX(%r12)
#endif
jne 10f
@@ -112,7 +113,8 @@ pthread_rwlock_timedrdlock:
movq %rdi, 8(%rsp)
xorq %rsi, %rsi /* movq $FUTEX_WAIT, %rsi */
- xorq %r10, %r10
+ movq %rsp, %r10
+ movl %r14d, %edx
leaq READERS_WAKEUP(%r12), %rdi
movq $SYS_futex, %rax
syscall
@@ -152,6 +154,7 @@ pthread_rwlock_timedrdlock:
7: movq %rdx, %rax
addq $16, %rsp
+ popq %r14
popq %r13
popq %r12
retq
diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.S
index 75c6cc42b4..6cbadabb07 100644
--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.S
+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.S
@@ -44,6 +44,7 @@
pthread_rwlock_timedwrlock:
pushq %r12
pushq %r13
+ pushq %r14
subq $16, %rsp
movq %rdi, %r12
@@ -73,7 +74,7 @@ pthread_rwlock_timedwrlock:
incl WRITERS_QUEUED(%r12)
je 4f
- movl WRITERS_WAKEUP(%r12), %edx
+ movl WRITERS_WAKEUP(%r12), %r14d
LOCK
#if MUTEX == 0
@@ -109,6 +110,7 @@ pthread_rwlock_timedwrlock:
xorq %rsi, %rsi /* movq $FUTEX_WAIT, %rsi */
movq %rsp, %r10
+ movl %r14d, %edx
leaq WRITERS_WAKEUP(%r12), %rdi
movq $SYS_futex, %rax
syscall
@@ -134,7 +136,7 @@ pthread_rwlock_timedwrlock:
jmp 9f
-5: xorq %rcx, %rdx
+5: xorq %rdx, %rdx
movq %fs:SELF, %rax
movq %rax, WRITER(%r12)
9: LOCK
@@ -148,6 +150,7 @@ pthread_rwlock_timedwrlock:
7: movq %rdx, %rax
addq $16, %rsp
+ popq %r14
popq %r13
popq %r12
retq
diff --git a/nptl/tst-rwlock6.c b/nptl/tst-rwlock6.c
index ea7f4ba634..86cd10b5ee 100644
--- a/nptl/tst-rwlock6.c
+++ b/nptl/tst-rwlock6.c
@@ -51,6 +51,8 @@ tf (void *arg)
++ts.tv_sec;
}
+ puts ("child calling timedrdlock");
+
int err = pthread_rwlock_timedrdlock (r, &ts);
if (err == 0)
{
@@ -65,6 +67,8 @@ tf (void *arg)
pthread_exit ((void *) 1l);
}
+ puts ("1st child timedrdlock done");
+
struct timeval tv2;
(void) gettimeofday (&tv2, NULL);
@@ -94,6 +98,8 @@ tf (void *arg)
pthread_exit ((void *) 1l);
}
+ puts ("2nd child timedrdlock done");
+
return NULL;
}
@@ -140,16 +146,19 @@ do_test (void)
++ts.tv_sec;
/* Get a write lock. */
- if (pthread_rwlock_timedwrlock (&r, &ts) != 0)
+ int e = pthread_rwlock_timedwrlock (&r, &ts);
+ if (e != 0)
{
- printf ("round %d: rwlock_wrlock failed\n", cnt);
+ printf ("round %d: rwlock_timedwrlock failed (%d)\n", cnt, e);
exit (1);
}
+ puts ("1st timedwrlock done");
+
(void) gettimeofday (&tv, NULL);
TIMEVAL_TO_TIMESPEC (&tv, &ts);
++ts.tv_sec;
- int e = pthread_rwlock_timedrdlock (&r, &ts);
+ e = pthread_rwlock_timedrdlock (&r, &ts);
if (e == 0)
{
puts ("timedrdlock succeeded");
@@ -161,6 +170,8 @@ do_test (void)
exit (1);
}
+ puts ("1st timedrdlock done");
+
(void) gettimeofday (&tv, NULL);
TIMEVAL_TO_TIMESPEC (&tv, &ts);
++ts.tv_sec;
@@ -176,6 +187,8 @@ do_test (void)
exit (1);
}
+ puts ("2nd timedwrlock done");
+
pthread_t th;
if (pthread_create (&th, NULL, tf, &r) != 0)
{
@@ -183,6 +196,8 @@ do_test (void)
exit (1);
}
+ puts ("started thread");
+
void *status;
if (pthread_join (th, &status) != 0)
{
@@ -195,6 +210,8 @@ do_test (void)
exit (1);
}
+ puts ("joined thread");
+
if (pthread_rwlock_destroy (&r) != 0)
{
printf ("round %d: rwlock_destroy failed\n", cnt);