GDB (API)
Defines | Enumerations | Functions | Variables
/home/stan/gdb/src/gdb/h8300-tdep.c File Reference
#include "defs.h"
#include "value.h"
#include "arch-utils.h"
#include "regcache.h"
#include "gdbcore.h"
#include "objfiles.h"
#include "gdb_assert.h"
#include "dis-asm.h"
#include "dwarf2-frame.h"
#include "frame-base.h"
#include "frame-unwind.h"

Go to the source code of this file.

Defines

#define H8300_MAX_NUM_REGS   18
#define E_PSEUDO_CCR_REGNUM(gdbarch)   (gdbarch_num_regs (gdbarch))
#define E_PSEUDO_EXR_REGNUM(gdbarch)   (gdbarch_num_regs (gdbarch)+1)
#define BINWORD(gdbarch)
#define IS_MOVB_RnRm(x)   (((x) & 0xff88) == 0x0c88)
#define IS_MOVW_RnRm(x)   (((x) & 0xff88) == 0x0d00)
#define IS_MOVL_RnRm(x)   (((x) & 0xff88) == 0x0f80)
#define IS_MOVB_Rn16_SP(x)   (((x) & 0xfff0) == 0x6ee0)
#define IS_MOVB_EXT(x)   ((x) == 0x7860)
#define IS_MOVB_Rn24_SP(x)   (((x) & 0xfff0) == 0x6aa0)
#define IS_MOVW_Rn16_SP(x)   (((x) & 0xfff0) == 0x6fe0)
#define IS_MOVW_EXT(x)   ((x) == 0x78e0)
#define IS_MOVW_Rn24_SP(x)   (((x) & 0xfff0) == 0x6ba0)
#define IS_MOVL_PRE(x)   ((x) == 0x0100)
#define IS_MOVL_Rn16_SP(x)   (((x) & 0xfff0) == 0x6fe0)
#define IS_MOVL_EXT(x)   ((x) == 0x78e0)
#define IS_MOVL_Rn24_SP(x)   (((x) & 0xfff0) == 0x6ba0)
#define IS_PUSHFP_MOVESPFP(x)   ((x) == 0x6df60d76)
#define IS_PUSH_FP(x)   ((x) == 0x01006df6)
#define IS_MOV_SP_FP(x)   ((x) == 0x0ff6)
#define IS_SUB2_SP(x)   ((x) == 0x1b87)
#define IS_SUB4_SP(x)   ((x) == 0x1b97)
#define IS_ADD_IMM_SP(x)   ((x) == 0x7a1f)
#define IS_SUB_IMM_SP(x)   ((x) == 0x7a3f)
#define IS_SUBL4_SP(x)   ((x) == 0x1acf)
#define IS_MOV_IMM_Rn(x)   (((x) & 0xfff0) == 0x7905)
#define IS_SUB_RnSP(x)   (((x) & 0xff0f) == 0x1907)
#define IS_ADD_RnSP(x)   (((x) & 0xff0f) == 0x0907)
#define IS_PUSH(x)   (((x) & 0xfff0) == 0x6df0)

Enumerations

