Fix parameter type in C++ version of iseqsig (bug 23171)

The commit

  commit c85e54ac6cef0faed7b7ffc722f52523dec59bf5
  Author: Gabriel F. T. Gomes <gabriel@inconstante.eti.br>
  Date:   Fri Nov 3 10:44:36 2017 -0200

      Provide a C++ version of iseqsig (bug 22377)

mistakenly used double parameters in the long double version of iseqsig,
thus causing spurious conversions to double, as reported on bug 23171.

Tested for powerpc64le and x86_64.

(cherry picked from commit fb0e10b8eb1ebb68c57d4551f7a95118f3c54837)
This commit is contained in:
Gabriel F. T. Gomes 2018-05-14 09:04:28 -03:00
parent 7b52c8ae05
commit 81b994bd83
3 changed files with 8 additions and 1 deletions

View File

@ -1,3 +1,9 @@
2018-05-24 Gabriel F. T. Gomes <gabriel@inconstante.eti.br>
[BZ #23171]
* math/math.h [C++] (iseqsig): Fix parameter type for the long
double version.
2018-06-01 Florian Weimer <fweimer@redhat.com>
[BZ #23236]

1
NEWS
View File

@ -139,6 +139,7 @@ The following bugs are resolved with this release:
[23024] getlogin_r: return early when linux sentinel value is set
[23037] resolv: Fully initialize struct mmsghdr in send_dg
[23137] s390: Fix blocking pthread_join
[23171] Fix parameter type in C++ version of iseqsig
[23196] __mempcpy_avx512_no_vzeroupper mishandles large copies
[23236] Harden function pointers in _IO_str_fields

View File

@ -880,7 +880,7 @@ template<> struct __iseqsig_type<double>
template<> struct __iseqsig_type<long double>
{
static int __call (double __x, double __y) throw ()
static int __call (long double __x, long double __y) throw ()
{
# ifndef __NO_LONG_DOUBLE_MATH
return __iseqsigl (__x, __y);