1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
|
# cr16 testcase for excp uimm4
# mach(): cr16
.include "testutils.inc"
start
.global excp
excp:
pass # pass macro use the excp 8
## Test 1: bbpsw = 0, bpsw = 1, psw = 0
#
# # bbsm = 0, bie = 0, bbcond = 0
# movw $0, r4
# lpr r4, cr8
#
# # bsm = 1, bie = 1, bcond = 1, sm = 0, ie = 0, cond = 0
# movw $0xc100, r4
# lpr r4, cr0
#
# # bbpc = 0
# movw $0, r4
# mvtc r4, bbpc
#
# # bpc = 42
# mvaddr_h_gr r4, 42
# mvtc r4, bpc
#
# # Copy excp2_handler to excp area of memory.
# ld24 r0,#0x48 # address of excp 2 handler
# ld24 r1,#excp2_handler
# ld r2,@r1
# st r2,@r0
# # Set up return address.
# ld24 r5,#excp2_ret1
#
#excp_insn1:
# excp 2
# fail
#
#excp2_ret1:
# # test bbsm = 1, bbie = 1, bbcond = 1
# mvfc r4, cr8
# test_h_gr r4, 0xc1
#
# # test bsm = 0, bie = 0, bcond = 0, sm = 0, ie = 0, cond = 0
# mvfc r4, cr0
# test_h_gr r4, 0
#
# # test bbpc = 42
# mvfc r4, bbpc
# test_h_gr r4, 42
#
# # test bpc = proper return address
# mvfc r4, bpc
# test_h_gr r4, excp_insn1 + 4
#
## Test 2: bbpsw = 1, bpsw = 0, psw = 1
#
# # bbsm = 1, bie = 1, bbcond = 1
# mvi_h_gr r4, 0xc1
# mvtc r4, cr8
#
# # bsm = 0, bie = 0, bcond = 0, sm = 1, ie = 1, cond = 1
# mvi_h_gr r4, 0xc1
# mvtc r4, cr0
#
# # bbpc = 42
# mvaddr_h_gr r4, 42
# mvtc r4, bbpc
#
# # bpc = 0
# mvaddr_h_gr r4, 0
# mvtc r4, bpc
#
# # Set up return address.
# ld24 r5,#excp2_ret2
#
#excp_insn2:
# excp #2
# fail
#
#excp2_ret2:
# # test bbsm = 0, bbie = 0, bbcond = 0
# mvfc r4, cr8
# test_h_gr r4, 0
#
# # test bsm = 1, bie = 1, bcond = 1, sm = 1, ie = 0, cond = 0
# mvfc r4, cr0
# test_h_gr r4, 0xc180
#
# # test bbpc = 0
# mvfc r4, bbpc
# test_h_gr r4, 0
#
# # test bpc = proper return address
# mvfc r4, bpc
# test_h_gr r4, excp_insn2 + 4
#
# pass
#
# .data
#
## Don't use rte as it will undo the effects of excp we're testing.
#
# .p2align 2
#excp2_handler:
# jmp r5
# nop
|