enum  gdb_regnum {
  ARM_A1_REGNUM = 0, ARM_A4_REGNUM = 3, ARM_AP_REGNUM = 11, ARM_IP_REGNUM = 12,
  ARM_SP_REGNUM = 13, ARM_LR_REGNUM = 14, ARM_PC_REGNUM = 15, ARM_F0_REGNUM = 16,
  ARM_F3_REGNUM = 19, ARM_F7_REGNUM = 23, ARM_FPS_REGNUM = 24, ARM_PS_REGNUM = 25,
  ARM_WR0_REGNUM, ARM_WR15_REGNUM = ARM_WR0_REGNUM + 15, ARM_WC0_REGNUM, ARM_WCSSF_REGNUM = ARM_WC0_REGNUM + 2,
  ARM_WCASF_REGNUM = ARM_WC0_REGNUM + 3, ARM_WC7_REGNUM = ARM_WC0_REGNUM + 7, ARM_WCGR0_REGNUM, ARM_WCGR3_REGNUM = ARM_WCGR0_REGNUM + 3,
  ARM_WCGR7_REGNUM = ARM_WCGR0_REGNUM + 7, ARM_D0_REGNUM, ARM_D31_REGNUM = ARM_D0_REGNUM + 31, ARM_FPSCR_REGNUM,
  ARM_NUM_REGS, ARM_FP_REGNUM = 11, THUMB_FP_REGNUM = 7, ARM_NUM_ARG_REGS = 4,
  ARM_LAST_ARG_REGNUM = ARM_A4_REGNUM, ARM_NUM_FP_ARG_REGS = 4, ARM_LAST_FP_ARG_REGNUM = ARM_F3_REGNUM, BFIN_R0_REGNUM = 0,
  BFIN_R1_REGNUM, BFIN_R2_REGNUM, BFIN_R3_REGNUM, BFIN_R4_REGNUM,
  BFIN_R5_REGNUM, BFIN_R6_REGNUM, BFIN_R7_REGNUM, BFIN_P0_REGNUM,
  BFIN_P1_REGNUM, BFIN_P2_REGNUM, BFIN_P3_REGNUM, BFIN_P4_REGNUM,
  BFIN_P5_REGNUM, BFIN_SP_REGNUM, BFIN_FP_REGNUM, BFIN_I0_REGNUM,
  BFIN_I1_REGNUM, BFIN_I2_REGNUM, BFIN_I3_REGNUM, BFIN_M0_REGNUM,
  BFIN_M1_REGNUM, BFIN_M2_REGNUM, BFIN_M3_REGNUM, BFIN_B0_REGNUM,
  BFIN_B1_REGNUM, BFIN_B2_REGNUM, BFIN_B3_REGNUM, BFIN_L0_REGNUM,
  BFIN_L1_REGNUM, BFIN_L2_REGNUM, BFIN_L3_REGNUM, BFIN_A0_DOT_X_REGNUM,
  BFIN_A0_DOT_W_REGNUM, BFIN_A1_DOT_X_REGNUM, BFIN_A1_DOT_W_REGNUM, BFIN_ASTAT_REGNUM,
  BFIN_RETS_REGNUM, BFIN_LC0_REGNUM, BFIN_LT0_REGNUM, BFIN_LB0_REGNUM,
  BFIN_LC1_REGNUM, BFIN_LT1_REGNUM, BFIN_LB1_REGNUM, BFIN_CYCLES_REGNUM,
  BFIN_CYCLES2_REGNUM, BFIN_USP_REGNUM, BFIN_SEQSTAT_REGNUM, BFIN_SYSCFG_REGNUM,
  BFIN_RETI_REGNUM, BFIN_RETX_REGNUM, BFIN_RETN_REGNUM, BFIN_RETE_REGNUM,
  BFIN_PC_REGNUM, BFIN_CC_REGNUM, E_R0_REGNUM, E_ER0_REGNUM = E_R0_REGNUM,
  E_ARG0_REGNUM = E_R0_REGNUM, E_RET0_REGNUM = E_R0_REGNUM, E_R1_REGNUM, E_ER1_REGNUM = E_R1_REGNUM,
  E_RET1_REGNUM = E_R1_REGNUM, E_R2_REGNUM, E_ER2_REGNUM = E_R2_REGNUM, E_ARGLAST_REGNUM = E_R2_REGNUM,
  E_R3_REGNUM, E_ER3_REGNUM = E_R3_REGNUM, E_R4_REGNUM, E_ER4_REGNUM = E_R4_REGNUM,
  E_R5_REGNUM, E_ER5_REGNUM = E_R5_REGNUM, E_R6_REGNUM, E_ER6_REGNUM = E_R6_REGNUM,
  E_FP_REGNUM = E_R6_REGNUM, E_SP_REGNUM, E_CCR_REGNUM, E_PC_REGNUM,
  E_CYCLES_REGNUM, E_TICK_REGNUM, E_EXR_REGNUM = E_TICK_REGNUM, E_INST_REGNUM,
  E_TICKS_REGNUM = E_INST_REGNUM, E_INSTS_REGNUM, E_MACH_REGNUM, E_MACL_REGNUM,
  E_SBR_REGNUM, E_VBR_REGNUM, E_R0_REGNUM, E_R1_REGNUM,
  E_R2_REGNUM, E_R3_REGNUM, E_R4_REGNUM, E_R5_REGNUM,
  E_R6_REGNUM, E_R7_REGNUM, E_R8_REGNUM, E_R9_REGNUM,
  E_R10_REGNUM, E_R11_REGNUM, E_R12_REGNUM, E_R13_REGNUM,
  E_R14_REGNUM, E_R15_REGNUM, E_R16_REGNUM, E_R17_REGNUM,
  E_R18_REGNUM, E_R19_REGNUM, E_R20_REGNUM, E_R21_REGNUM,
  E_R22_REGNUM, E_R23_REGNUM, E_R24_REGNUM, E_R25_REGNUM,
  E_R26_REGNUM, E_R27_REGNUM, E_R28_REGNUM, E_R29_REGNUM,
  E_R30_REGNUM, E_R31_REGNUM, E_PC_REGNUM, E_LR_REGNUM = E_R31_REGNUM,
  E_SP_REGNUM = E_R29_REGNUM, E_FP_REGNUM = E_R27_REGNUM, E_FN_RETURN_REGNUM = E_R2_REGNUM, E_1ST_ARGREG = E_R4_REGNUM,
  E_LAST_ARGREG = E_R11_REGNUM, E_NUM_REGS = E_PC_REGNUM + 1, SCORE_SP_REGNUM = 0, SCORE_FP_REGNUM = 2,
  SCORE_RA_REGNUM = 3, SCORE_A0_REGNUM = 4, SCORE_AL_REGNUM = 7, SCORE_PC_REGNUM = 49,
  E_R0_REGNUM, E_R1_REGNUM, E_R2_REGNUM, E_1ST_ARG_REGNUM = E_R2_REGNUM,
  E_PTR_RET_REGNUM = E_R2_REGNUM, E_R3_REGNUM, E_R4_REGNUM, E_R5_REGNUM,
  E_R6_REGNUM, E_R7_REGNUM, E_LST_ARG_REGNUM = E_R7_REGNUM, E_R8_REGNUM,
  E_R9_REGNUM, E_R10_REGNUM, E_R11_REGNUM, E_R12_REGNUM,
  E_R13_REGNUM, E_FP_REGNUM = E_R13_REGNUM, E_R14_REGNUM, E_PSW_REGNUM = E_R14_REGNUM,
  E_R15_REGNUM, E_SP_REGNUM = E_R15_REGNUM, E_PC_REGNUM, E_NUM_REGS
}
enum  { h8300_reg_size = 2, h8300h_reg_size = 4, h8300_max_reg_size = 4 }

