2021-01-02 19:32:25 +00:00
|
|
|
/* Copyright (C) 1997-2021 Free Software Foundation, Inc.
|
1997-06-29 22:05:27 +00:00
|
|
|
This file is part of the GNU C Library.
|
|
|
|
Contributed by Richard Henderson <richard@gnu.ai.mit.edu>, 1997.
|
|
|
|
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
2001-07-06 04:58:11 +00:00
|
|
|
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.
|
1997-06-29 22:05:27 +00:00
|
|
|
|
|
|
|
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
|
2001-07-06 04:58:11 +00:00
|
|
|
Lesser General Public License for more details.
|
1997-06-29 22:05:27 +00:00
|
|
|
|
2001-07-06 04:58:11 +00:00
|
|
|
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
|
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/>. */
|
1997-06-29 22:05:27 +00:00
|
|
|
|
|
|
|
#ifndef _LINUX_SPARC64_SYSDEP_H
|
|
|
|
#define _LINUX_SPARC64_SYSDEP_H 1
|
|
|
|
|
Delete everything under sysdeps/unix/sparc/
* sysdeps/unix/sparc/brk.S: Delete.
* sysdeps/unix/sparc/dl-brk.S: Delete.
* sysdeps/unix/sparc/pipe.S: Delete.
* sysdeps/unix/sparc/sysdep.S: Delete.
* sysdeps/unix/sparc/sysdep.h: Delete.
* sysdeps/unix/sparc/vfork.S: Delete.
* sysdeps/sparc/sysdep.h (SPARC_PIC_THUNK, SPARC_PIC_REG,
SPARC_PIC_REG_LEAF, ENTRY, END, LOC): Define.
* sysdeps/unix/sysv/linux/sparc/sysdep.h (ret, ret_NOERRNO,
ret_ERRVAL, r0, r1, MOVE): Define.
(JUMPTARGET): Remove.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Don't include
sysdeps/unix/sparc/sysdep.h
(ENTRY, END): Remove.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Likewise.
2012-04-25 18:44:02 +00:00
|
|
|
#include <sysdeps/unix/sysv/linux/sparc/sysdep.h>
|
1997-06-29 22:05:27 +00:00
|
|
|
|
2014-11-20 15:39:43 +00:00
|
|
|
#if IS_IN (rtld)
|
* sysdeps/unix/sysv/linux/s390/s390-32/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/s390/s390-64/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/x86_64/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Include
dl-sysdep.h.
(SYSCALL_ERROR_HANDLER): Define RTLD_PRIVATE_ERRNO variant.
(__INTERNAL_SYSCALL_STRING): Define.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Include
dl-sysdep.h.
(SYSCALL_ERROR_HANDLER): Define RTLD_PRIVATE_ERRNO variant.
(__INTERNAL_SYSCALL_STRING): Define.
* sysdeps/unix/sysv/linux/sparc/sysdep.h (INLINE_SYSCALL): Pass
__SYSCALL_STRING to inline_syscall*.
(INTERNAL_SYSCALL, INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO):
New macros.
(inline_syscall0, inline_syscall1, inline_syscall2, inline_syscall3,
inline_syscall4, inline_syscall5, inline_syscall6): Add string
argument.
2002-10-24 Roland McGrath <roland@redhat.com>
* libio/bug-wfflush.c: New file.
* libio/Makefile (tests): Add bug-wfflush.
2002-10-24 18:49:00 +00:00
|
|
|
# include <dl-sysdep.h> /* Defines RTLD_PRIVATE_ERRNO. */
|
|
|
|
#endif
|
2006-01-06 22:58:39 +00:00
|
|
|
#include <tls.h>
|
* sysdeps/unix/sysv/linux/s390/s390-32/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/s390/s390-64/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/x86_64/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Include
dl-sysdep.h.
(SYSCALL_ERROR_HANDLER): Define RTLD_PRIVATE_ERRNO variant.
(__INTERNAL_SYSCALL_STRING): Define.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Include
dl-sysdep.h.
(SYSCALL_ERROR_HANDLER): Define RTLD_PRIVATE_ERRNO variant.
(__INTERNAL_SYSCALL_STRING): Define.
* sysdeps/unix/sysv/linux/sparc/sysdep.h (INLINE_SYSCALL): Pass
__SYSCALL_STRING to inline_syscall*.
(INTERNAL_SYSCALL, INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO):
New macros.
(inline_syscall0, inline_syscall1, inline_syscall2, inline_syscall3,
inline_syscall4, inline_syscall5, inline_syscall6): Add string
argument.
2002-10-24 Roland McGrath <roland@redhat.com>
* libio/bug-wfflush.c: New file.
* libio/Makefile (tests): Add bug-wfflush.
2002-10-24 18:49:00 +00:00
|
|
|
|
1997-06-29 22:05:27 +00:00
|
|
|
#undef SYS_ify
|
|
|
|
#define SYS_ify(syscall_name) __NR_##syscall_name
|
|
|
|
|
1998-05-29 10:21:16 +00:00
|
|
|
#ifdef __ASSEMBLER__
|
1997-06-29 22:05:27 +00:00
|
|
|
|
2002-12-28 09:27:26 +00:00
|
|
|
#define LOADSYSCALL(x) mov __NR_##x, %g1
|
1997-06-29 22:05:27 +00:00
|
|
|
|
|
|
|
#undef PSEUDO
|
2006-03-06 01:34:09 +00:00
|
|
|
#define PSEUDO(name, syscall_name, args) \
|
|
|
|
.text; \
|
|
|
|
ENTRY(name); \
|
|
|
|
LOADSYSCALL(syscall_name); \
|
|
|
|
ta 0x6d; \
|
|
|
|
bcc,pt %xcc, 1f; \
|
2011-09-01 00:30:41 +00:00
|
|
|
nop; \
|
|
|
|
SYSCALL_ERROR_HANDLER \
|
2006-03-06 01:34:09 +00:00
|
|
|
1:
|
|
|
|
|
Delete everything under sysdeps/unix/sparc/
* sysdeps/unix/sparc/brk.S: Delete.
* sysdeps/unix/sparc/dl-brk.S: Delete.
* sysdeps/unix/sparc/pipe.S: Delete.
* sysdeps/unix/sparc/sysdep.S: Delete.
* sysdeps/unix/sparc/sysdep.h: Delete.
* sysdeps/unix/sparc/vfork.S: Delete.
* sysdeps/sparc/sysdep.h (SPARC_PIC_THUNK, SPARC_PIC_REG,
SPARC_PIC_REG_LEAF, ENTRY, END, LOC): Define.
* sysdeps/unix/sysv/linux/sparc/sysdep.h (ret, ret_NOERRNO,
ret_ERRVAL, r0, r1, MOVE): Define.
(JUMPTARGET): Remove.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Don't include
sysdeps/unix/sparc/sysdep.h
(ENTRY, END): Remove.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Likewise.
2012-04-25 18:44:02 +00:00
|
|
|
#undef PSEUDO_NOERRNO
|
2006-03-06 01:34:09 +00:00
|
|
|
#define PSEUDO_NOERRNO(name, syscall_name, args)\
|
|
|
|
.text; \
|
|
|
|
ENTRY(name); \
|
|
|
|
LOADSYSCALL(syscall_name); \
|
|
|
|
ta 0x6d;
|
|
|
|
|
Delete everything under sysdeps/unix/sparc/
* sysdeps/unix/sparc/brk.S: Delete.
* sysdeps/unix/sparc/dl-brk.S: Delete.
* sysdeps/unix/sparc/pipe.S: Delete.
* sysdeps/unix/sparc/sysdep.S: Delete.
* sysdeps/unix/sparc/sysdep.h: Delete.
* sysdeps/unix/sparc/vfork.S: Delete.
* sysdeps/sparc/sysdep.h (SPARC_PIC_THUNK, SPARC_PIC_REG,
SPARC_PIC_REG_LEAF, ENTRY, END, LOC): Define.
* sysdeps/unix/sysv/linux/sparc/sysdep.h (ret, ret_NOERRNO,
ret_ERRVAL, r0, r1, MOVE): Define.
(JUMPTARGET): Remove.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Don't include
sysdeps/unix/sparc/sysdep.h
(ENTRY, END): Remove.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Likewise.
2012-04-25 18:44:02 +00:00
|
|
|
#undef PSEUDO_ERRVAL
|
2006-03-06 01:34:09 +00:00
|
|
|
#define PSEUDO_ERRVAL(name, syscall_name, args) \
|
|
|
|
.text; \
|
|
|
|
ENTRY(name); \
|
|
|
|
LOADSYSCALL(syscall_name); \
|
|
|
|
ta 0x6d;
|
|
|
|
|
Delete everything under sysdeps/unix/sparc/
* sysdeps/unix/sparc/brk.S: Delete.
* sysdeps/unix/sparc/dl-brk.S: Delete.
* sysdeps/unix/sparc/pipe.S: Delete.
* sysdeps/unix/sparc/sysdep.S: Delete.
* sysdeps/unix/sparc/sysdep.h: Delete.
* sysdeps/unix/sparc/vfork.S: Delete.
* sysdeps/sparc/sysdep.h (SPARC_PIC_THUNK, SPARC_PIC_REG,
SPARC_PIC_REG_LEAF, ENTRY, END, LOC): Define.
* sysdeps/unix/sysv/linux/sparc/sysdep.h (ret, ret_NOERRNO,
ret_ERRVAL, r0, r1, MOVE): Define.
(JUMPTARGET): Remove.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Don't include
sysdeps/unix/sparc/sysdep.h
(ENTRY, END): Remove.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Likewise.
2012-04-25 18:44:02 +00:00
|
|
|
#undef PSEUDO_END
|
2006-03-06 01:34:09 +00:00
|
|
|
#define PSEUDO_END(name) \
|
|
|
|
END(name)
|
2004-12-22 20:10:10 +00:00
|
|
|
|
2011-09-01 00:30:41 +00:00
|
|
|
#ifndef PIC
|
|
|
|
# define SYSCALL_ERROR_HANDLER \
|
|
|
|
mov %o7, %g1; \
|
|
|
|
call __syscall_error; \
|
|
|
|
mov %g1, %o7;
|
|
|
|
#else
|
|
|
|
# if RTLD_PRIVATE_ERRNO
|
2012-03-01 23:04:16 +00:00
|
|
|
# define SYSCALL_ERROR_HANDLER \
|
2012-02-21 23:42:42 +00:00
|
|
|
0: SETUP_PIC_REG_LEAF(o2,g1) \
|
|
|
|
sethi %gdop_hix22(rtld_errno), %g1; \
|
|
|
|
xor %g1, %gdop_lox10(rtld_errno), %g1;\
|
|
|
|
ldx [%o2 + %g1], %g1, %gdop(rtld_errno); \
|
|
|
|
st %o0, [%g1]; \
|
|
|
|
jmp %o7 + 8; \
|
|
|
|
mov -1, %o0;
|
2011-09-01 00:30:41 +00:00
|
|
|
# elif defined _LIBC_REENTRANT
|
|
|
|
|
2014-11-24 09:33:45 +00:00
|
|
|
# if IS_IN (libc)
|
2011-09-10 20:50:28 +00:00
|
|
|
# define SYSCALL_ERROR_ERRNO __libc_errno
|
|
|
|
# else
|
|
|
|
# define SYSCALL_ERROR_ERRNO errno
|
|
|
|
# endif
|
2012-02-19 06:31:42 +00:00
|
|
|
# define SYSCALL_ERROR_HANDLER \
|
|
|
|
0: SETUP_PIC_REG_LEAF(o2,g1) \
|
2011-09-01 00:30:41 +00:00
|
|
|
sethi %tie_hi22(SYSCALL_ERROR_ERRNO), %g1; \
|
|
|
|
add %g1, %tie_lo10(SYSCALL_ERROR_ERRNO), %g1; \
|
|
|
|
ldx [%o2 + %g1], %g1, %tie_ldx(SYSCALL_ERROR_ERRNO);\
|
2011-09-10 20:50:28 +00:00
|
|
|
st %o0, [%g7 + %g1]; \
|
|
|
|
jmp %o7 + 8; \
|
2011-09-01 00:30:41 +00:00
|
|
|
mov -1, %o0;
|
|
|
|
# else
|
2012-03-01 23:04:16 +00:00
|
|
|
# define SYSCALL_ERROR_HANDLER \
|
2012-02-21 23:42:42 +00:00
|
|
|
0: SETUP_PIC_REG_LEAF(o2,g1) \
|
|
|
|
sethi %gdop_hix22(errno), %g1;\
|
|
|
|
xor %g1, %gdop_lox10(errno), %g1;\
|
|
|
|
ldx [%o2 + %g1], %g1, %gdop(errno);\
|
|
|
|
st %o0, [%g1]; \
|
|
|
|
jmp %o7 + 8; \
|
|
|
|
mov -1, %o0;
|
2011-09-01 00:30:41 +00:00
|
|
|
# endif /* _LIBC_REENTRANT */
|
|
|
|
#endif /* PIC */
|
1997-06-29 22:05:27 +00:00
|
|
|
|
2000-01-31 06:42:36 +00:00
|
|
|
#else /* __ASSEMBLER__ */
|
|
|
|
|
|
|
|
#define __SYSCALL_STRING \
|
|
|
|
"ta 0x6d;" \
|
|
|
|
"bcc,pt %%xcc, 1f;" \
|
2020-01-28 22:33:01 +00:00
|
|
|
" nop;" \
|
2011-09-01 00:30:41 +00:00
|
|
|
"sub %%g0, %%o0, %%o0;" \
|
* sysdeps/unix/sysv/linux/s390/s390-32/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/s390/s390-64/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/x86_64/sysdep.h (INTERNAL_SYSCALL,
INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): New macros.
(INLINE_SYSCALL): Use that.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Include
dl-sysdep.h.
(SYSCALL_ERROR_HANDLER): Define RTLD_PRIVATE_ERRNO variant.
(__INTERNAL_SYSCALL_STRING): Define.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Include
dl-sysdep.h.
(SYSCALL_ERROR_HANDLER): Define RTLD_PRIVATE_ERRNO variant.
(__INTERNAL_SYSCALL_STRING): Define.
* sysdeps/unix/sysv/linux/sparc/sysdep.h (INLINE_SYSCALL): Pass
__SYSCALL_STRING to inline_syscall*.
(INTERNAL_SYSCALL, INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO):
New macros.
(inline_syscall0, inline_syscall1, inline_syscall2, inline_syscall3,
inline_syscall4, inline_syscall5, inline_syscall6): Add string
argument.
2002-10-24 Roland McGrath <roland@redhat.com>
* libio/bug-wfflush.c: New file.
* libio/Makefile (tests): Add bug-wfflush.
2002-10-24 18:49:00 +00:00
|
|
|
"1:"
|
|
|
|
|
2008-05-21 09:29:07 +00:00
|
|
|
#define __SYSCALL_CLOBBERS \
|
2000-01-31 06:42:36 +00:00
|
|
|
"f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7", \
|
|
|
|
"f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15", \
|
|
|
|
"f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23", \
|
|
|
|
"f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31", \
|
|
|
|
"f32", "f34", "f36", "f38", "f40", "f42", "f44", "f46", \
|
|
|
|
"f48", "f50", "f52", "f54", "f56", "f58", "f60", "f62", \
|
|
|
|
"cc", "memory"
|
|
|
|
|
1998-05-29 10:21:16 +00:00
|
|
|
#endif /* __ASSEMBLER__ */
|
1997-06-29 22:05:27 +00:00
|
|
|
|
2002-12-07 02:12:17 +00:00
|
|
|
/* This is the offset from the %sp to the backing store above the
|
1997-06-29 22:05:27 +00:00
|
|
|
register windows. So if you poke stack memory directly you add this. */
|
|
|
|
#define STACK_BIAS 2047
|
|
|
|
|
2006-01-02 20:57:43 +00:00
|
|
|
/* Pointer mangling support. */
|
2014-11-20 15:39:43 +00:00
|
|
|
#if IS_IN (rtld)
|
2006-01-02 20:57:43 +00:00
|
|
|
/* We cannot use the thread descriptor because in ld.so we use setjmp
|
|
|
|
earlier than the descriptor is initialized. */
|
|
|
|
#else
|
|
|
|
# ifdef __ASSEMBLER__
|
|
|
|
# define PTR_MANGLE(dreg, reg, tmpreg) \
|
|
|
|
ldx [%g7 + POINTER_GUARD], tmpreg; \
|
|
|
|
xor reg, tmpreg, dreg
|
|
|
|
# define PTR_DEMANGLE(dreg, reg, tmpreg) PTR_MANGLE (dreg, reg, tmpreg)
|
|
|
|
# define PTR_MANGLE2(dreg, reg, tmpreg) \
|
|
|
|
xor reg, tmpreg, dreg
|
|
|
|
# define PTR_DEMANGLE2(dreg, reg, tmpreg) PTR_MANGLE2 (dreg, reg, tmpreg)
|
|
|
|
# else
|
|
|
|
# define PTR_MANGLE(var) \
|
|
|
|
(var) = (__typeof (var)) ((uintptr_t) (var) ^ THREAD_GET_POINTER_GUARD ())
|
|
|
|
# define PTR_DEMANGLE(var) PTR_MANGLE (var)
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
1997-06-29 22:05:27 +00:00
|
|
|
#endif /* linux/sparc64/sysdep.h */
|