*** empty log message ***
[deliverable/binutils-gdb.git] / gdb / x86-64-tdep.h
CommitLineData
c4f35dd8
MK
1/* Target-dependent code for the x86-64.
2
3 Copyright 2001, 2003
53e95fcf 4 Free Software Foundation, Inc.
c4f35dd8 5
53e95fcf
JS
6 Contributed by Jiri Smid, SuSE Labs.
7
8 This file is part of GDB.
9
10 This program is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
12 the Free Software Foundation; either version 2 of the License, or
13 (at your option) any later version.
14
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License for more details.
19
20 You should have received a copy of the GNU General Public License
21 along with this program; if not, write to the Free Software
22 Foundation, Inc., 59 Temple Place - Suite 330,
23 Boston, MA 02111-1307, USA. */
24
25#ifndef X86_64_TDEP_H
26#define X86_64_TDEP_H
27
da3331ec
AC
28struct gdbarch;
29struct frame_info;
30
53e95fcf 31#include "i386-tdep.h"
53e95fcf 32
402ecd56
MK
33/* Register numbers of various important registers. */
34
35#define X86_64_RAX_REGNUM 0 /* %rax */
36#define X86_64_RDX_REGNUM 3 /* %rdx */
37#define X86_64_RDI_REGNUM 5 /* %rdi */
38#define X86_64_RBP_REGNUM 6 /* %rbp */
39#define X86_64_RSP_REGNUM 7 /* %rsp */
40#define X86_64_RIP_REGNUM 16 /* %rip */
41#define X86_64_EFLAGS_REGNUM 17 /* %eflags */
42#define X86_64_ST0_REGNUM 22 /* %st0 */
43#define X86_64_XMM0_REGNUM 38 /* %xmm0 */
44#define X86_64_XMM1_REGNUM 39 /* %xmm1 */
45
c4f35dd8
MK
46/* Number of general purpose registers. */
47#define X86_64_NUM_GREGS 22
48
49void x86_64_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch);
53e95fcf 50
0485f6ad
MK
51/* Fill register REGNUM in GDB's register cache with the appropriate
52 floating-point or SSE register value from *FXSAVE. If REGNUM is
53 -1, do this for all registers. This function masks off any of the
54 reserved bits in *FXSAVE. */
b64bbf8c 55
0485f6ad 56void x86_64_supply_fxsave (const char *fxsave, int regnum);
baed091b 57
c4f35dd8 58/* Fill register REGNUM (if it is a floating-point or SSE register) in
0485f6ad 59 *FXSAVE with the value in GDB's register cache. If REGNUM is -1, do
c4f35dd8
MK
60 this for all registers. This function doesn't touch any of the
61 reserved bits in *FXSAVE. */
62
63void x86_64_fill_fxsave (char *fxsave, int regnum);
b246147c
MK
64\f
65
66/* Variables exported from amd64fbsd-tdep.c. */
67extern CORE_ADDR amd64fbsd_sigtramp_start;
68extern CORE_ADDR amd64fbsd_sigtramp_end;
69extern int amd64fbsd_sc_reg_offset[];
53e95fcf 70
c4f35dd8 71#endif /* x86-64-tdep.h */
This page took 0.326455 seconds and 4 git commands to generate.