diff options
author | Ulrich Drepper <drepper@redhat.com> | 2003-02-06 08:38:56 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2003-02-06 08:38:56 +0000 |
commit | 11090a992df365ac6b107027f2c932028172dcbf (patch) | |
tree | 55c0fbdd46957216487f59f5233901e7ccd5a8c6 /nptl/sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S | |
parent | 432cf458f981cb1e9c9051cc39217fc7773f45dd (diff) | |
download | glibc-11090a992df365ac6b107027f2c932028172dcbf.tar.gz glibc-11090a992df365ac6b107027f2c932028172dcbf.tar.xz glibc-11090a992df365ac6b107027f2c932028172dcbf.zip |
Update.
2003-02-06 Ulrich Drepper <drepper@redhat.com> * sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S: Remove wrong but inactive generalization. * sysdeps/unix/sysv/linux/i386/i486/pthread_cond_timedwait.S: Likewise. * sysdeps/unix/sysv/linux/i386/i486/pthread_cond_signal.S: Likewise. Minor optimization, remove one instruction. * sysdeps/unix/sysv/linux/i386/i486/pthread_cond_broadcast.S: Likewise.
Diffstat (limited to 'nptl/sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S')
-rw-r--r-- | nptl/sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/nptl/sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S b/nptl/sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S index 438fcca6a4..e43bcbac82 100644 --- a/nptl/sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S +++ b/nptl/sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S @@ -41,9 +41,6 @@ __condvar_cleanup: pushl %ebx movl 8(%esp), %ebx -#if cond_lock != 0 - addl $cond_lock, %ebx -#endif /* Get internal lock. */ movl $1, %eax @@ -70,7 +67,11 @@ __condvar_cleanup: adcl $0, woken_seq+4(%ebx) LOCK +#if cond_lock == 0 decl (%ebx) +#else + decl cond_lock(%ebx) +#endif je 2f #if cond_lock == 0 movl %ebx, %eax @@ -96,9 +97,6 @@ __pthread_cond_wait: xorl %esi, %esi movl 16(%esp), %ebx -#if cond_lock != 0 - addl $cond_lock, %ebx -#endif /* Get internal lock. */ movl $1, %eax @@ -153,10 +151,10 @@ __pthread_cond_wait: movl %esi, %ecx /* movl $FUTEX_WAIT, %ecx */ movl %edi, %edx - addl $wakeup_seq-cond_lock, %ebx + addl $wakeup_seq, %ebx movl $SYS_futex, %eax ENTER_KERNEL - subl $wakeup_seq-cond_lock, %ebx + subl $wakeup_seq, %ebx call __pthread_disable_asynccancel |