10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright 2011 Nexenta Systems, Inc. All rights reserved.
24 */
25 /*
26 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
27 * Use is subject to license terms.
28 */
29
30 #if defined(ELFOBJ)
31 #pragma weak finitel = __finitel
32 #endif
33
34 #include "libm.h"
35
36 #if defined(__sparc)
37 int
38 finitel(long double x) {
39 int *px = (int *) &x;
40 return ((px[0] & ~0x80000000) < 0x7fff0000);
41 }
42 #elif defined(__x86)
43 int
44 finitel(long double x) {
45 int *px = (int *) &x, t = px[2] & 0x7fff;
46 #if defined(HANDLE_UNSUPPORTED)
47 return (t != 0x7fff && ((px[1] & 0x80000000) != 0 || t == 0));
48 #else
49 return (t != 0x7fff);
50 #endif
51 }
52 #endif /* defined(__sparc) || defined(__x86) */
|
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright 2011 Nexenta Systems, Inc. All rights reserved.
24 */
25 /*
26 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
27 * Use is subject to license terms.
28 */
29
30 #include "libm.h"
31
32 #if defined(__sparc)
33 int
34 finitel(long double x) {
35 int *px = (int *) &x;
36 return ((px[0] & ~0x80000000) < 0x7fff0000);
37 }
38 #elif defined(__x86)
39 int
40 finitel(long double x) {
41 int *px = (int *) &x, t = px[2] & 0x7fff;
42 #if defined(HANDLE_UNSUPPORTED)
43 return (t != 0x7fff && ((px[1] & 0x80000000) != 0 || t == 0));
44 #else
45 return (t != 0x7fff);
46 #endif
47 }
48 #endif /* defined(__sparc) || defined(__x86) */
|