elf: Consolidate machine-agnostic DTV definitions in <dl-dtv.h>
[glibc.git] / sysdeps / powerpc / fpu / s_fmin.S
blob4d7c3b4fbc5dfd21ac6a783e9db4a623ef1d0685
1 /* Floating-point minimum.  PowerPC version.
2    Copyright (C) 1997-2016 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, see
17    <http://www.gnu.org/licenses/>.  */
19 #include <sysdep.h>
21 ENTRY(__fmin)
22 /* double [f1] fmin (double [f1] x, double [f2] y); */
23         fcmpu   cr0,fp1,fp2
24         bgt     cr0,0f          /* if x > y, neither x nor y can be NaN... */
25         bnulr+  cr0
26 /* x and y are unordered, so one of x or y must be a NaN... */
27         fcmpu   cr1,fp2,fp2
28         bunlr   cr1
29 0:      fmr     fp1,fp2
30         blr
31 END(__fmin)
33 weak_alias (__fmin,fmin)
35 /* It turns out that it's safe to use this code even for single-precision.  */
36 strong_alias(__fmin,__fminf)
37 weak_alias (__fmin,fminf)
39 #ifdef NO_LONG_DOUBLE
40 weak_alias (__fmin,__fminl)
41 weak_alias (__fmin,fminl)
42 #endif