Blame nptl/pthread_rwlock_unlock.c

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