2002-09-20 23:46:03 +00:00
|
|
|
/* Assembly macros for 32-bit PowerPC.
|
2019-01-01 00:11:28 +00:00
|
|
|
Copyright (C) 1999-2019 Free Software Foundation, Inc.
|
2002-09-20 23:46:03 +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
|
2012-02-09 23:18:22 +00:00
|
|
|
License along with the GNU C Library; if not, see
|
|
|
|
<http://www.gnu.org/licenses/>. */
|
2002-09-20 23:46:03 +00:00
|
|
|
|
|
|
|
#include <sysdeps/powerpc/sysdep.h>
|
|
|
|
|
2004-05-26 04:47:00 +00:00
|
|
|
#ifdef __ASSEMBLER__
|
|
|
|
|
2002-09-20 23:46:03 +00:00
|
|
|
/* If compiled for profiling, call `_mcount' at the start of each
|
|
|
|
function. */
|
|
|
|
#ifdef PROF
|
|
|
|
/* The mcount code relies on a the return address being on the stack
|
|
|
|
to locate our caller and so it can restore it; so store one just
|
|
|
|
for its benefit. */
|
2005-06-17 23:11:35 +00:00
|
|
|
# define CALL_MCOUNT \
|
2004-12-22 20:10:10 +00:00
|
|
|
mflr r0; \
|
2006-01-04 20:05:05 +00:00
|
|
|
stw r0,4(r1); \
|
2012-08-02 19:04:29 +00:00
|
|
|
cfi_offset (lr, 4); \
|
2004-12-22 20:10:10 +00:00
|
|
|
bl JUMPTARGET(_mcount);
|
2002-09-20 23:46:03 +00:00
|
|
|
#else /* PROF */
|
2003-02-20 20:30:02 +00:00
|
|
|
# define CALL_MCOUNT /* Do nothing. */
|
2002-09-20 23:46:03 +00:00
|
|
|
#endif /* PROF */
|
|
|
|
|
|
|
|
#define ENTRY(name) \
|
2012-08-02 19:04:29 +00:00
|
|
|
.globl C_SYMBOL_NAME(name); \
|
|
|
|
.type C_SYMBOL_NAME(name),@function; \
|
2002-09-20 23:46:03 +00:00
|
|
|
.align ALIGNARG(2); \
|
|
|
|
C_LABEL(name) \
|
2006-01-04 20:05:05 +00:00
|
|
|
cfi_startproc; \
|
2002-09-20 23:46:03 +00:00
|
|
|
CALL_MCOUNT
|
|
|
|
|
PowerPC64 ENTRY_TOCLESS
A number of functions in the sysdeps/powerpc/powerpc64/ tree don't use
or change r2, yet declare a global entry that sets up r2. This patch
fixes that problem, and consolidates the ENTRY and EALIGN macros.
* sysdeps/powerpc/powerpc64/sysdep.h: Formatting.
(NOPS, ENTRY_3): New macros.
(ENTRY): Rewrite.
(ENTRY_TOCLESS): Define.
(EALIGN, EALIGN_W_0, EALIGN_W_1, EALIGN_W_2, EALIGN_W_4, EALIGN_W_5,
EALIGN_W_6, EALIGN_W_7, EALIGN_W_8): Delete.
* sysdeps/powerpc/powerpc64/a2/memcpy.S: Replace EALIGN with ENTRY.
* sysdeps/powerpc/powerpc64/dl-trampoline.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_ceil.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_ceilf.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_floor.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_floorf.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_nearbyint.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_nearbyintf.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_rint.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_rintf.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_round.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_roundf.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_trunc.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_truncf.S: Likewise.
* sysdeps/powerpc/powerpc64/memset.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/fpu/s_finite.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/fpu/s_isinf.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/fpu/s_isnan.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strstr.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/fpu/e_expf.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/fpu/s_cosf.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/fpu/s_sinf.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strcasestr.S: Likewise.
* sysdeps/powerpc/powerpc64/addmul_1.S: Use ENTRY_TOCLESS.
* sysdeps/powerpc/powerpc64/cell/memcpy.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_copysign.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_copysignl.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_fabsl.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_isnan.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_llrint.S: Likewise.
* sysdeps/powerpc/powerpc64/fpu/s_llrintf.S: Likewise.
* sysdeps/powerpc/powerpc64/lshift.S: Likewise.
* sysdeps/powerpc/powerpc64/memcpy.S: Likewise.
* sysdeps/powerpc/powerpc64/mul_1.S: Likewise.
* sysdeps/powerpc/powerpc64/power4/memcmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power4/memcpy.S: Likewise.
* sysdeps/powerpc/powerpc64/power4/memset.S: Likewise.
* sysdeps/powerpc/powerpc64/power4/strncmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_ceil.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_ceilf.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_floor.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_floorf.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_llround.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_round.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_roundf.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_trunc.S: Likewise.
* sysdeps/powerpc/powerpc64/power5+/fpu/s_truncf.S: Likewise.
* sysdeps/powerpc/powerpc64/power5/fpu/s_isnan.S: Likewise.
* sysdeps/powerpc/powerpc64/power6/fpu/s_copysign.S: Likewise.
* sysdeps/powerpc/powerpc64/power6/fpu/s_isnan.S: Likewise.
* sysdeps/powerpc/powerpc64/power6/memcpy.S: Likewise.
* sysdeps/powerpc/powerpc64/power6/memset.S: Likewise.
* sysdeps/powerpc/powerpc64/power6x/fpu/s_isnan.S: Likewise.
* sysdeps/powerpc/powerpc64/power6x/fpu/s_llrint.S: Likewise.
* sysdeps/powerpc/powerpc64/power6x/fpu/s_llround.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/add_n.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/memchr.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/memcmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/memcpy.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/memmove.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/mempcpy.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/memrchr.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/memset.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/rawmemchr.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strcasecmp.S (strcasecmp_l):
Likewise.
* sysdeps/powerpc/powerpc64/power7/strchr.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strchrnul.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strcmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strlen.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strncmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strncpy.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strnlen.S: Likewise.
* sysdeps/powerpc/powerpc64/power7/strrchr.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/fpu/s_finite.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/fpu/s_isinf.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/fpu/s_isnan.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/fpu/s_llrint.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/fpu/s_llround.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/memcmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/memset.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strchr.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strcmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strcpy.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strlen.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strncmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strncpy.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strnlen.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strrchr.S: Likewise.
* sysdeps/powerpc/powerpc64/power8/strspn.S: Likewise.
* sysdeps/powerpc/powerpc64/power9/strcmp.S: Likewise.
* sysdeps/powerpc/powerpc64/power9/strncmp.S: Likewise.
* sysdeps/powerpc/powerpc64/strchr.S: Likewise.
* sysdeps/powerpc/powerpc64/strcmp.S: Likewise.
* sysdeps/powerpc/powerpc64/strlen.S: Likewise.
* sysdeps/powerpc/powerpc64/strncmp.S: Likewise.
* sysdeps/powerpc/powerpc64/ppc-mcount.S: Store LR earlier. Don't
add nop when SHARED.
* sysdeps/powerpc/powerpc64/start.S: Fix comment.
* sysdeps/powerpc/powerpc64/multiarch/strrchr-power8.S (ENTRY): Don't
define.
(ENTRY_TOCLESS): Define.
* sysdeps/powerpc/powerpc32/sysdep.h (ENTRY_TOCLESS): Define.
* sysdeps/powerpc/fpu/s_fma.S: Use ENTRY_TOCLESS.
* sysdeps/powerpc/fpu/s_fmaf.S: Likewise.
2017-06-14 01:15:50 +00:00
|
|
|
#define ENTRY_TOCLESS(name) ENTRY(name)
|
|
|
|
|
2011-12-17 20:07:31 +00:00
|
|
|
/* helper macro for accessing the 32-bit powerpc GOT. */
|
|
|
|
|
2012-08-02 19:04:29 +00:00
|
|
|
#define SETUP_GOT_ACCESS(regname,GOT_LABEL) \
|
2011-12-17 20:07:31 +00:00
|
|
|
bcl 20,31,GOT_LABEL ; \
|
|
|
|
GOT_LABEL: ; \
|
|
|
|
mflr (regname)
|
|
|
|
|
2002-09-20 23:46:03 +00:00
|
|
|
#define EALIGN_W_0 /* No words to insert. */
|
|
|
|
#define EALIGN_W_1 nop
|
|
|
|
#define EALIGN_W_2 nop;nop
|
|
|
|
#define EALIGN_W_3 nop;nop;nop
|
|
|
|
#define EALIGN_W_4 EALIGN_W_3;nop
|
|
|
|
#define EALIGN_W_5 EALIGN_W_4;nop
|
|
|
|
#define EALIGN_W_6 EALIGN_W_5;nop
|
|
|
|
#define EALIGN_W_7 EALIGN_W_6;nop
|
|
|
|
|
|
|
|
/* EALIGN is like ENTRY, but does alignment to 'words'*4 bytes
|
|
|
|
past a 2^align boundary. */
|
|
|
|
#ifdef PROF
|
2003-02-20 20:30:02 +00:00
|
|
|
# define EALIGN(name, alignt, words) \
|
2012-08-02 19:04:29 +00:00
|
|
|
.globl C_SYMBOL_NAME(name); \
|
|
|
|
.type C_SYMBOL_NAME(name),@function; \
|
2002-09-20 23:46:03 +00:00
|
|
|
.align ALIGNARG(2); \
|
|
|
|
C_LABEL(name) \
|
2006-01-04 20:05:05 +00:00
|
|
|
cfi_startproc; \
|
2002-09-20 23:46:03 +00:00
|
|
|
CALL_MCOUNT \
|
|
|
|
b 0f; \
|
|
|
|
.align ALIGNARG(alignt); \
|
|
|
|
EALIGN_W_##words; \
|
|
|
|
0:
|
|
|
|
#else /* PROF */
|
2003-02-20 20:30:02 +00:00
|
|
|
# define EALIGN(name, alignt, words) \
|
2012-08-02 19:04:29 +00:00
|
|
|
.globl C_SYMBOL_NAME(name); \
|
|
|
|
.type C_SYMBOL_NAME(name),@function; \
|
2002-09-20 23:46:03 +00:00
|
|
|
.align ALIGNARG(alignt); \
|
|
|
|
EALIGN_W_##words; \
|
2006-01-04 20:05:05 +00:00
|
|
|
C_LABEL(name) \
|
|
|
|
cfi_startproc;
|
2002-09-20 23:46:03 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#undef END
|
|
|
|
#define END(name) \
|
2006-01-04 20:05:05 +00:00
|
|
|
cfi_endproc; \
|
2002-09-20 23:46:03 +00:00
|
|
|
ASM_SIZE_DIRECTIVE(name)
|
|
|
|
|
2012-08-02 19:04:29 +00:00
|
|
|
#define DO_CALL(syscall) \
|
2012-01-12 22:05:03 +00:00
|
|
|
li 0,syscall; \
|
2002-09-20 23:46:03 +00:00
|
|
|
sc
|
|
|
|
|
2003-01-09 20:30:21 +00:00
|
|
|
#undef JUMPTARGET
|
2002-09-20 23:46:03 +00:00
|
|
|
#ifdef PIC
|
2003-02-20 20:30:02 +00:00
|
|
|
# define JUMPTARGET(name) name##@plt
|
2002-09-20 23:46:03 +00:00
|
|
|
#else
|
2003-02-20 20:30:02 +00:00
|
|
|
# define JUMPTARGET(name) name
|
|
|
|
#endif
|
|
|
|
|
2013-09-04 15:25:42 +00:00
|
|
|
#if defined SHARED && defined PIC && !defined NO_HIDDEN
|
2003-02-20 20:30:02 +00:00
|
|
|
# undef HIDDEN_JUMPTARGET
|
|
|
|
# define HIDDEN_JUMPTARGET(name) __GI_##name##@local
|
2002-09-20 23:46:03 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#define PSEUDO(name, syscall_name, args) \
|
|
|
|
.section ".text"; \
|
|
|
|
ENTRY (name) \
|
|
|
|
DO_CALL (SYS_ify (syscall_name));
|
|
|
|
|
|
|
|
#define PSEUDO_RET \
|
2003-01-07 00:42:43 +00:00
|
|
|
bnslr+; \
|
2005-05-21 19:29:13 +00:00
|
|
|
b __syscall_error@local
|
2002-09-20 23:46:03 +00:00
|
|
|
#define ret PSEUDO_RET
|
|
|
|
|
|
|
|
#undef PSEUDO_END
|
|
|
|
#define PSEUDO_END(name) \
|
|
|
|
END (name)
|
|
|
|
|
2003-03-23 19:44:31 +00:00
|
|
|
#define PSEUDO_NOERRNO(name, syscall_name, args) \
|
|
|
|
.section ".text"; \
|
|
|
|
ENTRY (name) \
|
|
|
|
DO_CALL (SYS_ify (syscall_name));
|
|
|
|
|
|
|
|
#define PSEUDO_RET_NOERRNO \
|
|
|
|
blr
|
|
|
|
#define ret_NOERRNO PSEUDO_RET_NOERRNO
|
|
|
|
|
|
|
|
#undef PSEUDO_END_NOERRNO
|
|
|
|
#define PSEUDO_END_NOERRNO(name) \
|
|
|
|
END (name)
|
|
|
|
|
Update.
2003-08-16 Jakub Jelinek <jakub@redhat.com>
* sysdeps/powerpc/powerpc32/sysdep.h (PSEUDO_ERRVAL,
PSEUDO_RET_ERRVAL, ret_ERRVAL, PSEUDO_END_ERRVAL): Define.
* sysdeps/powerpc/powerpc64/sysdep.h (PSEUDO_ERRVAL,
PSEUDO_RET_ERRVAL, ret_ERRVAL, PSEUDO_END_ERRVAL): Define.
* sysdeps/unix/alpha/sysdep.h (PSEUDO_ERRVAL,
ret_ERRVAL, PSEUDO_END_ERRVAL): Define.
* sysdeps/unix/mips/sysdep.h (PSEUDO_ERRVAL,
ret_ERRVAL, PSEUDO_END_ERRVAL): Define.
* sysdeps/unix/sparc/sysdep.h (PSEUDO_ERRVAL,
ret_ERRVAL): Define.
* sysdeps/unix/sysv/linux/s390/s390-32/sysdep.h (PSEUDO_ERRVAL,
PSEUDO_END_ERRVAL, ret_ERRVAL): Define.
* sysdeps/unix/sysv/linux/s390/s390-64/sysdep.h (PSEUDO_ERRVAL,
PSEUDO_END_ERRVAL, ret_ERRVAL): Define.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h (PSEUDO_ERRVAL):
Define.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h (PSEUDO_ERRVAL,
PSEUDO_END_ERRVAL, ret_ERRVAL): Define.
* sysdeps/unix/sysdep.h (PSEUDO_END_ERRVAL): Define.
* sysdeps/unix/sysv/linux/syscalls.list (posix_fadvise64,
posix_fadvise64_64): Remove.
* sysdeps/unix/sysv/linux/alpha/syscalls.list (posix_fadvise64): Add
V flag.
* sysdeps/unix/sysv/linux/ia64/syscalls.list (posix_fadvise64):
Likewise.
* sysdeps/unix/sysv/linux/powerpc/powerpc64/syscalls.list
(posix_fadvise64): Likewise.
* sysdeps/unix/sysv/linux/s390/s390-64/syscalls.list
(posix_fadvise64): Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc64/syscalls.list
(posix_fadvise64): Likewise.
* sysdeps/unix/sysv/linux/x86_64/syscalls.list (posix_fadvise64):
Likewise.
* sysdeps/unix/sysv/linux/i386/posix_fadvise64_64.S: Moved to...
* sysdeps/unix/sysv/linux/i386/posix_fadvise64.S: ...here.
(__posix_fadvise64_l64): Fix a typo in fadvise64 syscall invocation.
(__posix_fadvise64_l32): New function.
* sysdeps/unix/sysv/linux/i386/Makefile: Revert last change.
* sysdeps/unix/sysv/linux/powerpc/powerpc32/Versions (libc): Export
posix_fadvise64@@GLIBC_2.3.3.
* sysdeps/unix/sysv/linux/s390/s390-32/Versions (libc): Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc32/Versions (libc): Likewise.
* sysdeps/unix/sysv/linux/posix_fadvise.c (posix_fadvise): Return
error value.
* sysdeps/unix/sysv/linux/posix_fadvise64.c: New file.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h
(SYSCALL_ERROR_HANDLER): Use TLS errno/__libc_errno if USE___THREAD.
2003-08-15 Jakub Jelinek <jakub@redhat.com>
* sysdeps/sparc/sparc32/dl-machine.h (WEAKADDR): Remove.
(elf_machine_matches_host): Remove weak extern stuff.
Use GL(dl_hwcap) unconditionally and GL(dl_hwcap_mask) if SHARED.
(elf_machine_runtime_setup, sparc_fixup_plt): Remove weak extern
stuff. Use GL(dl_hwcap) unconditionally.
2003-08-17 00:37:19 +00:00
|
|
|
#define PSEUDO_ERRVAL(name, syscall_name, args) \
|
|
|
|
.section ".text"; \
|
|
|
|
ENTRY (name) \
|
|
|
|
DO_CALL (SYS_ify (syscall_name));
|
|
|
|
|
|
|
|
#define PSEUDO_RET_ERRVAL \
|
|
|
|
blr
|
|
|
|
#define ret_ERRVAL PSEUDO_RET_ERRVAL
|
|
|
|
|
|
|
|
#undef PSEUDO_END_ERRVAL
|
|
|
|
#define PSEUDO_END_ERRVAL(name) \
|
|
|
|
END (name)
|
|
|
|
|
2002-09-20 23:46:03 +00:00
|
|
|
/* Local labels stripped out by the linker. */
|
|
|
|
#undef L
|
|
|
|
#define L(x) .L##x
|
|
|
|
|
2012-01-12 22:05:03 +00:00
|
|
|
#define XGLUE(a,b) a##b
|
|
|
|
#define GLUE(a,b) XGLUE (a,b)
|
|
|
|
#define GENERATE_GOT_LABEL(name) GLUE (.got_label, name)
|
|
|
|
|
2002-09-20 23:46:03 +00:00
|
|
|
/* Label in text section. */
|
|
|
|
#define C_TEXT(name) name
|
|
|
|
|
|
|
|
#endif /* __ASSEMBLER__ */
|