125c28e83SPiotr Jasiukajtis /* 225c28e83SPiotr Jasiukajtis * CDDL HEADER START 325c28e83SPiotr Jasiukajtis * 425c28e83SPiotr Jasiukajtis * The contents of this file are subject to the terms of the 525c28e83SPiotr Jasiukajtis * Common Development and Distribution License (the "License"). 625c28e83SPiotr Jasiukajtis * You may not use this file except in compliance with the License. 725c28e83SPiotr Jasiukajtis * 825c28e83SPiotr Jasiukajtis * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 925c28e83SPiotr Jasiukajtis * or http://www.opensolaris.org/os/licensing. 1025c28e83SPiotr Jasiukajtis * See the License for the specific language governing permissions 1125c28e83SPiotr Jasiukajtis * and limitations under the License. 1225c28e83SPiotr Jasiukajtis * 1325c28e83SPiotr Jasiukajtis * When distributing Covered Code, include this CDDL HEADER in each 1425c28e83SPiotr Jasiukajtis * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 1525c28e83SPiotr Jasiukajtis * If applicable, add the following below this CDDL HEADER, with the 1625c28e83SPiotr Jasiukajtis * fields enclosed by brackets "[]" replaced with your own identifying 1725c28e83SPiotr Jasiukajtis * information: Portions Copyright [yyyy] [name of copyright owner] 1825c28e83SPiotr Jasiukajtis * 1925c28e83SPiotr Jasiukajtis * CDDL HEADER END 2025c28e83SPiotr Jasiukajtis */ 2125c28e83SPiotr Jasiukajtis /* 2225c28e83SPiotr Jasiukajtis * Copyright 2011 Nexenta Systems, Inc. All rights reserved. 2325c28e83SPiotr Jasiukajtis */ 2425c28e83SPiotr Jasiukajtis /* 2525c28e83SPiotr Jasiukajtis * Copyright 2005 Sun Microsystems, Inc. All rights reserved. 2625c28e83SPiotr Jasiukajtis * Use is subject to license terms. 2725c28e83SPiotr Jasiukajtis */ 2825c28e83SPiotr Jasiukajtis 29*ddc0e0b5SRichard Lowe #pragma weak __nextafter = nextafter 30*ddc0e0b5SRichard Lowe #pragma weak _nextafter = nextafter 3125c28e83SPiotr Jasiukajtis 3225c28e83SPiotr Jasiukajtis #include "libm.h" 3325c28e83SPiotr Jasiukajtis #include <float.h> /* DBL_MIN */ 3425c28e83SPiotr Jasiukajtis 3525c28e83SPiotr Jasiukajtis double 3625c28e83SPiotr Jasiukajtis nextafter(double x, double y) { 3725c28e83SPiotr Jasiukajtis int hx, hy, k; 3825c28e83SPiotr Jasiukajtis double ans; 3925c28e83SPiotr Jasiukajtis unsigned lx; 4025c28e83SPiotr Jasiukajtis volatile double dummy; 4125c28e83SPiotr Jasiukajtis 4225c28e83SPiotr Jasiukajtis hx = ((int *)&x)[HIWORD]; 4325c28e83SPiotr Jasiukajtis lx = ((int *)&x)[LOWORD]; 4425c28e83SPiotr Jasiukajtis hy = ((int *)&y)[HIWORD]; 4525c28e83SPiotr Jasiukajtis k = (hx & ~0x80000000) | lx; 4625c28e83SPiotr Jasiukajtis 4725c28e83SPiotr Jasiukajtis if (x == y) 4825c28e83SPiotr Jasiukajtis return (y); /* C99 requirement */ 4925c28e83SPiotr Jasiukajtis if (x != x || y != y) 5025c28e83SPiotr Jasiukajtis return (x * y); 5125c28e83SPiotr Jasiukajtis if (k == 0) { /* x = 0 */ 5225c28e83SPiotr Jasiukajtis k = hy & 0x80000000; 5325c28e83SPiotr Jasiukajtis ((int *)&ans)[HIWORD] = k; 5425c28e83SPiotr Jasiukajtis ((int *)&ans)[LOWORD] = 1; 5525c28e83SPiotr Jasiukajtis } else if (hx >= 0) { 5625c28e83SPiotr Jasiukajtis if (x > y) { 5725c28e83SPiotr Jasiukajtis ((int *)&ans)[LOWORD] = lx - 1; 5825c28e83SPiotr Jasiukajtis k = (lx == 0)? hx - 1 : hx; 5925c28e83SPiotr Jasiukajtis ((int *)&ans)[HIWORD] = k; 6025c28e83SPiotr Jasiukajtis } else { 6125c28e83SPiotr Jasiukajtis ((int *)&ans)[LOWORD] = lx + 1; 6225c28e83SPiotr Jasiukajtis k = (lx == 0xffffffff)? hx + 1 : hx; 6325c28e83SPiotr Jasiukajtis ((int *)&ans)[HIWORD] = k; 6425c28e83SPiotr Jasiukajtis } 6525c28e83SPiotr Jasiukajtis } else { 6625c28e83SPiotr Jasiukajtis if (x < y) { 6725c28e83SPiotr Jasiukajtis ((int *)&ans)[LOWORD] = lx - 1; 6825c28e83SPiotr Jasiukajtis k = (lx == 0)? hx - 1 : hx; 6925c28e83SPiotr Jasiukajtis ((int *)&ans)[HIWORD] = k; 7025c28e83SPiotr Jasiukajtis } else { 7125c28e83SPiotr Jasiukajtis ((int *)&ans)[LOWORD] = lx + 1; 7225c28e83SPiotr Jasiukajtis k = (lx == 0xffffffff)? hx + 1 : hx; 7325c28e83SPiotr Jasiukajtis ((int *)&ans)[HIWORD] = k; 7425c28e83SPiotr Jasiukajtis } 7525c28e83SPiotr Jasiukajtis } 7625c28e83SPiotr Jasiukajtis k = (k >> 20) & 0x7ff; 7725c28e83SPiotr Jasiukajtis if (k == 0x7ff) { 7825c28e83SPiotr Jasiukajtis /* overflow */ 7925c28e83SPiotr Jasiukajtis return (_SVID_libm_err(x, y, 46)); 8025c28e83SPiotr Jasiukajtis #if !defined(__lint) 8125c28e83SPiotr Jasiukajtis } else if (k == 0) { 8225c28e83SPiotr Jasiukajtis /* underflow */ 8325c28e83SPiotr Jasiukajtis dummy = DBL_MIN * copysign(DBL_MIN, x); 8425c28e83SPiotr Jasiukajtis #endif 8525c28e83SPiotr Jasiukajtis } 8625c28e83SPiotr Jasiukajtis return (ans); 8725c28e83SPiotr Jasiukajtis } 88