mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-24 12:25:35 +08:00
0d2163ebf2
powerpc-nofpu libc exports __sqrtsf2 and __sqrtdf2 symbols. The export of these soft-fp symbols is a mistake; they aren't part of the libgcc interface and GCC will never generate code that calls them. This patch makes them into compat symbols (no code built for static libc), moving their sources from the generic soft-fp sources to sysdeps/powerpc/nofpu (the underlying soft-fp FP_SQRT functionality remains of use to implement actual sqrt public interfaces, such as sqrtl / sqrtf128 for which it is used on various platforms, but __sqrt[sdt]f2 are not such interfaces). Tested with build-many-glibcs.py for relevant platforms. [BZ #18473] * soft-fp/sqrttf2.c: Remove file. * soft-fp/sqrtdf2.c: Move to .... * sysdeps/powerpc/nofpu/sqrtdf2.c: ... here. Include <shlib-compat.h>. (__sqrtdf2): Make conditional on [SHLIB_COMPAT (libc, GLIBC_2_3_2, GLIBC_2_28)]. Define as compat symbol. * soft-fp/sqrtsf2.c: Move to .... * sysdeps/powerpc/nofpu/sqrtsf2.c: ... here. Include <shlib-compat.h>. (__sqrtsf2): Make conditional on [SHLIB_COMPAT (libc, GLIBC_2_3_2, GLIBC_2_28)]. Define as compat symbol. * soft-fp/Makefile (gcc-single-routines): Remove sqrtsf2. (gcc-double-routines): Remove sqrtdf2. (gcc-quad-routines): Remove sqrttf2. * sysdeps/nios2/Makefile [$(subdir) = soft-fp] (sysdep_routines): Do not filter out sqrtsf2 and sqrtdf2. * sysdeps/powerpc/nofpu/Makefile [$(subdir) = soft-fp] (sysdep_routines): Add sqrtsf2 and sqrtdf2.
54 lines
2.2 KiB
Makefile
54 lines
2.2 KiB
Makefile
# Makefile fragment for PowerPC with no FPU.
|
|
|
|
ifeq ($(subdir),soft-fp)
|
|
sysdep_routines += $(gcc-single-routines) $(gcc-double-routines) \
|
|
sqrtsf2 sqrtdf2 \
|
|
sim-full atomic-feholdexcept atomic-feclearexcept \
|
|
atomic-feupdateenv flt-rounds
|
|
endif
|
|
|
|
ifeq ($(subdir),math)
|
|
libm-support += fenv_const
|
|
CPPFLAGS += -I../soft-fp/
|
|
# The follow CFLAGS are a work around for GCC Bugzilla Bug 29253
|
|
# "expand_abs wrong default code for floating point"
|
|
# As this is not a regression, a fix is not likely to go into
|
|
# gcc-4.1.1 and may be too late for gcc-4.2. So we need these flags
|
|
# until the fix in a gcc release and glibc drops support for earlier
|
|
# versions of gcc.
|
|
#
|
|
# This bug can cause wrong signs of zero results from fabsl, and
|
|
# spurious "invalid" exceptions from comparisons with NaN in the
|
|
# default code sequence generated. The fpclassify expansion used by
|
|
# __builtin_fpclassify, which is used in the absence of
|
|
# -fsignaling-nans, uses __builtin_fabsl, and is not affected by
|
|
# -fno-builtin-fabsl, so requiring -fsignaling-nans for some affected
|
|
# source files.
|
|
CFLAGS-e_atan2l.c += -fno-builtin-fabsl
|
|
CFLAGS-e_hypotl.c += -fno-builtin-fabsl
|
|
CFLAGS-e_powl.c += -fno-builtin-fabsl
|
|
CFLAGS-s_cacosl.c += -fsignaling-nans
|
|
CFLAGS-s_cacoshl.c += -fsignaling-nans
|
|
CFLAGS-s_casinhl.c += -fsignaling-nans
|
|
CFLAGS-s_catanl.c += -fsignaling-nans
|
|
CFLAGS-s_catanhl.c += -fsignaling-nans
|
|
CFLAGS-s_ccoshl.c += -fno-builtin-fabsl -fsignaling-nans
|
|
CFLAGS-s_cexpl.c += -fsignaling-nans
|
|
CFLAGS-s_csinhl.c += -fno-builtin-fabsl -fsignaling-nans
|
|
CFLAGS-s_clogl.c += -fno-builtin-fabsl -fsignaling-nans
|
|
CFLAGS-s_clog10l.c += -fno-builtin-fabsl -fsignaling-nans
|
|
CFLAGS-s_csinl.c += -fno-builtin-fabsl -fsignaling-nans
|
|
CFLAGS-s_csqrtl.c += -fno-builtin-fabsl -fsignaling-nans
|
|
CFLAGS-w_acosl_compat.c += -fno-builtin-fabsl
|
|
CFLAGS-w_asinl_compat.c += -fno-builtin-fabsl
|
|
CFLAGS-w_atanhl_compat.c += -fno-builtin-fabsl
|
|
CFLAGS-w_j0l_compat.c += -fno-builtin-fabsl
|
|
CFLAGS-w_j1l_compat.c += -fno-builtin-fabsl
|
|
CFLAGS-e_lgammal_r.c += -fno-builtin-fabsl
|
|
CFLAGS-e_log10l.c += -fno-builtin-fabsl
|
|
CFLAGS-e_log2l.c += -fno-builtin-fabsl
|
|
CFLAGS-e_remainderl.c += -fno-builtin-fabsl
|
|
CFLAGS-s_fmaxmagl.c += -fno-builtin-fabsl
|
|
CFLAGS-s_fminmagl.c += -fno-builtin-fabsl
|
|
endif
|