Bring in FreeBSD's msun code for our libm.
[dragonfly.git] / lib / libm / src / s_copysign.c
1 /* @(#)s_copysign.c 5.1 93/09/24 */
2 /* $FreeBSD: head/lib/msun/src/s_copysign.c 176451 2008-02-22 02:30:36Z das $ */
3 /*
4  * ====================================================
5  * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
6  *
7  * Developed at SunPro, a Sun Microsystems, Inc. business.
8  * Permission to use, copy, modify, and distribute this
9  * software is freely granted, provided that this notice
10  * is preserved.
11  * ====================================================
12  */
13
14 /*
15  * copysign(double x, double y)
16  * copysign(x,y) returns a value with the magnitude of x and
17  * with the sign bit of y.
18  */
19
20 #include "math.h"
21 #include "math_private.h"
22
23 double
24 copysign(double x, double y)
25 {
26         u_int32_t hx,hy;
27         GET_HIGH_WORD(hx,x);
28         GET_HIGH_WORD(hy,y);
29         SET_HIGH_WORD(x,(hx&0x7fffffff)|(hy&0x80000000));
30         return x;
31 }