- /* Target-dependent code for the i386.
 
 
-    Copyright (C) 2001-2015 Free Software Foundation, Inc.
 
 
-    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 3 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, see <http://www.gnu.org/licenses/>.  */
 
 
- #ifndef I386_TDEP_H
 
- #define I386_TDEP_H
 
 
- struct frame_info;
 
- struct gdbarch;
 
- struct reggroup;
 
- struct regset;
 
- struct regcache;
 
 
- /* GDB's i386 target supports both the 32-bit Intel Architecture
 
-    (IA-32) and the 64-bit AMD x86-64 architecture.  Internally it uses
 
-    a similar register layout for both.
 
 
-    - General purpose registers
 
-    - FPU data registers
 
-    - FPU control registers
 
-    - SSE data registers
 
-    - SSE control register
 
 
-    The general purpose registers for the x86-64 architecture are quite
 
-    different from IA-32.  Therefore, gdbarch_fp0_regnum
 
-    determines the register number at which the FPU data registers
 
-    start.  The number of FPU data and control registers is the same
 
-    for both architectures.  The number of SSE registers however,
 
-    differs and is determined by the num_xmm_regs member of `struct
 
-    gdbarch_tdep'.  */
 
 
- /* Convention for returning structures.  */
 
 
- enum struct_return
 
- {
 
-   pcc_struct_return,                /* Return "short" structures in memory.  */
 
-   reg_struct_return                /* Return "short" structures in registers.  */
 
- };
 
 
- /* i386 architecture specific information.  */
 
- struct gdbarch_tdep
 
