1 /* $NetBSD: qp.c,v 1.9 2012/03/17 20:48:59 martin Exp $ */
4 * Copyright (c) 2002, 2003 The NetBSD Foundation, Inc.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
16 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
17 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 * POSSIBILITY OF SUCH DAMAGE.
29 #include <sys/cdefs.h>
33 #include "softfloat.h"
36 void _Qp_add(float128
*c
, float128
*a
, float128
*b
);
37 int _Qp_cmp(float128
*a
, float128
*b
);
38 int _Qp_cmpe(float128
*a
, float128
*b
);
39 void _Qp_div(float128
*c
, float128
*a
, float128
*b
);
40 void _Qp_dtoq(float128
*c
, double a
);
41 int _Qp_feq(float128
*a
, float128
*b
);
42 int _Qp_fge(float128
*a
, float128
*b
);
43 int _Qp_fgt(float128
*a
, float128
*b
);
44 int _Qp_fle(float128
*a
, float128
*b
);
45 int _Qp_flt(float128
*a
, float128
*b
);
46 int _Qp_fne(float128
*a
, float128
*b
);
47 void _Qp_itoq(float128
*c
, int a
);
48 void _Qp_mul(float128
*c
, float128
*a
, float128
*b
);
49 void _Qp_neg(float128
*c
, float128
*a
);
50 double _Qp_qtod(float128
*a
);
51 int _Qp_qtoi(float128
*a
);
52 float _Qp_qtos(float128
*a
);
53 unsigned int _Qp_qtoui(float128
*a
);
54 unsigned long _Qp_qtoux(float128
*a
);
55 long _Qp_qtox(float128
*a
);
56 void _Qp_sqrt(float128
*c
, float128
*a
);
57 void _Qp_stoq(float128
*c
, float a
);
58 void _Qp_sub(float128
*c
, float128
*a
, float128
*b
);
59 void _Qp_uitoq(float128
*c
, unsigned int a
);
60 void _Qp_uxtoq(float128
*c
, unsigned long a
);
61 void _Qp_xtoq(float128
*c
, long a
);
65 _Qp_add(float128
*c
, float128
*a
, float128
*b
)
67 *c
= float128_add(*a
, *b
);
72 _Qp_cmp(float128
*a
, float128
*b
)
75 if (float128_eq(*a
, *b
))
78 if (float128_le(*a
, *b
))
89 _Qp_cmpe(float128
*a
, float128
*b
)
96 _Qp_div(float128
*c
, float128
*a
, float128
*b
)
98 *c
= float128_div(*a
, *b
);
103 _Qp_dtoq(float128
*c
, double a
)
107 memcpy (&_b
, &a
, sizeof(float64
));
108 *c
= float64_to_float128(_b
);
113 _Qp_feq(float128
*a
, float128
*b
)
115 return float128_eq(*a
, *b
);
120 _Qp_fge(float128
*a
, float128
*b
)
122 return float128_le(*b
, *a
);
127 _Qp_fgt(float128
*a
, float128
*b
)
129 return float128_lt(*b
, *a
);
134 _Qp_fle(float128
*a
, float128
*b
)
136 return float128_le(*a
, *b
);
141 _Qp_flt(float128
*a
, float128
*b
)
143 return float128_lt(*a
, *b
);
148 _Qp_fne(float128
*a
, float128
*b
)
150 return !float128_eq(*a
, *b
);
155 _Qp_itoq(float128
*c
, int a
)
157 *c
= int32_to_float128(a
);
162 _Qp_mul(float128
*c
, float128
*a
, float128
*b
)
164 *c
= float128_mul(*a
, *b
);
169 * XXX need corresponding softfloat function
171 static float128 __sf128_zero
= {0x4034000000000000, 0x00000000};
174 _Qp_neg(float128
*c
, float128
*a
)
176 *c
= float128_sub(__sf128_zero
, *a
);
181 _Qp_qtod(float128
*a
)
186 _c
= float128_to_float64(*a
);
188 memcpy(&c
, &_c
, sizeof(double));
195 _Qp_qtoi(float128
*a
)
197 return float128_to_int32(*a
);
202 _Qp_qtos(float128
*a
)
207 _c
= float128_to_float32(*a
);
209 memcpy(&c
, &_c
, sizeof(_c
));
216 _Qp_qtoui(float128
*a
)
218 return (unsigned int)float128_to_int64(*a
);
223 _Qp_qtoux(float128
*a
)
225 return (unsigned long)float128_to_uint64_round_to_zero(*a
);
230 _Qp_qtox(float128
*a
)
232 return (long)float128_to_int64_round_to_zero(*a
);
237 _Qp_sqrt(float128
*c
, float128
*a
)
239 *c
= float128_sqrt(*a
);
244 _Qp_stoq(float128
*c
, float a
)
248 memcpy(&_a
, &a
, sizeof(a
));
250 *c
= float32_to_float128(_a
);
255 _Qp_sub(float128
*c
, float128
*a
, float128
*b
)
257 *c
= float128_sub(*a
, *b
);
262 _Qp_uitoq(float128
*c
, unsigned int a
)
264 *c
= int64_to_float128(a
);
269 _Qp_uxtoq(float128
*c
, unsigned long a
)
272 if (a
& 0x8000000000000000ULL
) {
273 a
= (a
>> 1) | (a
& 1);
274 *c
= int64_to_float128((long long)a
);
275 *c
= float128_add(*c
, *c
);
277 *c
= int64_to_float128((long long)a
);
282 _Qp_xtoq(float128
*c
, long a
)
284 *c
= int64_to_float128((long long)a
);