aboutsummaryrefslogtreecommitdiff
path: root/pk/fp_asm.S
blob: a247952fd7d1d7ff4711f36da019fd98587f157a (plain)
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
// See LICENSE for license details.

	.text
	.globl	get_fp_state
get_fp_state:

	frsr	v0

	fsd		f0 ,  0(a0)
	fsd		f1 ,  8(a0)
	fsd		f2 , 16(a0)
	fsd		f3 , 24(a0)
	fsd		f4 , 32(a0)
	fsd		f5 , 40(a0)
	fsd		f6 , 48(a0)
	fsd		f7 , 56(a0)
	fsd		f8 , 64(a0)
	fsd		f9 , 72(a0)
	fsd		f10, 80(a0)
	fsd		f11, 88(a0)
	fsd		f12, 96(a0)
	fsd		f13,104(a0)
	fsd		f14,112(a0)
	fsd		f15,120(a0)
	fsd		f16,128(a0)
	fsd		f17,136(a0)
	fsd		f18,144(a0)
	fsd		f19,152(a0)
	fsd		f20,160(a0)
	fsd		f21,168(a0)
	fsd		f22,176(a0)
	fsd		f23,184(a0)
	fsd		f24,192(a0)
	fsd		f25,200(a0)
	fsd		f26,208(a0)
	fsd		f27,216(a0)
	fsd		f28,224(a0)
	fsd		f29,232(a0)
	fsd		f30,240(a0)
	fsd		f31,248(a0)

	ret

	.globl	put_fp_state
put_fp_state:

	fld		f0 ,  0(a0)
	fld		f1 ,  8(a0)
	fld		f2 , 16(a0)
	fld		f3 , 24(a0)
	fld		f4 , 32(a0)
	fld		f5 , 40(a0)
	fld		f6 , 48(a0)
	fld		f7 , 56(a0)
	fld		f8 , 64(a0)
	fld		f9 , 72(a0)
	fld		f10, 80(a0)
	fld		f11, 88(a0)
	fld		f12, 96(a0)
	fld		f13,104(a0)
	fld		f14,112(a0)
	fld		f15,120(a0)
	fld		f16,128(a0)
	fld		f17,136(a0)
	fld		f18,144(a0)
	fld		f19,152(a0)
	fld		f20,160(a0)
	fld		f21,168(a0)
	fld		f22,176(a0)
	fld		f23,184(a0)
	fld		f24,192(a0)
	fld		f25,200(a0)
	fld		f26,208(a0)
	fld		f27,216(a0)
	fld		f28,224(a0)
	fld		f29,232(a0)
	fld		f30,240(a0)
	fld		f31,248(a0)

	fssr	a1

	ret