aboutsummaryrefslogtreecommitdiffstats
path: root/runtime/mppa_k1c/vararg.S
blob: 9869eb0b101d358105301f1cd6e613a9cc63aea4 (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
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
113
114
115
116

// typedef void * va_list;
// unsigned int __compcert_va_int32(va_list * ap);
// unsigned long long __compcert_va_int64(va_list * ap);

	.text
	.balign 2
	.globl __compcert_va_int32
__compcert_va_int32:
	ld		$r32 = 0[$r0]	# $r32 <- *ap
;;
	addd	$r32 = $r32, 8	# $r32 <- $r32 + WORDSIZE
;;
	sd		0[$r0] = $r32	# *ap <- $r32
;;
	lws		$r0 = -8[$r32]	# retvalue <- 32-bits at *ap - WORDSIZE
	ret
;;

	.text
	.balign 2
	.globl __compcert_va_int64
	.globl __compcert_va_float64
	.globl __compcert_va_composite
__compcert_va_int64:
__compcert_va_float64:
# FIXME this assumes pass-by-reference
__compcert_va_composite:
# Prologue
	ld		$r32 = 0[$r0]	# $r32 <- *ap
;;
	addd	$r32 = $r32, 8	# $r32 <- $r32 + WORDSIZE
;;
	sd		0[$r0] = $r32	# *ap <- $r32
;;
	ld		$r0 = -8[$r32]	# retvalue <- 64-bits at *ap - WORDSIZE
	ret
;;
	
# FIXME this assumes pass-by-reference
	.globl __compcert_acswapd
__compcert_acswapd:
	acswapd	0[$r1] = $r2r3
	;;
	sq	0[$r0] = $r2r3
	ret
	;;
	.globl __compcert_acswapw
__compcert_acswapw:
	acswapw	0[$r1] = $r2r3
	;;
	sq	0[$r0] = $r2r3
	ret
	;;

	.globl __compcert_i32_sdiv
	.globl __compcert_i32_smod
	.globl __compcert_i32_udiv
	.globl __compcert_i32_umod
__compcert_i32_sdiv:
__compcert_i32_smod:
__compcert_i32_umod:
	sxwd $r0 = $r0
	sxwd $r1 = $r1
	make $r2 = 0x3ff0000000000000
	;;
	floatd.rn.s $r0 = $r0, 0
	;;
	floatd.rn.s $r3 = $r1, 0
	;;
	floatw.rn.s $r1 = $r1, 0
	;;
	finvw $r1=$r1
	;;
	fwidenlwd $r1 = $r1
	;;
	fmuld $r0 = $r0, $r1
	;;
	ffmsd $r2 = $r1, $r3
	copyd $r1 = $r0
	;;
	ffmad $r1 = $r2, $r0
	;;
	ffmad $r0 = $r2, $r1
	;;
	fixedd.rz $r0 = $r0, 0
	ret
	;;

__compcert_i32_udiv:
	zxwd $r0 = $r0
	zxwd $r1 = $r1
	make $r2 = 0x3ff0000000000000
	;;
	floatud.rn.s $r0 = $r0, 0
	;;
	floatud.rn.s $r3 = $r1, 0
	;;
	floatuw.rn.s $r1 = $r1, 0
	;;
	finvw $r1=$r1
	;;
	fwidenlwd $r1 = $r1
	;;
	fmuld $r0 = $r0, $r1
	;;
	ffmsd $r2 = $r1, $r3
	copyd $r1 = $r0
	;;
	ffmad $r1 = $r2, $r0
	;;
	ffmad $r0 = $r2, $r1
	;;
	fixedud.rz $r0 = $r0, 0
	ret
	;;