summaryrefslogtreecommitdiff
path: root/usr/src/cmd/fps/fptest/linpack.h
blob: 32ec023bcfd02f0d2cb0c031bd686cb9da92c091 (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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License (the "License").
 * You may not use this file except in compliance with the License.
 *
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 * or http://www.opensolaris.org/os/licensing.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information: Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 */

/*
 * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */

#ifndef _LINPACK_H
#define	_LINPACK_H

#ifdef __cplusplus
extern "C" {
#endif

#ifdef	DP
#define	PREC	"double"
#define	LINPACK	dlinpack_test
#define	LINSUB	dlinsub
#define	MATGEN	dmatgen
#define	GEFA	dgetrf_64
#define	GESL	dgetrs_64
#define	AXPY	daxpy
#define	SCAL	dscal
#define	EPSLON	depslon
#define	MXPY	dmxpy
#define	REAL	double
#define	LP_ZERO	0.0e0
#define	LP_ONE	1.0e0
#define	MAT_SIZE	d_mat_size
#define	LinpValsA	d_linpvalsa
#define	LAPACK_ECACHE_SIZE	d_lapack_ecache_size

#else

#define	PREC	"single"
#define	LINPACK	slinpack_test
#define	LINSUB	slinsub
#define	MATGEN	smatgen
#define	GEFA	sgetrf_64
#define	GESL	sgetrs_64
#define	AXPY	saxpy
#define	SCAL	sscal
#define	EPSLON	sepslon
#define	MXPY	smxpy
#define	REAL	float
#define	LP_ZERO	0.0
#define	LP_ONE	1.0
#define	MAT_SIZE	s_mat_size
#define	LinpValsA	s_linpvalsa
#define	LAPACK_ECACHE_SIZE	s_lapack_ecache_size

#endif

struct LinpVals {
	REAL  residn;
	REAL  resid;
	REAL  eps;
	REAL  x11;
	REAL  xn1;
};

#undef FPS_LAPA_LIB8
#undef FPS_LAPA_LIB10
#undef FPS_LAPA_LIB11
#undef FPS_LAPA_LIB12
#undef FPS_LAPA_LIB13
#undef FPS_LAPA_UNK

/* SS12 U1 */
#if (LAPA_COMP_PERF_6 == 1)
#define	FPS_LAPA_LIB13

#elif (LAPA_COMP_PERF_5 == 1)
#define	FPS_LAPA_LIB13

/* QA SS12 */
#elif (LAPA_COMP_PERF_4 == 1)
#define	FPS_LAPA_LIB13

/* SS12 */
#elif (LAPA_COMP_PERF_3 == 1)
#define	FPS_LAPA_LIB12

/* SS11 */
#elif (LAPA_COMP_PERF_2 == 1)
#define	FPS_LAPA_LIB11

/* SOS8 */
#elif (LAPA_COMP_PERF_0 == 1)
#define	FPS_LAPA_LIB8

#else

#define	FPS_LAPA_UNK
#endif

#ifdef __sparc

/* V9B V9 or V8 arch */
#ifdef V9B
#ifdef FPS_LAPA_LIB8
#include <singdoub64v9b_sos8.h>
#endif

#ifdef FPS_LAPA_LIB10
#include <singdoub64v9b_sos10.h>
#endif

#ifdef FPS_LAPA_LIB11
#include <singdoub64v9b_sos11.h>
#endif

#ifdef FPS_LAPA_LIB12
#include <singdoub64v9b_ss12.h>
#endif

#ifdef FPS_LAPA_LIB13
#include <singdoub64v9b_ss12u1.h>
#endif

#else

#ifdef FPS_LAPA_LIB8
#include <singdoub64_sos8.h>
#endif

#ifdef FPS_LAPA_LIB10
#include <singdoub64_sos10.h>
#endif

/* This is NOT a typo. singdoub64_sos10.h works with SOS11 */
#ifdef FPS_LAPA_LIB11
#include <singdoub64_sos10.h>
#endif

#ifdef FPS_LAPA_LIB12
#include <singdoub64_ss12.h>
#endif

#ifdef FPS_LAPA_LIB13
#include <singdoub64_ss12u1.h>
#endif

#endif /* V9B */

#endif

#ifdef __cplusplus
}
#endif

#endif /* _LINPACK_H */