xref: /aosp_15_r20/external/fdlibm/s_copysign.c (revision 1e651e1ef2b613db2c4b29ae59c1de74cf0222ae)
1*1e651e1eSRoland Levillain 
2*1e651e1eSRoland Levillain /* @(#)s_copysign.c 1.3 95/01/18 */
3*1e651e1eSRoland Levillain /*
4*1e651e1eSRoland Levillain  * ====================================================
5*1e651e1eSRoland Levillain  * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
6*1e651e1eSRoland Levillain  *
7*1e651e1eSRoland Levillain  * Developed at SunSoft, a Sun Microsystems, Inc. business.
8*1e651e1eSRoland Levillain  * Permission to use, copy, modify, and distribute this
9*1e651e1eSRoland Levillain  * software is freely granted, provided that this notice
10*1e651e1eSRoland Levillain  * is preserved.
11*1e651e1eSRoland Levillain  * ====================================================
12*1e651e1eSRoland Levillain  */
13*1e651e1eSRoland Levillain 
14*1e651e1eSRoland Levillain /*
15*1e651e1eSRoland Levillain  * ieee_copysign(double x, double y)
16*1e651e1eSRoland Levillain  * ieee_copysign(x,y) returns a value with the magnitude of x and
17*1e651e1eSRoland Levillain  * with the sign bit of y.
18*1e651e1eSRoland Levillain  */
19*1e651e1eSRoland Levillain 
20*1e651e1eSRoland Levillain #include "fdlibm.h"
21*1e651e1eSRoland Levillain 
22*1e651e1eSRoland Levillain #ifdef __STDC__
ieee_copysign(double x,double y)23*1e651e1eSRoland Levillain 	double ieee_copysign(double x, double y)
24*1e651e1eSRoland Levillain #else
25*1e651e1eSRoland Levillain 	double ieee_copysign(x,y)
26*1e651e1eSRoland Levillain 	double x,y;
27*1e651e1eSRoland Levillain #endif
28*1e651e1eSRoland Levillain {
29*1e651e1eSRoland Levillain 	__HI(x) = (__HI(x)&0x7fffffff)|(__HI(y)&0x80000000);
30*1e651e1eSRoland Levillain         return x;
31*1e651e1eSRoland Levillain }
32