- {
 
-   /* General-purpose registers.  */
 
-   int *gregset_reg_offset;
 
-   int gregset_num_regs;
 
-   size_t sizeof_gregset;
 
 
-   /* Floating-point registers.  */
 
-   size_t sizeof_fpregset;
 
 
-   /* Register number for %st(0).  The register numbers for the other
 
-      registers follow from this one.  Set this to -1 to indicate the
 
-      absence of an FPU.  */
 
-   int st0_regnum;
 
 
-   /* Number of MMX registers.  */
 
-   int num_mmx_regs;
 
 
-   /* Register number for %mm0.  Set this to -1 to indicate the absence
 
-      of MMX support.  */
 
-   int mm0_regnum;
 
 
-   /* Number of pseudo YMM registers.  */
 
-   int num_ymm_regs;
 
 
-   /* Register number for %ymm0.  Set this to -1 to indicate the absence
 
-      of pseudo YMM register support.  */
 
-   int ymm0_regnum;
 
 
-   /* Number of AVX512 OpMask registers (K-registers)  */
 
-   int num_k_regs;
 
 
-   /* Register number for %k0.  Set this to -1 to indicate the absence
 
-      of AVX512 OpMask register support.  */
 
-   int k0_regnum;
 
 
-   /* Number of pseudo ZMM registers ($zmm0-$zmm31).  */
 
-   int num_zmm_regs;
 
 
-   /* Register number for %zmm0.  Set this to -1 to indicate the absence
 
-      of pseudo ZMM register support.  */
 
-   int zmm0_regnum;
 
 
-   /* Number of byte registers.  */
 
-   int num_byte_regs;
 
 
-   /* Register pseudo number for %al.  */
 
-   int al_regnum;
 
 
-   /* Number of pseudo word registers.  */
 
-   int num_word_regs;
 
 
-   /* Register number for %ax.  */
 
-   int ax_regnum;
 
 
-   /* Number of pseudo dword registers.  */
 
-   int num_dword_regs;
 
 
-   /* Register number for %eax.  Set this to -1 to indicate the absence
 
-      of pseudo dword register support.  */
 
-   int eax_regnum;
 
 
-   /* Number of core registers.  */
 
-   int num_core_regs;
 
 
-   /* Number of SSE registers.  */
 
-   int num_xmm_regs;
 
 
-   /* Number of SSE registers added in AVX512.  */
 
-   int num_xmm_avx512_regs;
 
 
-   /* Register number of XMM16, the first XMM register added in AVX512.  */
 
-   int xmm16_regnum;
 
 
-   /* Number of YMM registers added in AVX512.  */
 
-   int num_ymm_avx512_regs;
 
 
-   /* Register number of YMM16, the first YMM register added in AVX512.  */
 
-   int ymm16_regnum;
 
 
-   /* Bits of the extended control register 0 (the XFEATURE_ENABLED_MASK
 
-      register), excluding the x87 bit, which are supported by this GDB.  */
 
 
-   uint64_t xcr0;
 
 
-   /* Offset of XCR0 in XSAVE extended state.  */
 
-   int xsave_xcr0_offset;
 
 
-   /* Register names.  */
 
-   const char **register_names;
 
 
-   /* Register number for %ymm0h.  Set this to -1 to indicate the absence
 
-      of upper YMM register support.  */
 
-   int ymm0h_regnum;
 
 
-   /* Upper YMM register names.  Only used for tdesc_numbered_register.  */
 
-   const char **ymmh_register_names;
 
 
-   /* Register number for %ymm16h.  Set this to -1 to indicate the absence
 
-   of support for YMM16-31.  */
 
-   int ymm16h_regnum;
 
 
-   /* YMM16-31 register names.  Only used for tdesc_numbered_register.  */
 
-   const char **ymm16h_register_names;
 
 
-   /* Register number for %bnd0r.  Set this to -1 to indicate the absence
 
-      bound registers.  */
 
-   int bnd0r_regnum;
 
 
-   /* Register number for pseudo register %bnd0.  Set this to -1 to indicate the absence
 
-      bound registers.  */
 
-   int bnd0_regnum;
 
 
-   /* Register number for %bndcfgu. Set this to -1 to indicate the absence
 
-      bound control registers.  */
 
-   int bndcfgu_regnum;
 
 
-   /* MPX register names.  Only used for tdesc_numbered_register.  */
 
-   const char **mpx_register_names;
 
 
-   /* Register number for %zmm0h.  Set this to -1 to indicate the absence
 
-      of ZMM_HI256 register support.  */
 
-   int zmm0h_regnum;
 
 
-   /* OpMask register names.  */
 
-   const char **k_register_names;
 
 
-   /* ZMM register names.  Only used for tdesc_numbered_register.  */
 
-   const char **zmmh_register_names;
 
 
-   /* XMM16-31 register names.  Only used for tdesc_numbered_register.  */
 
-   const char **xmm_avx512_register_names;
 
 
-   /* YMM16-31 register names.  Only used for tdesc_numbered_register.  */
 
-   const char **ymm_avx512_register_names;
 
 
-   /* Target description.  */
 
-   const struct target_desc *tdesc;
 
 
-   /* Register group function.  */
 
-   const void *register_reggroup_p;
 
 
-   /* Offset of saved PC in jmp_buf.  */
 
-   int jb_pc_offset;
 
 
-   /* Convention for returning structures.  */
 
-   enum struct_return struct_return;
 
 
-   /* Address range where sigtramp lives.  */
 
-   CORE_ADDR sigtramp_start;
 
-   CORE_ADDR sigtramp_end;
 
 
-   /* Detect sigtramp.  */
 
-   int (*sigtramp_p) (struct frame_info *);
 
 
-   /* Get address of sigcontext for sigtramp.  */
 
-   CORE_ADDR (*sigcontext_addr) (struct frame_info *);
 
 
-   /* Offset of registers in `struct sigcontext'.  */
 
-   int *sc_reg_offset;
 
-   int sc_num_regs;
 
 
-   /* Offset of saved PC and SP in `struct sigcontext'.  Usage of these
 
-      is deprecated, please use `sc_reg_offset' instead.  */
 
-   int sc_pc_offset;
 
-   int sc_sp_offset;
 
 
-   /* ISA-specific data types.  */
 
-   struct type *i386_mmx_type;
 
-   struct type *i386_ymm_type;
 
-   struct type *i386_zmm_type;
 
-   struct type *i387_ext_type;
 
-   struct type *i386_bnd_type;
 
 
-   /* Process record/replay target.  */
 
-   /* The map for registers because the AMD64's registers order
 
-      in GDB is not same as I386 instructions.  */
 
-   const int *record_regmap;
 
-   /* Parse intx80 args.  */
 
-   int (*i386_intx80_record) (struct regcache *regcache);
 
-   /* Parse sysenter args.  */
 
-   int (*i386_sysenter_record) (struct regcache *regcache);
 
-   /* Parse syscall args.  */
 
-   int (*i386_syscall_record) (struct regcache *regcache);
 
 
-   /* Regsets. */
 
-   const struct regset *fpregset;
 
- };
 
 
- /* Floating-point registers.  */
 
 
- /* All FPU control regusters (except for FIOFF and FOOFF) are 16-bit
 
-    (at most) in the FPU, but are zero-extended to 32 bits in GDB's
 
-    register cache.  */
 
 
- /* Return non-zero if REGNUM matches the FP register and the FP
 
-    register set is active.  */
 
- extern int i386_fp_regnum_p (struct gdbarch *, int);
 
- extern int i386_fpc_regnum_p (struct gdbarch *, int);
 
 
- /* Register numbers of various important registers.  */
 
 
- enum i386_regnum
 
