glibc/sysdeps/x86_64/x32/sysdep.h
Joseph Myers b75bc69cdf Don't use dbl-64/wordsize-64 lround based on llround for ILP32 (bug 19079).
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.
2015-10-07 00:40:12 +00:00

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__ */