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

Subversion Repositories openrisc_me

[/] [openrisc/] [tags/] [gdb/] [gdb-6.8/] [gdb-6.8.openrisc-2.1/] [sim/] [testsuite/] [sim/] [m32r/] [trap.cgs] - Diff between revs 24 and 33

Only display areas with differences | Details | Blame | View Log

Rev 24 Rev 33
# m32r testcase for trap #$uimm4
# m32r testcase for trap #$uimm4
# mach(): m32r m32rx
# mach(): m32r m32rx
        .include "testutils.inc"
        .include "testutils.inc"
        start
        start
        .global trap
        .global trap
trap:
trap:
; Test 1: bbpsw = 0, bpsw = 1, psw = 0
; Test 1: bbpsw = 0, bpsw = 1, psw = 0
        ; bbsm = 0, bie = 0, bbcond = 0
        ; bbsm = 0, bie = 0, bbcond = 0
        mvi_h_gr r4, 0
        mvi_h_gr r4, 0
        mvtc r4, cr8
        mvtc r4, cr8
        ; bsm = 1, bie = 1, bcond = 1, sm = 0, ie = 0, cond = 0
        ; bsm = 1, bie = 1, bcond = 1, sm = 0, ie = 0, cond = 0
        mvi_h_gr r4, 0xc100
        mvi_h_gr r4, 0xc100
        mvtc r4, cr0
        mvtc r4, cr0
        ; bbpc = 0
        ; bbpc = 0
        mvaddr_h_gr r4, 0
        mvaddr_h_gr r4, 0
        mvtc r4, bbpc
        mvtc r4, bbpc
        ; bpc = 42
        ; bpc = 42
        mvaddr_h_gr r4, 42
        mvaddr_h_gr r4, 42
        mvtc r4, bpc
        mvtc r4, bpc
        ; Copy trap2_handler to trap area of memory.
        ; Copy trap2_handler to trap area of memory.
        ld24 r0,#0x48 ; address of trap 2 handler
        ld24 r0,#0x48 ; address of trap 2 handler
        ld24 r1,#trap2_handler
        ld24 r1,#trap2_handler
        ld r2,@r1
        ld r2,@r1
        st r2,@r0
        st r2,@r0
        ; Set up return address.
        ; Set up return address.
        ld24 r5,#trap2_ret1
        ld24 r5,#trap2_ret1
trap_insn1:
trap_insn1:
        trap #2
        trap #2
        fail
        fail
trap2_ret1:
trap2_ret1:
        ; test bbsm = 1, bbie = 1, bbcond = 1
        ; test bbsm = 1, bbie = 1, bbcond = 1
        mvfc r4, cr8
        mvfc r4, cr8
        test_h_gr r4, 0xc1
        test_h_gr r4, 0xc1
        ; test bsm = 0, bie = 0, bcond = 0, sm = 0, ie = 0, cond = 0
        ; test bsm = 0, bie = 0, bcond = 0, sm = 0, ie = 0, cond = 0
        mvfc r4, cr0
        mvfc r4, cr0
        test_h_gr r4, 0
        test_h_gr r4, 0
        ; test bbpc = 42
        ; test bbpc = 42
        mvfc r4, bbpc
        mvfc r4, bbpc
        test_h_gr r4, 42
        test_h_gr r4, 42
        ; test bpc = proper return address
        ; test bpc = proper return address
        mvfc r4, bpc
        mvfc r4, bpc
        test_h_gr r4, trap_insn1 + 4
        test_h_gr r4, trap_insn1 + 4
; Test 2: bbpsw = 1, bpsw = 0, psw = 1
; Test 2: bbpsw = 1, bpsw = 0, psw = 1
        ; bbsm = 1, bie = 1, bbcond = 1
        ; bbsm = 1, bie = 1, bbcond = 1
        mvi_h_gr r4, 0xc1
        mvi_h_gr r4, 0xc1
        mvtc r4, cr8
        mvtc r4, cr8
        ; bsm = 0, bie = 0, bcond = 0, sm = 1, ie = 1, cond = 1
        ; bsm = 0, bie = 0, bcond = 0, sm = 1, ie = 1, cond = 1
        mvi_h_gr r4, 0xc1
        mvi_h_gr r4, 0xc1
        mvtc r4, cr0
        mvtc r4, cr0
        ; bbpc = 42
        ; bbpc = 42
        mvaddr_h_gr r4, 42
        mvaddr_h_gr r4, 42
        mvtc r4, bbpc
        mvtc r4, bbpc
        ; bpc = 0
        ; bpc = 0
        mvaddr_h_gr r4, 0
        mvaddr_h_gr r4, 0
        mvtc r4, bpc
        mvtc r4, bpc
        ; Set up return address.
        ; Set up return address.
        ld24 r5,#trap2_ret2
        ld24 r5,#trap2_ret2
trap_insn2:
trap_insn2:
        trap #2
        trap #2
        fail
        fail
trap2_ret2:
trap2_ret2:
        ; test bbsm = 0, bbie = 0, bbcond = 0
        ; test bbsm = 0, bbie = 0, bbcond = 0
        mvfc r4, cr8
        mvfc r4, cr8
        test_h_gr r4, 0
        test_h_gr r4, 0
        ; test bsm = 1, bie = 1, bcond = 1, sm = 1, ie = 0, cond = 0
        ; test bsm = 1, bie = 1, bcond = 1, sm = 1, ie = 0, cond = 0
        mvfc r4, cr0
        mvfc r4, cr0
        test_h_gr r4, 0xc180
        test_h_gr r4, 0xc180
        ; test bbpc = 0
        ; test bbpc = 0
        mvfc r4, bbpc
        mvfc r4, bbpc
        test_h_gr r4, 0
        test_h_gr r4, 0
        ; test bpc = proper return address
        ; test bpc = proper return address
        mvfc r4, bpc
        mvfc r4, bpc
        test_h_gr r4, trap_insn2 + 4
        test_h_gr r4, trap_insn2 + 4
        pass
        pass
        .data
        .data
; Don't use rte as it will undo the effects of trap we're testing.
; Don't use rte as it will undo the effects of trap we're testing.
        .p2align 2
        .p2align 2
trap2_handler:
trap2_handler:
        jmp r5
        jmp r5
        nop
        nop
 
 

powered by: WebSVN 2.1.0

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