(pthread_barrier_wait): Don't save, load, and restore %esi for last thread.
[kopensolaris-gnu/glibc.git] / nptl / sysdeps / unix / sysv / linux / i386 / i486 / sem_post.S
1 /* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
3    Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
4
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.
9
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.
14
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.  */
19
20 #include <sysdep.h>
21 #include <shlib-compat.h>
22
23 #ifndef UP
24 # define LOCK lock
25 #else
26 # define
27 #endif
28
29 #define SYS_futex               240
30 #define FUTEX_WAKE              1
31
32 #define EAGAIN                  11
33 #define EINVAL                  22
34
35
36         .text
37
38         .globl  __new_sem_post
39         .type   __new_sem_post,@function
40         .align  16
41 __new_sem_post:
42         pushl   %ebx
43
44         movl    8(%esp), %ebx
45         movl    $1, %edx
46         LOCK
47         xaddl   %edx, (%ebx)
48
49         movl    $SYS_futex, %eax
50         movl    $FUTEX_WAKE, %ecx
51         incl    %edx
52         ENTER_KERNEL
53
54         testl   %eax, %eax
55         js      1f
56
57         xorl    %eax, %eax
58         popl    %ebx
59         ret
60
61 1:
62 #ifdef PIC
63         call    __i686.get_pc_thunk.bx
64 #else
65         movl    $4f, %ebx
66 4:
67 #endif
68         addl    $_GLOBAL_OFFSET_TABLE_, %ebx
69 #if USE___THREAD
70         movl    %gs:0, %edx
71         subl    errno@gottpoff(%ebx), %edx
72         movl    $EINVAL, (%edx)
73 #else
74         call    __errno_location@plt
75         movl    $EAGAIN, (%eax)
76 #endif
77
78         orl     $-1, %eax
79         popl    %ebx
80         ret
81         .size   __new_sem_post,.-__new_sem_post
82         .symver __new_sem_post, sem_post@@GLIBC_2.1
83 #if SHLIB_COMPAT(libpthread, GLIBC_2_0, GLIBC_2_1)
84         .global __old_sem_post
85 __old_sem_post = __new_sem_post
86         .symver __old_sem_post, sem_post@GLIBC_2.0
87 #endif
88
89
90 #ifdef PIC
91         .section .gnu.linkonce.t.__i686.get_pc_thunk.bx,"ax",@progbits
92         .globl  __i686.get_pc_thunk.bx
93         .hidden __i686.get_pc_thunk.bx
94         .type   __i686.get_pc_thunk.bx,@function
95 __i686.get_pc_thunk.bx:
96         movl (%esp), %ebx;
97         ret
98         .size   __i686.get_pc_thunk.bx,.-__i686.get_pc_thunk.bx
99 #endif