~ubuntu-branches/ubuntu/precise/eglibc/precise

« back to all changes in this revision

Viewing changes to sysdeps/x86_64/fpu/multiarch/s_fma.c

  • Committer: Package Import Robot
  • Author(s): Matthias Klose
  • Date: 2011-10-04 17:48:26 UTC
  • mfrom: (216.1.23 oneiric)
  • Revision ID: package-import@ubuntu.com-20111004174826-2cyb9ewn3ucymlsx
Tags: 2.13-20ubuntu5
libc6-dev: Don't break the current {gnat,gcj}-4.4-base versons. LP: #853688.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* FMA version of fma.
2
 
   Copyright (C) 2009, 2010, 2011 Free Software Foundation, Inc.
3
 
   Contributed by Intel Corporation.
4
 
   This file is part of the GNU C Library.
5
 
 
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.
10
 
 
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.
15
 
 
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. */
20
 
 
21
 
#include <config.h>
22
 
#include <math.h>
23
 
#include <init-arch.h>
24
 
 
25
 
#ifdef HAVE_AVX_SUPPORT
26
 
 
27
 
extern double __fma_sse2 (double x, double y, double z) attribute_hidden;
28
 
 
29
 
 
30
 
static double
31
 
__fma_fma3 (double x, double y, double z)
32
 
{
33
 
  asm ("vfmadd213sd %3, %2, %0" : "=x" (x) : "0" (x), "x" (y), "xm" (z));
34
 
  return x;
35
 
}
36
 
 
37
 
 
38
 
# ifdef HAVE_FMA4_SUPPORT
39
 
static double
40
 
__fma_fma4 (double x, double y, double z)
41
 
{
42
 
  asm ("vfmaddsd %3, %2, %1, %0" : "=x" (x) : "x" (x), "xm" (y), "xm" (z));
43
 
  return x;
44
 
}
45
 
# else
46
 
#  undef HAS_FMA4
47
 
#  define HAS_FMA4 0
48
 
#  define __fma_fma4 ((void *) 0)
49
 
# endif
50
 
 
51
 
 
52
 
libm_ifunc (__fma, HAS_FMA
53
 
            ? __fma_fma3 : (HAS_FMA4 ? __fma_fma4 : __fma_sse2));
54
 
weak_alias (__fma, fma)
55
 
 
56
 
# define __fma __fma_sse2
57
 
#endif
58
 
 
59
 
#include <sysdeps/ieee754/dbl-64/s_fma.c>