mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-06 12:00:24 +08:00
1dca195e1c
Platforms with 64-bit registers where 32-bit values need to have the high 32 bits set in a particular way need to have an explicit cast when using the 64-bit sysdeps/ieee754/dbl-64/wordsize-64 version of llround() as lround(). This includes tilegx32, and likely MIPS. x32 does not need this, and AArch64 ILP32 will not either. Require it to be specified in sysdep.h to be explicit.
97 lines
2.1 KiB
C
97 lines
2.1 KiB
C
/* Assembler macros for x32.
|
|
Copyright (C) 2012-2015 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
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
#include <sysdeps/x86_64/sysdep.h>
|
|
|
|
#undef LP_SIZE
|
|
#undef LP_OP
|
|
#undef ASM_ADDR
|
|
|
|
#undef RAX_LP
|
|
#undef RBP_LP
|
|
#undef RBX_LP
|
|
#undef RCX_LP
|
|
#undef RDI_LP
|
|
#undef RDX_LP
|
|
#undef RSP_LP
|
|
#undef RSI_LP
|
|
#undef R8_LP
|
|
#undef R9_LP
|
|
#undef R10_LP
|
|
#undef R11_LP
|
|
#undef R12_LP
|
|
#undef R13_LP
|
|
#undef R14_LP
|
|
#undef R15_LP
|
|
|
|
#ifdef __ASSEMBLER__
|
|
|
|
# define LP_SIZE 4
|
|
|
|
# define LP_OP(insn) insn##l
|
|
|
|
# define ASM_ADDR .long
|
|
|
|
# define RAX_LP eax
|
|
# define RBP_LP ebp
|
|
# define RBX_LP ebx
|
|
# define RCX_LP ecx
|
|
# define RDI_LP edi
|
|
# define RDX_LP edx
|
|
# define RSI_LP esi
|
|
# define RSP_LP esp
|
|
# define R8_LP r8d
|
|
# define R9_LP r9d
|
|
# define R10_LP r10d
|
|
# define R11_LP r11d
|
|
# define R12_LP r12d
|
|
# define R13_LP r13d
|
|
# define R14_LP r14d
|
|
# define R15_LP r15d
|
|
|
|
#else /* __ASSEMBLER__ */
|
|
|
|
# define LP_SIZE "4"
|
|
|
|
# define LP_OP(insn) #insn "l"
|
|
|
|
# define ASM_ADDR ".long"
|
|
|
|
# define RAX_LP "eax"
|
|
# define RBP_LP "ebp"
|
|
# define RBX_LP "ebx"
|
|
# define RCX_LP "ecx"
|
|
# define RDI_LP "edi"
|
|
# define RDX_LP "edx"
|
|
# define RSI_LP "esi"
|
|
# define RSP_LP "esp"
|
|
# define R8_LP "r8d"
|
|
# define R9_LP "r9d"
|
|
# define R10_LP "r10d"
|
|
# define R11_LP "r11d"
|
|
# define R12_LP "r12d"
|
|
# define R13_LP "r13d"
|
|
# define R14_LP "r14d"
|
|
# define R15_LP "r15d"
|
|
|
|
#endif /* __ASSEMBLER__ */
|
|
|
|
/* On x32, it is not required to normalize a 64-bit value before using
|
|
it as a 32-bit value. */
|
|
#define REGISTER_CAST_INT32_TO_INT64 0
|