Functions

void _initialize_h8300_tdep (void)

Variables

initialize_file_ftype _initialize_h8300_tdep

Define Documentation

#define BINWORD (   gdbarch)
Value:
((is_h8300hmode (gdbarch) \
                  && !is_h8300_normal_mode (gdbarch)) \
                 ? h8300h_reg_size : h8300_reg_size)

Definition at line 92 of file h8300-tdep.c.

#define E_PSEUDO_CCR_REGNUM (   gdbarch)    (gdbarch_num_regs (gdbarch))

Definition at line 62 of file h8300-tdep.c.

#define E_PSEUDO_EXR_REGNUM (   gdbarch)    (gdbarch_num_regs (gdbarch)+1)

Definition at line 63 of file h8300-tdep.c.

#define H8300_MAX_NUM_REGS   18

Definition at line 60 of file h8300-tdep.c.

#define IS_ADD_IMM_SP (   x)    ((x) == 0x7a1f)

Definition at line 159 of file h8300-tdep.c.

#define IS_ADD_RnSP (   x)    (((x) & 0xff0f) == 0x0907)

Definition at line 164 of file h8300-tdep.c.

#define IS_MOV_IMM_Rn (   x)    (((x) & 0xfff0) == 0x7905)

Definition at line 162 of file h8300-tdep.c.

#define IS_MOV_SP_FP (   x)    ((x) == 0x0ff6)

Definition at line 156 of file h8300-tdep.c.

#define IS_MOVB_EXT (   x)    ((x) == 0x7860)

Definition at line 143 of file h8300-tdep.c.

#define IS_MOVB_Rn16_SP (   x)    (((x) & 0xfff0) == 0x6ee0)

Definition at line 142 of file h8300-tdep.c.

#define IS_MOVB_Rn24_SP (   x)    (((x) & 0xfff0) == 0x6aa0)

Definition at line 144 of file h8300-tdep.c.

#define IS_MOVB_RnRm (   x)    (((x) & 0xff88) == 0x0c88)

Definition at line 139 of file h8300-tdep.c.

#define IS_MOVL_EXT (   x)    ((x) == 0x78e0)

Definition at line 151 of file h8300-tdep.c.

#define IS_MOVL_PRE (   x)    ((x) == 0x0100)

Definition at line 149 of file h8300-tdep.c.

#define IS_MOVL_Rn16_SP (   x)    (((x) & 0xfff0) == 0x6fe0)

Definition at line 150 of file h8300-tdep.c.

#define IS_MOVL_Rn24_SP (   x)    (((x) & 0xfff0) == 0x6ba0)

