about summary refs log tree commit diff
path: root/sysdeps/ieee754
diff options
context:
space:
mode:
authorJoseph Myers <joseph@codesourcery.com>2015-09-15 17:24:23 +0000
committerJoseph Myers <joseph@codesourcery.com>2015-09-15 17:24:23 +0000
commit694aabefd2eb3a0e2c5624d7feb1d7310b2bdd8b (patch)
treee53ee8681fc6863277423922a1832087a23c456d /sysdeps/ieee754
parent828bf6828b048b1482e95f84ca92e5fe0edcdc0c (diff)
downloadglibc-694aabefd2eb3a0e2c5624d7feb1d7310b2bdd8b.tar.gz
glibc-694aabefd2eb3a0e2c5624d7feb1d7310b2bdd8b.tar.xz
glibc-694aabefd2eb3a0e2c5624d7feb1d7310b2bdd8b.zip
Simplify hypotf infinity handling (bug 15918).
Bug 15918 points out that the handling of infinities in hypotf can be
simplified: it's enough to return the absolute value of the infinite
argument without first comparing it to the other argument and possibly
returning that other argument's absolute value.  This patch makes that
cleanup (which should not change how hypotf behaves on any input).

Tested for x86_64.

	[BZ #15918]
	* sysdeps/ieee754/flt-32/e_hypotf.c (__ieee754_hypotf): Simplify
	handling of cases where one argument is an infinity.
Diffstat (limited to 'sysdeps/ieee754')
-rw-r--r--sysdeps/ieee754/flt-32/e_hypotf.c12
1 files changed, 2 insertions, 10 deletions
diff --git a/sysdeps/ieee754/flt-32/e_hypotf.c b/sysdeps/ieee754/flt-32/e_hypotf.c
index 8f499b5fde..717b82e42f 100644
--- a/sysdeps/ieee754/flt-32/e_hypotf.c
+++ b/sysdeps/ieee754/flt-32/e_hypotf.c
@@ -27,17 +27,9 @@ __ieee754_hypotf(float x, float y)
 	GET_FLOAT_WORD(hb,y);
 	hb &= 0x7fffffff;
 	if (ha == 0x7f800000)
-	  {
-	    if (x == y)
-	      return fabsf(y);
-	    return fabsf(x);
-	  }
+	  return fabsf(x);
 	else if (hb == 0x7f800000)
-	  {
-	    if (x == y)
-	      return fabsf(x);
-	    return fabsf(y);
-	  }
+	  return fabsf(y);
 	else if (ha > 0x7f800000 || hb > 0x7f800000)
 	  return fabsf(x) * fabsf(y);
 	else if (ha == 0)