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
117
118
119
|
divert(-1)
dnl m4 macros for alpha assembler on unicos.
dnl Copyright 2000, 2002, 2003, 2004 Free Software Foundation, Inc.
dnl
dnl This file is part of the GNU MP Library.
dnl
dnl The GNU MP Library is free software; you can redistribute it and/or
dnl modify it under the terms of the GNU Lesser General Public License as
dnl published by the Free Software Foundation; either version 3 of the
dnl License, or (at your option) any later version.
dnl
dnl The GNU MP Library is distributed in the hope that it will be useful,
dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
dnl Lesser General Public License for more details.
dnl
dnl You should have received a copy of the GNU Lesser General Public License
dnl along with the GNU MP Library. If not, see http://www.gnu.org/licenses/.
dnl Note that none of the standard GMP_ASM_ autoconf tests are done for
dnl unicos, so none of the config.m4 results can be used here.
dnl No underscores on unicos
define(`GSYM_PREFIX')
define(`ASM_START',
m4_assert_numargs(0)
` .ident dummy')
define(`X',
m4_assert_numargs(1)
`^X$1')
define(`FLOAT64',
m4_assert_numargs(2)
` .psect $1@crud,data
$1: .t_floating $2
.endp')
dnl Called: PROLOGUE_cpu(GSYM_PREFIX`'foo[,gp|noalign])
dnl EPILOGUE_cpu(GSYM_PREFIX`'foo)
define(`PROLOGUE_cpu',
m4_assert_numargs_range(1,2)
`ifelse(`$2',gp,,
`ifelse(`$2',noalign,,
`ifelse(`$2',,,`m4_error(`Unrecognised PROLOGUE parameter
')')')')dnl
.stack 192 ; What does this mean? Only Cray knows.
.psect $1@code,code,cache
$1::')
define(`EPILOGUE_cpu',
m4_assert_numargs(1)
` .endp')
dnl Usage: LDGP(dst,src)
dnl
dnl Emit an "ldgp dst,src", but only on systems using a GOT (which unicos
dnl doesn't).
define(LDGP,
m4_assert_numargs(2)
)
dnl Usage: EXTERN(variable_name)
define(`EXTERN',
m4_assert_numargs(1)
` .extern $1')
define(`DATASTART',
m4_assert_numargs(1)
` .psect $1@crud,data
$1:')
define(`DATAEND',
m4_assert_numargs(0)
` .endp')
define(`ASM_END',
m4_assert_numargs(0)
` .end')
define(`cvttqc',
m4_assert_numargs(-1)
`cvttq/c')
dnl Load a symbolic address into a register
define(`LEA',
m4_assert_numargs(2)
`laum $1, $2(r31)
sll $1, 32, $1
lalm $1, $2($1)
lal $1, $2($1)')
dnl Usage: ALIGN(bytes)
dnl
dnl Unicos assembler .align emits zeros, even in code segments, so disable
dnl aligning.
dnl
dnl GCC uses a macro emiting nops until the desired alignment is reached
dnl (see unicosmk_file_start in alpha.c). Could do something like that if
dnl we cared. The maximum desired alignment must be established at the
dnl start of the section though, since of course emitting nops only
dnl advances relative to the section beginning.
define(`ALIGN',
m4_assert_numargs(1)
)
divert
|