- {
 
-   I386_EAX_REGNUM,                /* %eax */
 
-   I386_ECX_REGNUM,                /* %ecx */
 
-   I386_EDX_REGNUM,                /* %edx */
 
-   I386_EBX_REGNUM,                /* %ebx */
 
-   I386_ESP_REGNUM,                /* %esp */
 
-   I386_EBP_REGNUM,                /* %ebp */
 
-   I386_ESI_REGNUM,                /* %esi */
 
-   I386_EDI_REGNUM,                /* %edi */
 
-   I386_EIP_REGNUM,                /* %eip */
 
-   I386_EFLAGS_REGNUM,                /* %eflags */
 
-   I386_CS_REGNUM,                /* %cs */
 
-   I386_SS_REGNUM,                /* %ss */
 
-   I386_DS_REGNUM,                /* %ds */
 
-   I386_ES_REGNUM,                /* %es */
 
-   I386_FS_REGNUM,                /* %fs */
 
-   I386_GS_REGNUM,                /* %gs */
 
-   I386_ST0_REGNUM,                /* %st(0) */
 
-   I386_MXCSR_REGNUM = 40,        /* %mxcsr */
 
-   I386_YMM0H_REGNUM,                /* %ymm0h */
 
-   I386_YMM7H_REGNUM = I386_YMM0H_REGNUM + 7,
 
-   I386_BND0R_REGNUM,
 
-   I386_BND3R_REGNUM = I386_BND0R_REGNUM + 3,
 
-   I386_BNDCFGU_REGNUM,
 
-   I386_BNDSTATUS_REGNUM,
 
-   I386_K0_REGNUM,                /* %k0 */
 
-   I386_K7_REGNUM = I386_K0_REGNUM + 7,
 
-   I386_ZMM0H_REGNUM,                /* %zmm0h */
 
-   I386_ZMM7H_REGNUM = I386_ZMM0H_REGNUM + 7
 
- };
 
 
- /* Register numbers of RECORD_REGMAP.  */
 
 
- enum record_i386_regnum
 
- {
 
-   X86_RECORD_REAX_REGNUM,
 
-   X86_RECORD_RECX_REGNUM,
 
-   X86_RECORD_REDX_REGNUM,
 
-   X86_RECORD_REBX_REGNUM,
 
-   X86_RECORD_RESP_REGNUM,
 
-   X86_RECORD_REBP_REGNUM,
 
-   X86_RECORD_RESI_REGNUM,
 
-   X86_RECORD_REDI_REGNUM,
 
-   X86_RECORD_R8_REGNUM,
 
-   X86_RECORD_R9_REGNUM,
 
-   X86_RECORD_R10_REGNUM,
 
-   X86_RECORD_R11_REGNUM,
 
-   X86_RECORD_R12_REGNUM,
 
-   X86_RECORD_R13_REGNUM,
 
-   X86_RECORD_R14_REGNUM,
 
-   X86_RECORD_R15_REGNUM,
 
-   X86_RECORD_REIP_REGNUM,
 
-   X86_RECORD_EFLAGS_REGNUM,
 
-   X86_RECORD_CS_REGNUM,
 
-   X86_RECORD_SS_REGNUM,
 
-   X86_RECORD_DS_REGNUM,
 
-   X86_RECORD_ES_REGNUM,
 
-   X86_RECORD_FS_REGNUM,
 
-   X86_RECORD_GS_REGNUM,
 
- };
 
 
- #define I386_NUM_GREGS        16
 
- #define I386_NUM_XREGS  9
 
 
- #define I386_SSE_NUM_REGS        (I386_MXCSR_REGNUM + 1)
 
- #define I386_AVX_NUM_REGS        (I386_YMM7H_REGNUM + 1)
 
- #define I386_MPX_NUM_REGS        (I386_BNDSTATUS_REGNUM + 1)
 
- #define I386_AVX512_NUM_REGS        (I386_ZMM7H_REGNUM + 1)
 
 
- /* Size of the largest register.  */
 
- #define I386_MAX_REGISTER_SIZE        64
 
 
- /* Types for i386-specific registers.  */
 
- extern struct type *i387_ext_type (struct gdbarch *gdbarch);
 
 
- /* Checks of different pseudo-registers.  */
 
- extern int i386_byte_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_word_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_dword_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_xmm_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_xmm_avx512_regnum_p (struct gdbarch * gdbarch, int regnum);
 
- extern int i386_ymm_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_ymm_avx512_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_bnd_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_k_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_zmm_regnum_p (struct gdbarch *gdbarch, int regnum);
 
- extern int i386_zmmh_regnum_p (struct gdbarch *gdbarch, int regnum);
 
 
- extern const char *i386_pseudo_register_name (struct gdbarch *gdbarch,
 
-                                               int regnum);
 