Definition at line 152 of file h8300-tdep.c.

#define IS_MOVL_RnRm (   x)    (((x) & 0xff88) == 0x0f80)

Definition at line 141 of file h8300-tdep.c.

#define IS_MOVW_EXT (   x)    ((x) == 0x78e0)

Definition at line 146 of file h8300-tdep.c.

#define IS_MOVW_Rn16_SP (   x)    (((x) & 0xfff0) == 0x6fe0)

Definition at line 145 of file h8300-tdep.c.

#define IS_MOVW_Rn24_SP (   x)    (((x) & 0xfff0) == 0x6ba0)

Definition at line 147 of file h8300-tdep.c.

#define IS_MOVW_RnRm (   x)    (((x) & 0xff88) == 0x0d00)

Definition at line 140 of file h8300-tdep.c.

#define IS_PUSH (   x)    (((x) & 0xfff0) == 0x6df0)

Definition at line 165 of file h8300-tdep.c.

#define IS_PUSH_FP (   x)    ((x) == 0x01006df6)

Definition at line 155 of file h8300-tdep.c.

#define IS_PUSHFP_MOVESPFP (   x)    ((x) == 0x6df60d76)

Definition at line 154 of file h8300-tdep.c.

#define IS_SUB2_SP (   x)    ((x) == 0x1b87)

Definition at line 157 of file h8300-tdep.c.

#define IS_SUB4_SP (   x)    ((x) == 0x1b97)

Definition at line 158 of file h8300-tdep.c.

#define IS_SUB_IMM_SP (   x)    ((x) == 0x7a3f)

Definition at line 160 of file h8300-tdep.c.

#define IS_SUB_RnSP (   x)    (((x) & 0xff0f) == 0x1907)

Definition at line 163 of file h8300-tdep.c.

#define IS_SUBL4_SP (   x)    ((x) == 0x1acf)

Definition at line 161 of file h8300-tdep.c.


Enumeration Type Documentation

anonymous enum
Enumerator:
h8300_reg_size 
h8300h_reg_size 
h8300_max_reg_size 

Definition at line 80 of file h8300-tdep.c.

