Fix some uses of ret in libpthread
[glibc/nacl-glibc.git] / nptl / sysdeps / unix / sysv / linux / i386 / i486 / sem_trywait.S
blobc766a86a1050b0d104c8d50a75100c70d43866eb
1 /* Copyright (C) 2002, 2003, 2005, 2007 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
3    Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, write to the Free
17    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18    02111-1307 USA.  */
20 #include <sysdep.h>
21 #include <shlib-compat.h>
22 #include <pthread-errnos.h>
23 #include <lowlevellock.h>
25         .text
27         .globl  __new_sem_trywait
28         .type   __new_sem_trywait,@function
29         .align  16
30 __new_sem_trywait:
31         movl    4(%esp), %ecx
33         movl    (%ecx), %eax
34 2:      testl   %eax, %eax
35         jz      1f
37         leal    -1(%eax), %edx
38         LOCK
39         cmpxchgl %edx, (%ecx)
40         jne     2b
41         xorl    %eax, %eax
42         popl %ecx; nacljmp %ecx
45 #ifdef PIC
46         call    __i686.get_pc_thunk.cx
47 #else
48         movl    $3f, %ecx
50 #endif
51         addl    $_GLOBAL_OFFSET_TABLE_, %ecx
52 #if USE___THREAD
53 # ifdef NO_TLS_DIRECT_SEG_REFS
54         movl    errno@gotntpoff(%ecx), %edx
55         addl    %gs:0, %edx
56         movl    $EAGAIN, (%edx)
57 # else
58         movl    errno@gotntpoff(%ecx), %edx
59         movl    $EAGAIN, %gs:(%edx)
60 # endif
61 #else
62         call    __errno_location@plt
63         movl    $EAGAIN, (%eax)
64 #endif
65         orl     $-1, %eax
66         popl %ecx; nacljmp %ecx
67         .size   __new_sem_trywait,.-__new_sem_trywait
68         versioned_symbol(libpthread, __new_sem_trywait, sem_trywait, GLIBC_2_1)
69 #if SHLIB_COMPAT(libpthread, GLIBC_2_0, GLIBC_2_1)
70         .global __old_sem_trywait
71 __old_sem_trywait = __new_sem_trywait
72         compat_symbol(libpthread, __old_sem_trywait, sem_trywait, GLIBC_2_0)
73 #endif
76 #ifdef PIC
77         .section .gnu.linkonce.t.__i686.get_pc_thunk.cx,"ax",@progbits
78         .globl  __i686.get_pc_thunk.cx
79         .hidden __i686.get_pc_thunk.cx
80         .type   __i686.get_pc_thunk.cx,@function
81 __i686.get_pc_thunk.cx:
82         movl (%esp), %ecx;
83         popl %ecx; nacljmp %ecx
84         .size   __i686.get_pc_thunk.cx,.-__i686.get_pc_thunk.cx
85 #endif