mirror of
https://sourceware.org/git/glibc.git
synced 2025-12-06 12:01:08 +03:00
The only usage was for pthread_spin_lock, introduced by 12d2dd7060,
as a way to optimize the code for certain architectures. Now that atomic
builtins are used by default, let the compiler use the best code sequence
for the atomic exchange.
Co-authored-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
Reviewed-by: Wilco Dijkstra <Wilco.Dijkstra@arm.com>
58 lines
1.7 KiB
C
58 lines
1.7 KiB
C
/* Copyright (C) 2003-2025 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
|
|
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
|
|
<https://www.gnu.org/licenses/>. */
|
|
|
|
#include "pthreadP.h"
|
|
#include <shlib-compat.h>
|
|
|
|
#define __ARCH_ACQ_INSTR "isync"
|
|
#if defined _ARCH_PWR6 || defined _ARCH_PWR6X
|
|
# define MUTEX_HINT_ACQ ",1"
|
|
# define MUTEX_HINT_REL ",0"
|
|
#else
|
|
# define MUTEX_HINT_ACQ
|
|
# define MUTEX_HINT_REL
|
|
#endif
|
|
|
|
int
|
|
__pthread_spin_lock (pthread_spinlock_t *lock)
|
|
{
|
|
unsigned int __tmp;
|
|
|
|
asm volatile (
|
|
"1: lwarx %0,0,%1" MUTEX_HINT_ACQ "\n"
|
|
" cmpwi 0,%0,0\n"
|
|
" bne- 2f\n"
|
|
" stwcx. %2,0,%1\n"
|
|
" bne- 2f\n"
|
|
__ARCH_ACQ_INSTR "\n"
|
|
" .subsection 1\n"
|
|
"2: lwzx %0,0,%1\n"
|
|
" cmpwi 0,%0,0\n"
|
|
" bne 2b\n"
|
|
" b 1b\n"
|
|
" .previous"
|
|
: "=&r" (__tmp)
|
|
: "r" (lock), "r" (1)
|
|
: "cr0", "memory");
|
|
return 0;
|
|
}
|
|
versioned_symbol (libc, __pthread_spin_lock, pthread_spin_lock, GLIBC_2_34);
|
|
|
|
#if OTHER_SHLIB_COMPAT (libpthread, GLIBC_2_2, GLIBC_2_34)
|
|
compat_symbol (libpthread, __pthread_spin_lock, pthread_spin_lock, GLIBC_2_2);
|
|
#endif
|