about summary refs log tree commit diff
path: root/nptl/pthread_rwlock_trywrlock.c
diff options
context:
space:
mode:
Diffstat (limited to 'nptl/pthread_rwlock_trywrlock.c')
-rw-r--r--nptl/pthread_rwlock_trywrlock.c61
1 files changed, 0 insertions, 61 deletions
diff --git a/nptl/pthread_rwlock_trywrlock.c b/nptl/pthread_rwlock_trywrlock.c
deleted file mode 100644
index 0d9ccaf79c..0000000000
--- a/nptl/pthread_rwlock_trywrlock.c
+++ /dev/null
@@ -1,61 +0,0 @@
-/* Copyright (C) 2002-2017 Free Software Foundation, Inc.
-   This file is part of the GNU C Library.
-   Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
-
-   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
-   License along with the GNU C Library; if not, see
-   <http://www.gnu.org/licenses/>.  */
-
-#include <errno.h>
-#include "pthreadP.h"
-#include <atomic.h>
-
-/* See pthread_rwlock_common.c for an overview.  */
-int
-__pthread_rwlock_trywrlock (pthread_rwlock_t *rwlock)
-{
-  /* When in a trywrlock, we can acquire the write lock if it is in states
-     #1 (idle and read phase) and #5 (idle and write phase), and also in #6
-     (readers waiting, write phase) if we prefer writers.
-     If we observe any other state, we are allowed to fail and do not need to
-     "synchronize memory" as specified by POSIX (hence relaxed MO is
-     sufficient for the first load and the CAS failure path).
-     We face a similar issue as in tryrdlock in that we need to both avoid
-     live-locks / starvation and must not fail spuriously (see there for
-     further comments) -- and thus must loop until we get a definitive
-     observation or state change.  */
-  unsigned int r = atomic_load_relaxed (&rwlock->__data.__readers);
-  bool prefer_writer =
-      (rwlock->__data.__flags != PTHREAD_RWLOCK_PREFER_READER_NP);
-  while (((r & PTHREAD_RWLOCK_WRLOCKED) == 0)
-      && (((r >> PTHREAD_RWLOCK_READER_SHIFT) == 0)
-	  || (prefer_writer && ((r & PTHREAD_RWLOCK_WRPHASE) != 0))))
-    {
-      /* Try to transition to states #7 or #8 (i.e., acquire the lock).  */
-      if (atomic_compare_exchange_weak_acquire (
-	  &rwlock->__data.__readers, &r,
-	  r | PTHREAD_RWLOCK_WRPHASE | PTHREAD_RWLOCK_WRLOCKED))
-	{
-	  atomic_store_relaxed (&rwlock->__data.__writers_futex, 1);
-	  atomic_store_relaxed (&rwlock->__data.__wrphase_futex, 1);
-	  atomic_store_relaxed (&rwlock->__data.__cur_writer,
-	      THREAD_GETMEM (THREAD_SELF, tid));
-	  return 0;
-	}
-      /* TODO Back-off.  */
-      /* See above.  */
-    }
-  return EBUSY;
-}
-
-strong_alias (__pthread_rwlock_trywrlock, pthread_rwlock_trywrlock)