.
[glibc.git] / sysdeps / x86_64 / fpu / s_copysign.S
blobf1ebcf8bf19ab646dede1bdb54b1a6418fde2e1c
1 /* copy sign, double version.
2    Copyright (C) 2002 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4    Contributed by Andreas Jaeger <aj@suse.de>, 2002.
6    The GNU C Library is free software; you can redistribute it and/or
7    modify it under the terms of the GNU Lesser General Public
8    License as published by the Free Software Foundation; either
9    version 2.1 of the License, or (at your option) any later version.
11    The GNU C Library is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14    Lesser General Public License for more details.
16    You should have received a copy of the GNU Lesser General Public
17    License along with the GNU C Library; if not, write to the Free
18    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
19    02111-1307 USA.  */
21 #include <machine/asm.h>
23 #ifdef __ELF__
24         .section .rodata
25 #else
26         .text
27 #endif
29         .align ALIGNARG(4)
30         ASM_TYPE_DIRECTIVE(signmask,@object)
31 signmask:
32         .byte 0, 0, 0, 0, 0, 0, 0, 0x80
33         .byte 0, 0, 0, 0, 0, 0, 0, 0
34 othermask:
35         .byte 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x7f
36         .byte 0, 0, 0, 0, 0, 0, 0, 0
37         ASM_SIZE_DIRECTIVE(othermask)
39 #ifdef PIC
40 #define MO(op) op##(%rip)
41 #else
42 #define MO(op) op
43 #endif
45 ENTRY(__copysign)
46         andpd MO(othermask),%xmm0
47         andpd MO(signmask),%xmm1
48         orpd %xmm1,%xmm0
49         ret
50 END (__copysign)
52 weak_alias (__copysign, copysign)