enum gdb_regnum
Enumerator:
ARM_A1_REGNUM 
ARM_A4_REGNUM 
ARM_AP_REGNUM 
ARM_IP_REGNUM 
ARM_SP_REGNUM 
ARM_LR_REGNUM 
ARM_PC_REGNUM 
ARM_F0_REGNUM 
ARM_F3_REGNUM 
ARM_F7_REGNUM 
ARM_FPS_REGNUM 
ARM_PS_REGNUM 
ARM_WR0_REGNUM 
ARM_WR15_REGNUM 
ARM_WC0_REGNUM 
ARM_WCSSF_REGNUM 
ARM_WCASF_REGNUM 
ARM_WC7_REGNUM 
ARM_WCGR0_REGNUM 
ARM_WCGR3_REGNUM 
ARM_WCGR7_REGNUM 
ARM_D0_REGNUM 
ARM_D31_REGNUM 
ARM_FPSCR_REGNUM 
ARM_NUM_REGS 
ARM_FP_REGNUM 
THUMB_FP_REGNUM 
ARM_NUM_ARG_REGS 
ARM_LAST_ARG_REGNUM 
ARM_NUM_FP_ARG_REGS 
ARM_LAST_FP_ARG_REGNUM 
BFIN_R0_REGNUM 
BFIN_R1_REGNUM 
BFIN_R2_REGNUM 
BFIN_R3_REGNUM 
BFIN_R4_REGNUM 
BFIN_R5_REGNUM 
BFIN_R6_REGNUM 
BFIN_R7_REGNUM 
BFIN_P0_REGNUM 
BFIN_P1_REGNUM 
BFIN_P2_REGNUM 
BFIN_P3_REGNUM 
BFIN_P4_REGNUM 
BFIN_P5_REGNUM 
BFIN_SP_REGNUM 
BFIN_FP_REGNUM 
BFIN_I0_REGNUM 
BFIN_I1_REGNUM 
BFIN_I2_REGNUM 
BFIN_I3_REGNUM 
BFIN_M0_REGNUM 
BFIN_M1_REGNUM 
BFIN_M2_REGNUM 
BFIN_M3_REGNUM 
BFIN_B0_REGNUM 
BFIN_B1_REGNUM 
BFIN_B2_REGNUM 
BFIN_B3_REGNUM 
BFIN_L0_REGNUM 
BFIN_L1_REGNUM 
BFIN_L2_REGNUM 
BFIN_L3_REGNUM 
BFIN_A0_DOT_X_REGNUM 
BFIN_A0_DOT_W_REGNUM 
BFIN_A1_DOT_X_REGNUM 
BFIN_A1_DOT_W_REGNUM 
BFIN_ASTAT_REGNUM 
BFIN_RETS_REGNUM 
BFIN_LC0_REGNUM 
BFIN_LT0_REGNUM 
BFIN_LB0_REGNUM 
BFIN_LC1_REGNUM 
BFIN_LT1_REGNUM 
BFIN_LB1_REGNUM 
BFIN_CYCLES_REGNUM 
BFIN_CYCLES2_REGNUM 
BFIN_USP_REGNUM 
BFIN_SEQSTAT_REGNUM 
BFIN_SYSCFG_REGNUM 
BFIN_RETI_REGNUM 
BFIN_RETX_REGNUM 
BFIN_RETN_REGNUM 
BFIN_RETE_REGNUM 
BFIN_PC_REGNUM 
BFIN_CC_REGNUM 
E_R0_REGNUM 
E_ER0_REGNUM 
E_ARG0_REGNUM 
E_RET0_REGNUM 
E_R1_REGNUM 
E_ER1_REGNUM 
E_RET1_REGNUM 
E_R2_REGNUM 
E_ER2_REGNUM 
E_ARGLAST_REGNUM 
E_R3_REGNUM 
E_ER3_REGNUM 
E_R4_REGNUM 
E_ER4_REGNUM 
E_R5_REGNUM 
E_ER5_REGNUM 
E_R6_REGNUM 
E_ER6_REGNUM 
E_FP_REGNUM 
E_SP_REGNUM 
E_CCR_REGNUM 
E_PC_REGNUM 
E_CYCLES_REGNUM 
E_TICK_REGNUM 
E_EXR_REGNUM 
E_INST_REGNUM 
E_TICKS_REGNUM 
E_INSTS_REGNUM 
E_MACH_REGNUM 
E_MACL_REGNUM 
E_SBR_REGNUM 
E_VBR_REGNUM 
E_R0_REGNUM 
E_R1_REGNUM 
E_R2_REGNUM 
E_R3_REGNUM 
E_R4_REGNUM 
E_R5_REGNUM 
E_R6_REGNUM 
E_R7_REGNUM 
E_R8_REGNUM 
E_R9_REGNUM 
E_R10_REGNUM 
E_R11_REGNUM 
E_R12_REGNUM 
E_R13_REGNUM 
E_R14_REGNUM 
E_R15_REGNUM 
E_R16_REGNUM 
E_R17_REGNUM 
E_R18_REGNUM 
E_R19_REGNUM 
E_R20_REGNUM 
E_R21_REGNUM 
E_R22_REGNUM 
E_R23_REGNUM 
E_R24_REGNUM 
E_R25_REGNUM 
E_R26_REGNUM 
E_R27_REGNUM 
E_R28_REGNUM 
E_R29_REGNUM 
E_R30_REGNUM 
E_R31_REGNUM 
E_PC_REGNUM 
E_LR_REGNUM 
E_SP_REGNUM 
E_FP_REGNUM 
E_FN_RETURN_REGNUM 
E_1ST_ARGREG 
E_LAST_ARGREG 
E_NUM_REGS 
SCORE_SP_REGNUM 
SCORE_FP_REGNUM 
SCORE_RA_REGNUM 
SCORE_A0_REGNUM 
SCORE_AL_REGNUM 
SCORE_PC_REGNUM 
E_R0_REGNUM 
E_R1_REGNUM 
E_R2_REGNUM 
E_1ST_ARG_REGNUM 
E_PTR_RET_REGNUM 
E_R3_REGNUM 
E_R4_REGNUM 
E_R5_REGNUM 
E_R6_REGNUM 
E_R7_REGNUM 
E_LST_ARG_REGNUM 
E_R8_REGNUM 
E_R9_REGNUM 
E_R10_REGNUM 
E_R11_REGNUM 
E_R12_REGNUM 
E_R13_REGNUM 
E_FP_REGNUM 
E_R14_REGNUM 
E_PSW_REGNUM 
E_R15_REGNUM 
E_SP_REGNUM 
E_PC_REGNUM 
E_NUM_REGS 

Definition at line 37 of file h8300-tdep.c.


Function Documentation

void _initialize_h8300_tdep ( void  )

Definition at line 1367 of file h8300-tdep.c.


Variable Documentation

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Defines