mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-06 12:00:24 +08:00
b75bc69cdf
The implementation of lround in dbl-64/wordsize-64 as an alias or wrapper for llround is always incorrect when long is not 64-bit, because it misses required exceptions in overflow cases, as shown by my recently added tests. This patch removes that alias / wrapper in the non-LP64 case, together with the REGISTER_CAST_INT32_TO_INT64 macro, restoring the previous version of lround for dbl-64/wordsize-64 (newly conditioned on !_LP64). Tested for x86_64, and for mips64 with use of dbl-64/wordsize-64 enabled. [BZ #19079] * sysdeps/ieee754/dbl-64/wordsize-64/s_lround.c: Restore previous file, conditioned on [!_LP64]. * sysdeps/ieee754/dbl-64/wordsize-64/s_llround.c [!_LP64] (__lround): Do not define as function or alias. [!_LP64] (lround): Likewise. [!_LP64] (__lroundl): Likewise. [!_LP64] (lroundl): Likewise. * sysdeps/tile/sysdep.h (REGISTER_CAST_INT32_TO_INT64): Remove macro. * sysdeps/x86_64/x32/sysdep.h (REGISTER_CAST_INT32_TO_INT64): Likewise.
93 lines
2.0 KiB
C
93 lines
2.0 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__ */
|