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
|
#include "pcr.h"
.text
.globl get_fp_state
.ent get_fp_state
get_fp_state:
mffsr $v0
sf.d $f0 , 0($a0)
sf.d $f1 , 8($a0)
sf.d $f2 , 16($a0)
sf.d $f3 , 24($a0)
sf.d $f4 , 32($a0)
sf.d $f5 , 40($a0)
sf.d $f6 , 48($a0)
sf.d $f7 , 56($a0)
sf.d $f8 , 64($a0)
sf.d $f9 , 72($a0)
sf.d $f10, 80($a0)
sf.d $f11, 88($a0)
sf.d $f12, 96($a0)
sf.d $f13,104($a0)
sf.d $f14,112($a0)
sf.d $f15,120($a0)
sf.d $f16,128($a0)
sf.d $f17,136($a0)
sf.d $f18,144($a0)
sf.d $f19,152($a0)
sf.d $f20,160($a0)
sf.d $f21,168($a0)
sf.d $f22,176($a0)
sf.d $f23,184($a0)
sf.d $f24,192($a0)
sf.d $f25,200($a0)
sf.d $f26,208($a0)
sf.d $f27,216($a0)
sf.d $f28,224($a0)
sf.d $f29,232($a0)
sf.d $f30,240($a0)
sf.d $f31,248($a0)
ret
.end get_fp_state
.globl put_fp_state
.ent put_fp_state
put_fp_state:
lf.d $f0 , 0($a0)
lf.d $f1 , 8($a0)
lf.d $f2 , 16($a0)
lf.d $f3 , 24($a0)
lf.d $f4 , 32($a0)
lf.d $f5 , 40($a0)
lf.d $f6 , 48($a0)
lf.d $f7 , 56($a0)
lf.d $f8 , 64($a0)
lf.d $f9 , 72($a0)
lf.d $f10, 80($a0)
lf.d $f11, 88($a0)
lf.d $f12, 96($a0)
lf.d $f13,104($a0)
lf.d $f14,112($a0)
lf.d $f15,120($a0)
lf.d $f16,128($a0)
lf.d $f17,136($a0)
lf.d $f18,144($a0)
lf.d $f19,152($a0)
lf.d $f20,160($a0)
lf.d $f21,168($a0)
lf.d $f22,176($a0)
lf.d $f23,184($a0)
lf.d $f24,192($a0)
lf.d $f25,200($a0)
lf.d $f26,208($a0)
lf.d $f27,216($a0)
lf.d $f28,224($a0)
lf.d $f29,232($a0)
lf.d $f30,240($a0)
lf.d $f31,248($a0)
mtfsr $a1
ret
.end put_fp_state
|