OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gdb-7.1/] [gdb/] [testsuite/] [gdb.arch/] [amd64-disp-step.S] - Diff between revs 227 and 816

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 227 Rev 816
/* Copyright 2009, 2010 Free Software Foundation, Inc.
/* Copyright 2009, 2010 Free Software Foundation, Inc.
   This program is free software; you can redistribute it and/or modify
   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
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 3 of the License, or
   the Free Software Foundation; either version 3 of the License, or
   (at your option) any later version.
   (at your option) any later version.
   This program is distributed in the hope that it will be useful,
   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.
   GNU General Public License for more details.
   You should have received a copy of the GNU General Public License
   You should have received a copy of the GNU General Public License
   along with this program.  If not, see .
   along with this program.  If not, see .
   This file is part of the gdb testsuite.
   This file is part of the gdb testsuite.
   It tests displaced stepping over various insns that require special
   It tests displaced stepping over various insns that require special
   handling.  */
   handling.  */
        .text
        .text
        .global main
        .global main
main:
main:
        nop
        nop
/***********************************************/
/***********************************************/
/* test call/ret */
/* test call/ret */
        .global test_call
        .global test_call
test_call:
test_call:
        call test_call_subr
        call test_call_subr
        nop
        nop
        .global test_ret_end
        .global test_ret_end
test_ret_end:
test_ret_end:
        nop
        nop
/***********************************************/
/***********************************************/
/* test abs-jmp/rep-ret */
/* test abs-jmp/rep-ret */
test_abs_jmp_setup:
test_abs_jmp_setup:
        mov $test_abs_jmp_return,%rdx
        mov $test_abs_jmp_return,%rdx
        push %rdx
        push %rdx
        mov $test_abs_jmp_subr,%rdx
        mov $test_abs_jmp_subr,%rdx
        .global test_abs_jmp
        .global test_abs_jmp
test_abs_jmp:
test_abs_jmp:
        jmp *%rdx
        jmp *%rdx
test_abs_jmp_return:
test_abs_jmp_return:
        nop
        nop
        .global test_rep_ret_end
        .global test_rep_ret_end
test_rep_ret_end:
test_rep_ret_end:
        nop
        nop
/***********************************************/
/***********************************************/
/* test syscall */
/* test syscall */
        .global test_syscall
        .global test_syscall
        mov $0x27,%eax /* getpid */
        mov $0x27,%eax /* getpid */
test_syscall:
test_syscall:
        syscall
        syscall
        nop
        nop
test_syscall_end:
test_syscall_end:
        nop
        nop
/***********************************************/
/***********************************************/
/* Test stepping over int3.
/* Test stepping over int3.
   The prefixes are pointless, but it's possible, so we exercise it.  */
   The prefixes are pointless, but it's possible, so we exercise it.  */
        nop
        nop
        .global test_int3
        .global test_int3
test_int3:
test_int3:
        repz
        repz
        repz
        repz
        int3
        int3
        nop
        nop
        .global test_int3_end
        .global test_int3_end
test_int3_end:
test_int3_end:
        nop
        nop
/***********************************************/
/***********************************************/
/* test rip-relative
/* test rip-relative
   GDB picks a spare register to hold the rip-relative address.
   GDB picks a spare register to hold the rip-relative address.
   Exercise all the possibilities (rax-rdi, sans rsp).  */
   Exercise all the possibilities (rax-rdi, sans rsp).  */
        .global test_rip_rax
        .global test_rip_rax
test_rip_rax:
test_rip_rax:
        add answer(%rip),%rax
        add answer(%rip),%rax
        .global test_rip_rax_end
        .global test_rip_rax_end
test_rip_rax_end:
test_rip_rax_end:
        nop
        nop
        .global test_rip_rbx
        .global test_rip_rbx
test_rip_rbx:
test_rip_rbx:
        add answer(%rip),%rbx
        add answer(%rip),%rbx
        .global test_rip_rbx_end
        .global test_rip_rbx_end
test_rip_rbx_end:
test_rip_rbx_end:
        nop
        nop
        .global test_rip_rcx
        .global test_rip_rcx
test_rip_rcx:
test_rip_rcx:
        add answer(%rip),%rcx
        add answer(%rip),%rcx
        .global test_rip_rcx_end
        .global test_rip_rcx_end
test_rip_rcx_end:
test_rip_rcx_end:
        nop
        nop
        .global test_rip_rdx
        .global test_rip_rdx
test_rip_rdx:
test_rip_rdx:
        add answer(%rip),%rdx
        add answer(%rip),%rdx
        .global test_rip_rdx_end
        .global test_rip_rdx_end
test_rip_rdx_end:
test_rip_rdx_end:
        nop
        nop
        .global test_rip_rbp
        .global test_rip_rbp
test_rip_rbp:
test_rip_rbp:
        add answer(%rip),%rbp
        add answer(%rip),%rbp
        .global test_rip_rbp_end
        .global test_rip_rbp_end
test_rip_rbp_end:
test_rip_rbp_end:
        nop
        nop
        .global test_rip_rsi
        .global test_rip_rsi
test_rip_rsi:
test_rip_rsi:
        add answer(%rip),%rsi
        add answer(%rip),%rsi
        .global test_rip_rsi_end
        .global test_rip_rsi_end
test_rip_rsi_end:
test_rip_rsi_end:
        nop
        nop
        .global test_rip_rdi
        .global test_rip_rdi
test_rip_rdi:
test_rip_rdi:
        add answer(%rip),%rdi
        add answer(%rip),%rdi
        .global test_rip_rdi_end
        .global test_rip_rdi_end
test_rip_rdi_end:
test_rip_rdi_end:
        nop
        nop
        /* skip over test data */
        /* skip over test data */
        jmp done
        jmp done
/* test rip-relative data */
/* test rip-relative data */
answer: .8byte 42
answer: .8byte 42
/***********************************************/
/***********************************************/
/* all done */
/* all done */
done:
done:
        mov $0,%rdi
        mov $0,%rdi
        call exit
        call exit
        hlt
        hlt
/***********************************************/
/***********************************************/
/* subroutine to help test call/ret */
/* subroutine to help test call/ret */
test_call_subr:
test_call_subr:
        nop
        nop
        .global test_call_end
        .global test_call_end
test_call_end:
test_call_end:
        nop
        nop
        .global test_ret
        .global test_ret
test_ret:
test_ret:
        ret
        ret
/***********************************************/
/***********************************************/
/* subroutine to help test abs-jmp/rep-ret */
/* subroutine to help test abs-jmp/rep-ret */
test_abs_jmp_subr:
test_abs_jmp_subr:
        nop
        nop
        .global test_abs_jmp_end
        .global test_abs_jmp_end
test_abs_jmp_end:
test_abs_jmp_end:
        nop
        nop
        .global test_rep_ret
        .global test_rep_ret
test_rep_ret:
test_rep_ret:
        repz
        repz
        ret
        ret
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.