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