~ubuntu-branches/ubuntu/utopic/eglibc/utopic

« back to all changes in this revision

Viewing changes to sysdeps/ieee754/ldbl-96/s_nexttowardf.c

  • Committer: Package Import Robot
  • Author(s): Adam Conrad
  • Date: 2012-10-26 05:14:58 UTC
  • mfrom: (1.5.1) (4.4.22 experimental)
  • Revision ID: package-import@ubuntu.com-20121026051458-oryotr4i03ob5pab
Tags: 2.16-0ubuntu1
* Merge with unreleased 2.16 in Debian experimental, remaining changes:
  - Drop the Breaks line from libc6, which refers to a Debian transition
  - Remove the libc6 recommends on libc6-i686, which we don't build
  - Enable libc6{,-dev}-armel on armhf and libc6{-dev}-armhf on armel
  - Ship update-locale and validlocale in /usr/sbin in libc-bin
  - Don't build locales or locales-all in Ubuntu, we rely on langpacks
  - Heavily mangle the way we do service restarting on major upgrades
  - Use different MIN_KERNEL_SUPPORTED versions than Debian, due to
    buildd needs.  This should be universally bumped to 3.2.0 once all
    our buildds (including the PPA guests) are running precise kernels
  - Build i386 variants as -march=i686, build amd64 with -O3, and build
    ppc64 variants (both 64-bit and 32-bit) with -O3 -fno-tree-vectorize
  - Re-enable unsubmitted-ldconfig-cache-abi.diff and rebuild the cache
    on upgrades from previous versions that used a different constant
  - debian/patches/any/local-CVE-2012-3406.diff: switch to malloc when
    array grows too large to handle via alloca extension (CVE-2012-3406)
  - Build generic i386/i686 flavour with -mno-tls-direct-seg-refs
* Changes added/dropped with this merge while reducing our delta:
  - Stop building glibc docs from the eglibc source, and instead make
    the glibc-docs stub have a hard dependency on glibc-doc-reference
  - Remove outdated conflicts against ancient versions of ia32-libs
  - Drop the tzdata dependency from libc6, it's in required and minimal
  - Use gcc-4.7/g++-4.7 by default on all our supported architectures
  - Save our historical changelog as changelog.ubuntu in the source
  - Drop nscd's libaudit build-dep for now, as libaudit is in universe
  - Drop the unnecessary Breaks from libc6 to locales and locales-all
  - Ship xen's ld.so.conf.d snippet as /etc/ld.so.conf.d/libc6-xen.conf
* Disable hard failures on the test suite for the first upload to raring

Show diffs side-by-side

added added

removed removed

Lines of Context:
17
17
static char rcsid[] = "$NetBSD: $";
18
18
#endif
19
19
 
20
 
#include "math.h"
 
20
#include <math.h>
21
21
#include <math_private.h>
22
22
#include <float.h>
23
23
 
24
 
#ifdef __STDC__
25
 
        float __nexttowardf(float x, long double y)
26
 
#else
27
 
        float __nexttowardf(x,y)
28
 
        float x;
29
 
        long double y;
30
 
#endif
 
24
float __nexttowardf(float x, long double y)
31
25
{
32
26
        int32_t hx,ix,iy;
33
27
        u_int32_t hy,ly,esy;
50
44
            return x;
51
45
        }
52
46
        if(hx>=0) {                             /* x > 0 */
53
 
            if(esy>=0x8000||((ix>>23)&0xff)>iy-0x3f80
54
 
               || (((ix>>23)&0xff)==iy-0x3f80
55
 
                   && ((ix&0x7fffff)<<8)>(hy&0x7fffffff))) {/* x > y, x -= ulp */
 
47
            if(x > y) {                         /* x -= ulp */
56
48
                hx -= 1;
57
49
            } else {                            /* x < y, x += ulp */
58
50
                hx += 1;
59
51
            }
60
52
        } else {                                /* x < 0 */
61
 
            if(esy<0x8000||((ix>>23)&0xff)>iy-0x3f80
62
 
               || (((ix>>23)&0xff)==iy-0x3f80
63
 
                   && ((ix&0x7fffff)<<8)>(hy&0x7fffffff))) {/* x < y, x -= ulp */
 
53
            if(x < y) {                         /* x -= ulp */
64
54
                hx -= 1;
65
55
            } else {                            /* x > y, x += ulp */
66
56
                hx += 1;