Wake only when there are waiters.
[kopensolaris-gnu/glibc.git] / nptl / sysdeps / unix / sysv / linux / x86_64 / sem_post.S
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.
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 #include <pthread-errnos.h>
23 #include <structsem.h>
24
25 #ifndef UP
26 # define LOCK lock
27 #else
28 # define
29 #endif
30
31 #define SYS_futex               202
32 #define FUTEX_WAKE              1
33
34
35         .text
36
37         .globl  sem_post
38         .type   sem_post,@function
39         .align  16
40 sem_post:
41         LOCK
42 #if VALUE == 0
43         addl    $1, (%rdi)
44 #else
45         addl    $1, VALUE(%rdi)
46 #endif
47
48         cmpq    $0, NWAITERS(%rdi)
49         je      2f
50
51         movl    $SYS_futex, %eax
52         movl    $FUTEX_WAKE, %esi
53         movl    $1, %edx
54         syscall
55
56         testq   %rax, %rax
57         js      1f
58
59 2:      xorl    %eax, %eax
60         retq
61
62 1:
63 #if USE___THREAD
64         movq    errno@gottpoff(%rip), %rdx
65         movl    $EINVAL, %fs:(%rdx)
66 #else
67         callq   __errno_location@plt
68         movl    $EINVAL, (%rax)
69 #endif
70
71         orl     $-1, %eax
72         retq
73         .size   sem_post,.-sem_post