/* 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
. */
#include
#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