blob: 4e013f88333e58ffe73fb706a6980ac7a5137576 [file] [log] [blame]
/* Target-dependent code for the x86-64.
Copyright 2001, 2003
Free Software Foundation, Inc.
Contributed by Jiri Smid, SuSE Labs.
This file is part of GDB.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#ifndef X86_64_TDEP_H
#define X86_64_TDEP_H
struct gdbarch;
struct frame_info;
#include "i386-tdep.h"
/* Register numbers of x86-64 registers. */
enum x86_64_regnums
{
X86_64_RAX_REGNUM,
X86_64_RBX_REGNUM,
X86_64_RCX_REGNUM,
X86_64_RDX_REGNUM,
X86_64_RSI_REGNUM,
X86_64_RDI_REGNUM,
X86_64_RBP_REGNUM,
X86_64_RSP_REGNUM,
X86_64_R8_REGNUM,
X86_64_R9_REGNUM,
X86_64_R10_REGNUM,
X86_64_R11_REGNUM,
X86_64_R12_REGNUM,
X86_64_R13_REGNUM,
X86_64_R14_REGNUM,
X86_64_R15_REGNUM,
X86_64_RIP_REGNUM,
X86_64_EFLAGS_REGNUM,
X86_64_DS_REGNUM,
X86_64_ES_REGNUM,
X86_64_FS_REGNUM,
X86_64_GS_REGNUM,
X86_64_ST0_REGNUM,
X86_64_ST1_REGNUM,
X86_64_ST2_REGNUM,
X86_64_ST3_REGNUM,
X86_64_ST4_REGNUM,
X86_64_ST5_REGNUM,
X86_64_ST6_REGNUM,
X86_64_ST7_REGNUM,
X86_64_FCTRL_REGNUM,
X86_64_FSTAT_REGNUM,
X86_64_FTAG_REGNUM,
X86_64_FISEG_REGNUM,
X86_64_FIOFF_REGNUM,
X86_64_FOSEG_REGNUM,
X86_64_FOOFF_REGNUM,
X86_64_FOP_REGNUM,
X86_64_XMM0_REGNUM,
X86_64_XMM1_REGNUM,
X86_64_XMM2_REGNUM,
X86_64_XMM3_REGNUM,
X86_64_XMM4_REGNUM,
X86_64_XMM5_REGNUM,
X86_64_XMM6_REGNUM,
X86_64_XMM7_REGNUM,
X86_64_XMM8_REGNUM,
X86_64_XMM9_REGNUM,
X86_64_XMM10_REGNUM,
X86_64_XMM11_REGNUM,
X86_64_XMM12_REGNUM,
X86_64_XMM13_REGNUM,
X86_64_XMM14_REGNUM,
X86_64_XMM15_REGNUM,
X86_64_MXCSR_REGNUM
};
/* Number of general purpose registers. */
#define X86_64_NUM_GREGS 22
void x86_64_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch);
/* Fill GDB's register array with the floating-point and SSE register
values in *FXSAVE. This function masks off any of the reserved
bits in *FXSAVE. */
void x86_64_supply_fxsave (char *fxsave);
/* Fill register REGNUM (if it is a floating-point or SSE register) in
*FXSAVE with the value in GDB's register array. If REGNUM is -1, do
this for all registers. This function doesn't touch any of the
reserved bits in *FXSAVE. */
void x86_64_fill_fxsave (char *fxsave, int regnum);
/* Variables exported from amd64fbsd-tdep.c. */
extern CORE_ADDR amd64fbsd_sigtramp_start;
extern CORE_ADDR amd64fbsd_sigtramp_end;
extern int amd64fbsd_sc_reg_offset[];
#endif /* x86-64-tdep.h */