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
111
112
|
# frv testcase for rstf $FRk,@($GRi,$GRj)
# mach: frv
# as(frv): -mcpu=frv
.include "testutils.inc"
start
.global add
add:
; No nesr's active
set_gr_gr sp,gr10
set_gr_gr sp,gr24
set_mem_limmed 0x2222,0x2222,gr24
set_gr_gr gr24,gr27
inc_gr_immed -4,gr27
set_mem_limmed 0x3333,0x3333,gr27
set_gr_gr gr27,gr26
inc_gr_immed -4,gr26
set_mem_limmed 0x4444,0x4444,gr26
set_gr_gr gr26,gr25
inc_gr_immed -4,gr25
set_mem_limmed 0x5555,0x5555,gr25
set_gr_limmed 0x1111,0x1111,gr20
set_fr_iimmed 0x1111,0x1111,fr20
set_gr_immed 0,gr7
set_fr_iimmed 0xffff,0xffff,fr8
rstf fr8,@(sp,gr7)
test_mem_limmed 0xffff,0xffff,gr24
test_mem_limmed 0x3333,0x3333,gr27
test_mem_limmed 0x4444,0x4444,gr26
test_mem_limmed 0x5555,0x5555,gr25
test_gr_limmed 0x1111,0x1111,gr20
test_fr_limmed 0x1111,0x1111,fr20
; 1 nesr active with the incorrect address in neear for gr
inc_gr_immed -8,gr10
nldi @(sp,-8),gr20
test_spr_gr neear0,gr10
set_mem_limmed 0x2222,0x2222,gr24
set_mem_limmed 0x3333,0x3333,gr27
set_mem_limmed 0x4444,0x4444,gr26
set_mem_limmed 0x5555,0x5555,gr25
set_gr_limmed 0x1111,0x1111,gr20
set_fr_iimmed 0x1111,0x1111,fr20
set_fr_iimmed 0xffff,0xffff,fr8
set_gr_immed -4,gr7
rstf fr8,@(sp,gr7)
test_mem_limmed 0x2222,0x2222,gr24
test_mem_limmed 0xffff,0xffff,gr27
test_mem_limmed 0x4444,0x4444,gr26
test_mem_limmed 0x5555,0x5555,gr25
test_gr_limmed 0x1111,0x1111,gr20
test_fr_limmed 0x1111,0x1111,fr20
; 1 nesr active with the incorrect address in neear for fr
inc_gr_immed -4,gr10
nldfi @(sp,-12),fr20
test_spr_gr neear1,gr10
set_mem_limmed 0x2222,0x2222,gr24
set_mem_limmed 0x3333,0x3333,gr27
set_mem_limmed 0x4444,0x4444,gr26
set_mem_limmed 0x5555,0x5555,gr25
set_gr_limmed 0x1111,0x1111,gr20
set_fr_iimmed 0x1111,0x1111,fr20
set_fr_iimmed 0xffff,0xffff,fr8
inc_gr_immed -4,sp
set_gr_immed 4,gr7
rstf fr8,@(sp,gr7)
test_mem_limmed 0xffff,0xffff,gr24
test_mem_limmed 0x3333,0x3333,gr27
test_mem_limmed 0x4444,0x4444,gr26
test_mem_limmed 0x5555,0x5555,gr25
test_gr_limmed 0x1111,0x1111,gr20
test_fr_limmed 0x1111,0x1111,fr20
; 1 nesr active with the correct address in neear for gr
set_mem_limmed 0x2222,0x2222,gr24
set_mem_limmed 0x3333,0x3333,gr27
set_mem_limmed 0x4444,0x4444,gr26
set_mem_limmed 0x5555,0x5555,gr25
set_gr_limmed 0x1111,0x1111,gr20
set_fr_iimmed 0x1111,0x1111,fr20
set_fr_iimmed 0xffff,0xffff,fr8
inc_gr_immed -4,sp
set_gr_immed 0,gr7
rstf fr8,@(sp,gr7)
test_mem_limmed 0x2222,0x2222,gr24
test_mem_limmed 0x3333,0x3333,gr27
test_mem_limmed 0xffff,0xffff,gr26
test_mem_limmed 0x5555,0x5555,gr25
test_gr_limmed 0xffff,0xffff,gr20
test_fr_limmed 0x1111,0x1111,fr20
; 1 nesr active with the correct address in neear for fr
set_mem_limmed 0x2222,0x2222,gr24
set_mem_limmed 0x3333,0x3333,gr27
set_mem_limmed 0x4444,0x4444,gr26
set_mem_limmed 0x5555,0x5555,gr25
set_gr_limmed 0x1111,0x1111,gr20
set_fr_iimmed 0x1111,0x1111,fr20
set_fr_iimmed 0xffff,0xffff,fr8
set_gr_immed -4,gr7
rstf fr8,@(sp,gr7)
test_mem_limmed 0x2222,0x2222,gr24
test_mem_limmed 0x3333,0x3333,gr27
test_mem_limmed 0x4444,0x4444,gr26
test_mem_limmed 0xffff,0xffff,gr25
test_gr_limmed 0x1111,0x1111,gr20
test_fr_limmed 0xffff,0xffff,fr20
pass
|