2017-01-01 00:14:16 +00:00
|
|
|
/* Copyright (C) 2003-2017 Free Software Foundation, Inc.
|
2003-02-05 09:54:24 +00:00
|
|
|
This file is part of the GNU C Library.
|
|
|
|
Contributed by Martin Schwidefsky <schwidefsky@de.ibm.com>, 2003.
|
|
|
|
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
Lesser General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
2012-02-09 23:18:22 +00:00
|
|
|
License along with the GNU C Library; if not, see
|
|
|
|
<http://www.gnu.org/licenses/>. */
|
2003-02-05 09:54:24 +00:00
|
|
|
|
|
|
|
#include <errno.h>
|
|
|
|
#include <sysdep.h>
|
2014-12-04 13:12:23 +00:00
|
|
|
#include <futex-internal.h>
|
2003-02-05 09:54:24 +00:00
|
|
|
#include <pthread.h>
|
|
|
|
#include <pthreadP.h>
|
2012-05-25 20:35:08 +00:00
|
|
|
#include <stap-probe.h>
|
2014-03-31 15:07:46 +00:00
|
|
|
|
2014-05-22 14:00:12 +00:00
|
|
|
#include "pthread_rwlock_common.c"
|
2003-02-05 09:54:24 +00:00
|
|
|
|
2014-05-22 14:00:12 +00:00
|
|
|
/* See pthread_rwlock_common.c for an overview. */
|
2003-02-27 10:32:38 +00:00
|
|
|
int
|
|
|
|
__pthread_rwlock_unlock (pthread_rwlock_t *rwlock)
|
2003-02-05 09:54:24 +00:00
|
|
|
{
|
2012-05-25 20:35:08 +00:00
|
|
|
LIBC_PROBE (rwlock_unlock, 1, rwlock);
|
|
|
|
|
2014-05-22 14:00:12 +00:00
|
|
|
/* We distinguish between having acquired a read vs. a write lock by looking
|
|
|
|
at the writer TID. If it's equal to our TID, we must be the writer
|
|
|
|
because nobody else can have stored this value. Also, if we are a
|
|
|
|
reader, we will read from the wrunlock store with value 0 by the most
|
|
|
|
recent writer because that writer happens-before us. */
|
|
|
|
if (atomic_load_relaxed (&rwlock->__data.__cur_writer)
|
|
|
|
== THREAD_GETMEM (THREAD_SELF, tid))
|
|
|
|
__pthread_rwlock_wrunlock (rwlock);
|
2003-02-05 09:54:24 +00:00
|
|
|
else
|
2014-05-22 14:00:12 +00:00
|
|
|
__pthread_rwlock_rdunlock (rwlock);
|
2003-02-05 09:54:24 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
weak_alias (__pthread_rwlock_unlock, pthread_rwlock_unlock)
|
2012-05-26 20:16:19 +00:00
|
|
|
hidden_def (__pthread_rwlock_unlock)
|