2014-11-07 17:25:32 +00:00
|
|
|
/* Shared HTM header. Emulate transactional execution facility intrinsics for
|
|
|
|
compilers and assemblers that do not support the intrinsics and instructions
|
|
|
|
yet.
|
|
|
|
|
2019-01-01 00:11:28 +00:00
|
|
|
Copyright (C) 2015-2019 Free Software Foundation, Inc.
|
2014-11-07 17:25:32 +00:00
|
|
|
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
|
Prefer https to http for gnu.org and fsf.org URLs
Also, change sources.redhat.com to sourceware.org.
This patch was automatically generated by running the following shell
script, which uses GNU sed, and which avoids modifying files imported
from upstream:
sed -ri '
s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g
s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g
' \
$(find $(git ls-files) -prune -type f \
! -name '*.po' \
! -name 'ChangeLog*' \
! -path COPYING ! -path COPYING.LIB \
! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \
! -path manual/texinfo.tex ! -path scripts/config.guess \
! -path scripts/config.sub ! -path scripts/install-sh \
! -path scripts/mkinstalldirs ! -path scripts/move-if-change \
! -path INSTALL ! -path locale/programs/charmap-kw.h \
! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \
! '(' -name configure \
-execdir test -f configure.ac -o -f configure.in ';' ')' \
! '(' -name preconfigure \
-execdir test -f preconfigure.ac ';' ')' \
-print)
and then by running 'make dist-prepare' to regenerate files built
from the altered files, and then executing the following to cleanup:
chmod a+x sysdeps/unix/sysv/linux/riscv/configure
# Omit irrelevant whitespace and comment-only changes,
# perhaps from a slightly-different Autoconf version.
git checkout -f \
sysdeps/csky/configure \
sysdeps/hppa/configure \
sysdeps/riscv/configure \
sysdeps/unix/sysv/linux/csky/configure
# Omit changes that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines
git checkout -f \
sysdeps/powerpc/powerpc64/ppc-mcount.S \
sysdeps/unix/sysv/linux/s390/s390-64/syscall.S
# Omit change that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline
git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
2019-09-07 05:40:42 +00:00
|
|
|
<https://www.gnu.org/licenses/>. */
|
2014-11-07 17:25:32 +00:00
|
|
|
|
|
|
|
#ifndef _HTM_H
|
|
|
|
#define _HTM_H 1
|
|
|
|
|
|
|
|
#ifdef __ASSEMBLER__
|
|
|
|
|
|
|
|
/* tbegin. */
|
|
|
|
.macro TBEGIN
|
|
|
|
.long 0x7c00051d
|
|
|
|
.endm
|
|
|
|
|
|
|
|
/* tend. 0 */
|
|
|
|
.macro TEND
|
|
|
|
.long 0x7c00055d
|
|
|
|
.endm
|
|
|
|
|
|
|
|
/* tabort. code */
|
|
|
|
.macro TABORT code
|
|
|
|
.byte 0x7c
|
|
|
|
.byte \code
|
|
|
|
.byte 0x07
|
|
|
|
.byte 0x1d
|
|
|
|
.endm
|
|
|
|
|
|
|
|
/*"TEXASR - Transaction EXception And Summary Register"
|
|
|
|
mfspr %dst,130 */
|
|
|
|
.macro TEXASR dst
|
|
|
|
mfspr \dst,130
|
|
|
|
.endm
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#include <endian.h>
|
|
|
|
|
|
|
|
/* Official HTM intrinsics interface matching GCC, but works
|
|
|
|
on older GCC compatible compilers and binutils.
|
|
|
|
We should somehow detect if the compiler supports it, because
|
|
|
|
it may be able to generate slightly better code. */
|
|
|
|
|
|
|
|
#define TBEGIN ".long 0x7c00051d"
|
|
|
|
#define TEND ".long 0x7c00055d"
|
|
|
|
#if __BYTE_ORDER == __LITTLE_ENDIAN
|
2015-02-12 11:34:16 +00:00
|
|
|
# define TABORT ".byte 0x1d,0x07,%1,0x7c"
|
2014-11-07 17:25:32 +00:00
|
|
|
#else
|
|
|
|
# define TABORT ".byte 0x7c,%1,0x07,0x1d"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define __force_inline inline __attribute__((__always_inline__))
|
|
|
|
|
|
|
|
#ifndef __HTM__
|
|
|
|
|
|
|
|
#define _TEXASRU_EXTRACT_BITS(TEXASR,BITNUM,SIZE) \
|
|
|
|
(((TEXASR) >> (31-(BITNUM))) & ((1<<(SIZE))-1))
|
|
|
|
#define _TEXASRU_FAILURE_PERSISTENT(TEXASRU) \
|
|
|
|
_TEXASRU_EXTRACT_BITS(TEXASRU, 7, 1)
|
|
|
|
|
|
|
|
#define _tbegin() \
|
|
|
|
({ unsigned int __ret; \
|
|
|
|
asm volatile ( \
|
|
|
|
TBEGIN "\t\n" \
|
|
|
|
"mfcr %0\t\n" \
|
|
|
|
"rlwinm %0,%0,3,1\t\n" \
|
|
|
|
"xori %0,%0,1\t\n" \
|
|
|
|
: "=r" (__ret) : \
|
|
|
|
: "cr0", "memory"); \
|
|
|
|
__ret; \
|
|
|
|
})
|
|
|
|
|
|
|
|
#define _tend() \
|
|
|
|
({ unsigned int __ret; \
|
|
|
|
asm volatile ( \
|
|
|
|
TEND "\t\n" \
|
|
|
|
"mfcr %0\t\n" \
|
|
|
|
"rlwinm %0,%0,3,1\t\n" \
|
|
|
|
"xori %0,%0,1\t\n" \
|
|
|
|
: "=r" (__ret) : \
|
|
|
|
: "cr0", "memory"); \
|
|
|
|
__ret; \
|
|
|
|
})
|
|
|
|
|
|
|
|
#define _tabort(__code) \
|
|
|
|
({ unsigned int __ret; \
|
|
|
|
asm volatile ( \
|
|
|
|
TABORT "\t\n" \
|
|
|
|
"mfcr %0\t\n" \
|
|
|
|
"rlwinm %0,%0,3,1\t\n" \
|
|
|
|
"xori %0,%0,1\t\n" \
|
|
|
|
: "=r" (__ret) : "r" (__code) \
|
|
|
|
: "cr0", "memory"); \
|
|
|
|
__ret; \
|
|
|
|
})
|
|
|
|
|
|
|
|
#define _texasru() \
|
|
|
|
({ unsigned long __ret; \
|
|
|
|
asm volatile ( \
|
|
|
|
"mfspr %0,131\t\n" \
|
|
|
|
: "=r" (__ret)); \
|
|
|
|
__ret; \
|
|
|
|
})
|
|
|
|
|
2015-12-28 14:24:43 +00:00
|
|
|
#define __libc_tbegin(tdb) _tbegin ()
|
|
|
|
#define __libc_tend(nested) _tend ()
|
|
|
|
#define __libc_tabort(abortcode) _tabort (abortcode)
|
|
|
|
#define __builtin_get_texasru() _texasru ()
|
2014-11-07 17:25:32 +00:00
|
|
|
|
|
|
|
#else
|
|
|
|
# include <htmintrin.h>
|
2015-12-28 14:24:43 +00:00
|
|
|
|
|
|
|
# ifdef __TM_FENCE__
|
|
|
|
/* New GCC behavior. */
|
2016-01-20 16:33:19 +00:00
|
|
|
# define __libc_tbegin(R) __builtin_tbegin (R)
|
|
|
|
# define __libc_tend(R) __builtin_tend (R)
|
|
|
|
# define __libc_tabort(R) __builtin_tabort (R)
|
2015-12-28 14:24:43 +00:00
|
|
|
# else
|
|
|
|
/* Workaround an old GCC behavior. Earlier releases of GCC 4.9 and 5.0,
|
|
|
|
didn't use to treat __builtin_tbegin, __builtin_tend and
|
|
|
|
__builtin_tabort as compiler barriers, moving instructions into and
|
|
|
|
out the transaction.
|
|
|
|
Remove this when glibc drops support for GCC 5.0. */
|
|
|
|
# define __libc_tbegin(R) \
|
|
|
|
({ __asm__ volatile("" ::: "memory"); \
|
|
|
|
unsigned int __ret = __builtin_tbegin (R); \
|
|
|
|
__asm__ volatile("" ::: "memory"); \
|
|
|
|
__ret; \
|
|
|
|
})
|
|
|
|
# define __libc_tabort(R) \
|
|
|
|
({ __asm__ volatile("" ::: "memory"); \
|
|
|
|
unsigned int __ret = __builtin_tabort (R); \
|
|
|
|
__asm__ volatile("" ::: "memory"); \
|
|
|
|
__ret; \
|
|
|
|
})
|
|
|
|
# define __libc_tend(R) \
|
|
|
|
({ __asm__ volatile("" ::: "memory"); \
|
|
|
|
unsigned int __ret = __builtin_tend (R); \
|
|
|
|
__asm__ volatile("" ::: "memory"); \
|
|
|
|
__ret; \
|
|
|
|
})
|
|
|
|
# endif /* __TM_FENCE__ */
|
2014-11-07 17:25:32 +00:00
|
|
|
#endif /* __HTM__ */
|
|
|
|
|
|
|
|
#endif /* __ASSEMBLER__ */
|
|
|
|
|
2015-10-28 22:34:31 +00:00
|
|
|
/* Definitions used for TEXASR Failure code (bits 0:7). If the failure
|
|
|
|
should be persistent, the abort code must be odd. 0xd0 through 0xff
|
|
|
|
are reserved for the kernel and potential hypervisor. */
|
|
|
|
#define _ABORT_PERSISTENT 0x01 /* An unspecified persistent abort. */
|
|
|
|
#define _ABORT_LOCK_BUSY 0x34 /* Busy lock, not persistent. */
|
|
|
|
#define _ABORT_NESTED_TRYLOCK (0x32 | _ABORT_PERSISTENT)
|
|
|
|
#define _ABORT_SYSCALL (0x30 | _ABORT_PERSISTENT)
|
2014-11-07 17:25:32 +00:00
|
|
|
|
|
|
|
#endif
|