- extern struct type *i386_pseudo_register_type (struct gdbarch *gdbarch,
 
-                                                int regnum);
 
 
- extern void i386_pseudo_register_read_into_value (struct gdbarch *gdbarch,
 
-                                                   struct regcache *regcache,
 
-                                                   int regnum,
 
-                                                   struct value *result);
 
 
- extern void i386_pseudo_register_write (struct gdbarch *gdbarch,
 
-                                         struct regcache *regcache,
 
-                                         int regnum, const gdb_byte *buf);
 
 
- /* Segment selectors.  */
 
- #define I386_SEL_RPL        0x0003  /* Requester's Privilege Level mask.  */
 
- #define I386_SEL_UPL        0x0003        /* User Privilige Level.  */
 
- #define I386_SEL_KPL        0x0000        /* Kernel Privilige Level.  */
 
 
- /* The length of the longest i386 instruction (according to
 
-    include/asm-i386/kprobes.h in Linux 2.6.  */
 
- #define I386_MAX_INSN_LEN (16)
 
 
- /* Functions exported from i386-tdep.c.  */
 
- extern CORE_ADDR i386_pe_skip_trampoline_code (struct frame_info *frame,
 
-                                                CORE_ADDR pc, char *name);
 
- extern CORE_ADDR i386_skip_main_prologue (struct gdbarch *gdbarch,
 
-                                           CORE_ADDR pc);
 
 
- /* Return whether the THIS_FRAME corresponds to a sigtramp routine.  */
 
- extern int i386_sigtramp_p (struct frame_info *this_frame);
 
 
- /* Return non-zero if REGNUM is a member of the specified group.  */
 
- extern int i386_register_reggroup_p (struct gdbarch *gdbarch, int regnum,
 
-                                      struct reggroup *group);
 
 
- /* Supply register REGNUM from the general-purpose register set REGSET
 
-    to register cache REGCACHE.  If REGNUM is -1, do this for all
 
-    registers in REGSET.  */
 
- extern void i386_supply_gregset (const struct regset *regset,
 
-                                  struct regcache *regcache, int regnum,
 
-                                  const void *gregs, size_t len);
 
 
- /* General-purpose register set. */
 
- extern const struct regset i386_gregset;
 
 
- /* Floating-point register set. */
 
- extern const struct regset i386_fpregset;
 
 
- /* Default iterator over core file register note sections.  */
 
- extern void
 
-   i386_iterate_over_regset_sections (struct gdbarch *gdbarch,
 
-                                      iterate_over_regset_sections_cb *cb,
 
-                                      void *cb_data,
 
-                                      const struct regcache *regcache);
 
 
- extern struct displaced_step_closure *i386_displaced_step_copy_insn
 
-   (struct gdbarch *gdbarch, CORE_ADDR from, CORE_ADDR to,
 
-    struct regcache *regs);
 
- extern void i386_displaced_step_fixup (struct gdbarch *gdbarch,
 
-                                        struct displaced_step_closure *closure,
 
-                                        CORE_ADDR from, CORE_ADDR to,
 
-                                        struct regcache *regs);
 
 
- /* Initialize a basic ELF architecture variant.  */
 
- extern void i386_elf_init_abi (struct gdbarch_info, struct gdbarch *);
 
 
- /* Initialize a SVR4 architecture variant.  */
 
- extern void i386_svr4_init_abi (struct gdbarch_info, struct gdbarch *);
 
 
- extern int i386_process_record (struct gdbarch *gdbarch,
 
-                                 struct regcache *regcache, CORE_ADDR addr);
 
 
 
 
- /* Functions and variables exported from i386bsd-tdep.c.  */
 
 
- extern void i386bsd_init_abi (struct gdbarch_info, struct gdbarch *);
 
- extern CORE_ADDR i386fbsd_sigtramp_start_addr;
 
- extern CORE_ADDR i386fbsd_sigtramp_end_addr;
 
- extern CORE_ADDR i386obsd_sigtramp_start_addr;
 
- extern CORE_ADDR i386obsd_sigtramp_end_addr;
 
- extern int i386fbsd4_sc_reg_offset[];
 
- extern int i386fbsd_sc_reg_offset[];
 
- extern int i386nbsd_sc_reg_offset[];
 
- extern int i386obsd_sc_reg_offset[];
 
- extern int i386bsd_sc_reg_offset[];
 
 
- /* SystemTap related functions.  */
 
 
- extern int i386_stap_is_single_operand (struct gdbarch *gdbarch,
 
-                                         const char *s);
 
 
- extern int i386_stap_parse_special_token (struct gdbarch *gdbarch,
 
-                                           struct stap_parse_info *p);
 
 
- #endif /* i386-tdep.h */