* opcode/i386.h: Add multiple inclusion protection.
(EAX_REG_NUM,ECX_REG_NUM,EDX_REGNUM,EBX_REG_NUM,ESI_REG_NUM)
(EDI_REG_NUM): New macros.
(MODRM_MOD_FIELD,MODRM_REG_FIELD,MODRM_RM_FIELD): New macros.
(SIB_SCALE_FIELD,SIB_INDEX_FIELD,SIB_BASE_FIELD): New macros.
(REG_PREFIX_P): New macro.
* amd64-tdep.h (amd64_displaced_step_copy_insn): Declare.
(amd64_displaced_step_fixup): Declare.
* amd64-tdep.c: #include opcode/i386.h, dis-asm.h.
(amd64_arch_regmap): Move out of amd64_analyze_stack_align
and make static global.
(amd64_arch_regmap_len): New static global.
(amd64_arch_reg_to_regnum): New function.
(struct amd64_insn): New struct.
(struct displaced_step_closure): New struct.
(onebyte_has_modrm,twobyte_has_modrm): New static globals.
(rex_prefix_p,skip_prefixes)
(amd64_insn_length_fprintf,amd64_insn_length_init_dis)
(amd64_insn_length,amd64_get_unused_input_int_reg)
(amd64_get_insn_details,fixup_riprel,fixup_displaced_copy)
(amd64_displaced_step_copy_insn)
(amd64_absolute_jmp_p,amd64_absolute_call_p,amd64_ret_p)
(amd64_call_p,amd64_breakpoint_p,amd64_syscall_p)
(amd64_displaced_step_fixup): New functions.
* amd64-linux-tdep.c: #include arch-utils.h.
(amd64_linux_init_abi): Install displaced stepping support.
* gdb.arch/amd64-disp-step.S: New file.
* gdb.arch/amd64-disp-step.exp: New file.
* gdb.arch/i386-disp-step.S: New file.
* gdb.arch/i386-disp-step.exp: New file.
2009-01-29 00:29:57 +00:00
|
|
|
/* Copyright 2009 Free Software Foundation, Inc.
|
|
|
|
|
|
|
|
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/>.
|
|
|
|
|
|
|
|
This file is part of the gdb testsuite.
|
|
|
|
It tests displaced stepping over various insns that require special
|
|
|
|
handling. */
|
|
|
|
|
|
|
|
.text
|
|
|
|
|
|
|
|
.global main
|
|
|
|
main:
|
|
|
|
nop
|
|
|
|
|
2009-02-17 06:14:17 +00:00
|
|
|
/***********************************************/
|
|
|
|
|
* opcode/i386.h: Add multiple inclusion protection.
(EAX_REG_NUM,ECX_REG_NUM,EDX_REGNUM,EBX_REG_NUM,ESI_REG_NUM)
(EDI_REG_NUM): New macros.
(MODRM_MOD_FIELD,MODRM_REG_FIELD,MODRM_RM_FIELD): New macros.
(SIB_SCALE_FIELD,SIB_INDEX_FIELD,SIB_BASE_FIELD): New macros.
(REG_PREFIX_P): New macro.
* amd64-tdep.h (amd64_displaced_step_copy_insn): Declare.
(amd64_displaced_step_fixup): Declare.
* amd64-tdep.c: #include opcode/i386.h, dis-asm.h.
(amd64_arch_regmap): Move out of amd64_analyze_stack_align
and make static global.
(amd64_arch_regmap_len): New static global.
(amd64_arch_reg_to_regnum): New function.
(struct amd64_insn): New struct.
(struct displaced_step_closure): New struct.
(onebyte_has_modrm,twobyte_has_modrm): New static globals.
(rex_prefix_p,skip_prefixes)
(amd64_insn_length_fprintf,amd64_insn_length_init_dis)
(amd64_insn_length,amd64_get_unused_input_int_reg)
(amd64_get_insn_details,fixup_riprel,fixup_displaced_copy)
(amd64_displaced_step_copy_insn)
(amd64_absolute_jmp_p,amd64_absolute_call_p,amd64_ret_p)
(amd64_call_p,amd64_breakpoint_p,amd64_syscall_p)
(amd64_displaced_step_fixup): New functions.
* amd64-linux-tdep.c: #include arch-utils.h.
(amd64_linux_init_abi): Install displaced stepping support.
* gdb.arch/amd64-disp-step.S: New file.
* gdb.arch/amd64-disp-step.exp: New file.
* gdb.arch/i386-disp-step.S: New file.
* gdb.arch/i386-disp-step.exp: New file.
2009-01-29 00:29:57 +00:00
|
|
|
/* test call/ret */
|
|
|
|
|
|
|
|
.global test_call
|
|
|
|
test_call:
|
|
|
|
call test_call_subr
|
|
|
|
nop
|
|
|
|
.global test_ret_end
|
|
|
|
test_ret_end:
|
|
|
|
nop
|
|
|
|
|
2009-02-17 06:14:17 +00:00
|
|
|
/***********************************************/
|
|
|
|
|
* opcode/i386.h: Add multiple inclusion protection.
(EAX_REG_NUM,ECX_REG_NUM,EDX_REGNUM,EBX_REG_NUM,ESI_REG_NUM)
(EDI_REG_NUM): New macros.
(MODRM_MOD_FIELD,MODRM_REG_FIELD,MODRM_RM_FIELD): New macros.
(SIB_SCALE_FIELD,SIB_INDEX_FIELD,SIB_BASE_FIELD): New macros.
(REG_PREFIX_P): New macro.
* amd64-tdep.h (amd64_displaced_step_copy_insn): Declare.
(amd64_displaced_step_fixup): Declare.
* amd64-tdep.c: #include opcode/i386.h, dis-asm.h.
(amd64_arch_regmap): Move out of amd64_analyze_stack_align
and make static global.
(amd64_arch_regmap_len): New static global.
(amd64_arch_reg_to_regnum): New function.
(struct amd64_insn): New struct.
(struct displaced_step_closure): New struct.
(onebyte_has_modrm,twobyte_has_modrm): New static globals.
(rex_prefix_p,skip_prefixes)
(amd64_insn_length_fprintf,amd64_insn_length_init_dis)
(amd64_insn_length,amd64_get_unused_input_int_reg)
(amd64_get_insn_details,fixup_riprel,fixup_displaced_copy)
(amd64_displaced_step_copy_insn)
(amd64_absolute_jmp_p,amd64_absolute_call_p,amd64_ret_p)
(amd64_call_p,amd64_breakpoint_p,amd64_syscall_p)
(amd64_displaced_step_fixup): New functions.
* amd64-linux-tdep.c: #include arch-utils.h.
(amd64_linux_init_abi): Install displaced stepping support.
* gdb.arch/amd64-disp-step.S: New file.
* gdb.arch/amd64-disp-step.exp: New file.
* gdb.arch/i386-disp-step.S: New file.
* gdb.arch/i386-disp-step.exp: New file.
2009-01-29 00:29:57 +00:00
|
|
|
/* test abs-jmp/rep-ret */
|
|
|
|
|
|
|
|
test_abs_jmp_setup:
|
|
|
|
mov $test_abs_jmp_return,%rdx
|
|
|
|
push %rdx
|
|
|
|
mov $test_abs_jmp_subr,%rdx
|
|
|
|
.global test_abs_jmp
|
|
|
|
test_abs_jmp:
|
|
|
|
jmp *%rdx
|
|
|
|
test_abs_jmp_return:
|
|
|
|
nop
|
|
|
|
.global test_rep_ret_end
|
|
|
|
test_rep_ret_end:
|
|
|
|
nop
|
|
|
|
|
2009-02-17 06:14:17 +00:00
|
|
|
/***********************************************/
|
|
|
|
|
* opcode/i386.h: Add multiple inclusion protection.
(EAX_REG_NUM,ECX_REG_NUM,EDX_REGNUM,EBX_REG_NUM,ESI_REG_NUM)
(EDI_REG_NUM): New macros.
(MODRM_MOD_FIELD,MODRM_REG_FIELD,MODRM_RM_FIELD): New macros.
(SIB_SCALE_FIELD,SIB_INDEX_FIELD,SIB_BASE_FIELD): New macros.
(REG_PREFIX_P): New macro.
* amd64-tdep.h (amd64_displaced_step_copy_insn): Declare.
(amd64_displaced_step_fixup): Declare.
* amd64-tdep.c: #include opcode/i386.h, dis-asm.h.
(amd64_arch_regmap): Move out of amd64_analyze_stack_align
and make static global.
(amd64_arch_regmap_len): New static global.
(amd64_arch_reg_to_regnum): New function.
(struct amd64_insn): New struct.
(struct displaced_step_closure): New struct.
(onebyte_has_modrm,twobyte_has_modrm): New static globals.
(rex_prefix_p,skip_prefixes)
(amd64_insn_length_fprintf,amd64_insn_length_init_dis)
(amd64_insn_length,amd64_get_unused_input_int_reg)
(amd64_get_insn_details,fixup_riprel,fixup_displaced_copy)
(amd64_displaced_step_copy_insn)
(amd64_absolute_jmp_p,amd64_absolute_call_p,amd64_ret_p)
(amd64_call_p,amd64_breakpoint_p,amd64_syscall_p)
(amd64_displaced_step_fixup): New functions.
* amd64-linux-tdep.c: #include arch-utils.h.
(amd64_linux_init_abi): Install displaced stepping support.
* gdb.arch/amd64-disp-step.S: New file.
* gdb.arch/amd64-disp-step.exp: New file.
* gdb.arch/i386-disp-step.S: New file.
* gdb.arch/i386-disp-step.exp: New file.
2009-01-29 00:29:57 +00:00
|
|
|
/* test syscall */
|
|
|
|
|
|
|
|
.global test_syscall
|
|
|
|
mov $0x27,%eax /* getpid */
|
|
|
|
test_syscall:
|
|
|
|
syscall
|
|
|
|
nop
|
|
|
|
test_syscall_end:
|
|
|
|
nop
|
|
|
|
|
2009-02-17 06:14:17 +00:00
|
|
|
/***********************************************/
|
|
|
|
|
|
|
|
/* Test stepping over int3.
|
|
|
|
The prefixes are pointless, but it's possible, so we exercise it. */
|
|
|
|
|
|
|
|
nop
|
|
|
|
.global test_int3
|
|
|
|
test_int3:
|
|
|
|
repz
|
|
|
|
repz
|
|
|
|
int3
|
|
|
|
nop
|
|
|
|
.global test_int3_end
|
|
|
|
test_int3_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
/***********************************************/
|
|
|
|
|
* opcode/i386.h: Add multiple inclusion protection.
(EAX_REG_NUM,ECX_REG_NUM,EDX_REGNUM,EBX_REG_NUM,ESI_REG_NUM)
(EDI_REG_NUM): New macros.
(MODRM_MOD_FIELD,MODRM_REG_FIELD,MODRM_RM_FIELD): New macros.
(SIB_SCALE_FIELD,SIB_INDEX_FIELD,SIB_BASE_FIELD): New macros.
(REG_PREFIX_P): New macro.
* amd64-tdep.h (amd64_displaced_step_copy_insn): Declare.
(amd64_displaced_step_fixup): Declare.
* amd64-tdep.c: #include opcode/i386.h, dis-asm.h.
(amd64_arch_regmap): Move out of amd64_analyze_stack_align
and make static global.
(amd64_arch_regmap_len): New static global.
(amd64_arch_reg_to_regnum): New function.
(struct amd64_insn): New struct.
(struct displaced_step_closure): New struct.
(onebyte_has_modrm,twobyte_has_modrm): New static globals.
(rex_prefix_p,skip_prefixes)
(amd64_insn_length_fprintf,amd64_insn_length_init_dis)
(amd64_insn_length,amd64_get_unused_input_int_reg)
(amd64_get_insn_details,fixup_riprel,fixup_displaced_copy)
(amd64_displaced_step_copy_insn)
(amd64_absolute_jmp_p,amd64_absolute_call_p,amd64_ret_p)
(amd64_call_p,amd64_breakpoint_p,amd64_syscall_p)
(amd64_displaced_step_fixup): New functions.
* amd64-linux-tdep.c: #include arch-utils.h.
(amd64_linux_init_abi): Install displaced stepping support.
* gdb.arch/amd64-disp-step.S: New file.
* gdb.arch/amd64-disp-step.exp: New file.
* gdb.arch/i386-disp-step.S: New file.
* gdb.arch/i386-disp-step.exp: New file.
2009-01-29 00:29:57 +00:00
|
|
|
/* test rip-relative
|
|
|
|
GDB picks a spare register to hold the rip-relative address.
|
|
|
|
Exercise all the possibilities (rax-rdi, sans rsp). */
|
|
|
|
|
|
|
|
.global test_rip_rax
|
|
|
|
test_rip_rax:
|
|
|
|
add answer(%rip),%rax
|
|
|
|
.global test_rip_rax_end
|
|
|
|
test_rip_rax_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
.global test_rip_rbx
|
|
|
|
test_rip_rbx:
|
|
|
|
add answer(%rip),%rbx
|
|
|
|
.global test_rip_rbx_end
|
|
|
|
test_rip_rbx_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
.global test_rip_rcx
|
|
|
|
test_rip_rcx:
|
|
|
|
add answer(%rip),%rcx
|
|
|
|
.global test_rip_rcx_end
|
|
|
|
test_rip_rcx_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
.global test_rip_rdx
|
|
|
|
test_rip_rdx:
|
|
|
|
add answer(%rip),%rdx
|
|
|
|
.global test_rip_rdx_end
|
|
|
|
test_rip_rdx_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
.global test_rip_rbp
|
|
|
|
test_rip_rbp:
|
|
|
|
add answer(%rip),%rbp
|
|
|
|
.global test_rip_rbp_end
|
|
|
|
test_rip_rbp_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
.global test_rip_rsi
|
|
|
|
test_rip_rsi:
|
|
|
|
add answer(%rip),%rsi
|
|
|
|
.global test_rip_rsi_end
|
|
|
|
test_rip_rsi_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
.global test_rip_rdi
|
|
|
|
test_rip_rdi:
|
|
|
|
add answer(%rip),%rdi
|
|
|
|
.global test_rip_rdi_end
|
|
|
|
test_rip_rdi_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
/* skip over test data */
|
|
|
|
jmp done
|
|
|
|
|
|
|
|
/* test rip-relative data */
|
|
|
|
|
|
|
|
answer: .8byte 42
|
|
|
|
|
2009-02-17 06:14:17 +00:00
|
|
|
/***********************************************/
|
|
|
|
|
* opcode/i386.h: Add multiple inclusion protection.
(EAX_REG_NUM,ECX_REG_NUM,EDX_REGNUM,EBX_REG_NUM,ESI_REG_NUM)
(EDI_REG_NUM): New macros.
(MODRM_MOD_FIELD,MODRM_REG_FIELD,MODRM_RM_FIELD): New macros.
(SIB_SCALE_FIELD,SIB_INDEX_FIELD,SIB_BASE_FIELD): New macros.
(REG_PREFIX_P): New macro.
* amd64-tdep.h (amd64_displaced_step_copy_insn): Declare.
(amd64_displaced_step_fixup): Declare.
* amd64-tdep.c: #include opcode/i386.h, dis-asm.h.
(amd64_arch_regmap): Move out of amd64_analyze_stack_align
and make static global.
(amd64_arch_regmap_len): New static global.
(amd64_arch_reg_to_regnum): New function.
(struct amd64_insn): New struct.
(struct displaced_step_closure): New struct.
(onebyte_has_modrm,twobyte_has_modrm): New static globals.
(rex_prefix_p,skip_prefixes)
(amd64_insn_length_fprintf,amd64_insn_length_init_dis)
(amd64_insn_length,amd64_get_unused_input_int_reg)
(amd64_get_insn_details,fixup_riprel,fixup_displaced_copy)
(amd64_displaced_step_copy_insn)
(amd64_absolute_jmp_p,amd64_absolute_call_p,amd64_ret_p)
(amd64_call_p,amd64_breakpoint_p,amd64_syscall_p)
(amd64_displaced_step_fixup): New functions.
* amd64-linux-tdep.c: #include arch-utils.h.
(amd64_linux_init_abi): Install displaced stepping support.
* gdb.arch/amd64-disp-step.S: New file.
* gdb.arch/amd64-disp-step.exp: New file.
* gdb.arch/i386-disp-step.S: New file.
* gdb.arch/i386-disp-step.exp: New file.
2009-01-29 00:29:57 +00:00
|
|
|
/* all done */
|
|
|
|
|
|
|
|
done:
|
|
|
|
mov $0,%rdi
|
|
|
|
call exit
|
|
|
|
hlt
|
|
|
|
|
|
|
|
/***********************************************/
|
|
|
|
|
|
|
|
/* subroutine to help test call/ret */
|
|
|
|
|
|
|
|
test_call_subr:
|
|
|
|
nop
|
|
|
|
.global test_call_end
|
|
|
|
test_call_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
.global test_ret
|
|
|
|
test_ret:
|
|
|
|
ret
|
|
|
|
|
2009-02-17 06:14:17 +00:00
|
|
|
/***********************************************/
|
|
|
|
|
* opcode/i386.h: Add multiple inclusion protection.
(EAX_REG_NUM,ECX_REG_NUM,EDX_REGNUM,EBX_REG_NUM,ESI_REG_NUM)
(EDI_REG_NUM): New macros.
(MODRM_MOD_FIELD,MODRM_REG_FIELD,MODRM_RM_FIELD): New macros.
(SIB_SCALE_FIELD,SIB_INDEX_FIELD,SIB_BASE_FIELD): New macros.
(REG_PREFIX_P): New macro.
* amd64-tdep.h (amd64_displaced_step_copy_insn): Declare.
(amd64_displaced_step_fixup): Declare.
* amd64-tdep.c: #include opcode/i386.h, dis-asm.h.
(amd64_arch_regmap): Move out of amd64_analyze_stack_align
and make static global.
(amd64_arch_regmap_len): New static global.
(amd64_arch_reg_to_regnum): New function.
(struct amd64_insn): New struct.
(struct displaced_step_closure): New struct.
(onebyte_has_modrm,twobyte_has_modrm): New static globals.
(rex_prefix_p,skip_prefixes)
(amd64_insn_length_fprintf,amd64_insn_length_init_dis)
(amd64_insn_length,amd64_get_unused_input_int_reg)
(amd64_get_insn_details,fixup_riprel,fixup_displaced_copy)
(amd64_displaced_step_copy_insn)
(amd64_absolute_jmp_p,amd64_absolute_call_p,amd64_ret_p)
(amd64_call_p,amd64_breakpoint_p,amd64_syscall_p)
(amd64_displaced_step_fixup): New functions.
* amd64-linux-tdep.c: #include arch-utils.h.
(amd64_linux_init_abi): Install displaced stepping support.
* gdb.arch/amd64-disp-step.S: New file.
* gdb.arch/amd64-disp-step.exp: New file.
* gdb.arch/i386-disp-step.S: New file.
* gdb.arch/i386-disp-step.exp: New file.
2009-01-29 00:29:57 +00:00
|
|
|
/* subroutine to help test abs-jmp/rep-ret */
|
|
|
|
|
|
|
|
test_abs_jmp_subr:
|
|
|
|
nop
|
|
|
|
.global test_abs_jmp_end
|
|
|
|
test_abs_jmp_end:
|
|
|
|
nop
|
|
|
|
|
|
|
|
.global test_rep_ret
|
|
|
|
test_rep_ret:
|
|
|
|
repz
|
|
|
|
ret
|