diff options
Diffstat (limited to 'sysdeps/ieee754/ldbl-opt/Makefile')
-rw-r--r-- | sysdeps/ieee754/ldbl-opt/Makefile | 69 |
1 files changed, 64 insertions, 5 deletions
diff --git a/sysdeps/ieee754/ldbl-opt/Makefile b/sysdeps/ieee754/ldbl-opt/Makefile index 474f68a..ef7da1f 100644 --- a/sysdeps/ieee754/ldbl-opt/Makefile +++ b/sysdeps/ieee754/ldbl-opt/Makefile @@ -42,6 +42,7 @@ libnldbl-calls = \ cimag \ clog \ clog10 \ + compoundn \ conj \ copysign \ cos \ @@ -166,6 +167,7 @@ libnldbl-calls = \ obstack_vprintf \ obstack_vprintf_chk \ pow \ + pown \ powr \ printf \ printf_chk \ @@ -179,6 +181,7 @@ libnldbl-calls = \ remainder \ remquo \ rint \ + rootn \ round \ roundeven \ rsqrt \ @@ -263,7 +266,7 @@ extra-objs += $(addsuffix .oS, $(libnldbl-routines)) CFLAGS-nldbl-acos.c = -fno-builtin-acosl CFLAGS-nldbl-acosh.c = -fno-builtin-acoshl -CFLAGS-nldbl-acospi.c = -fno-builtin-acospi +CFLAGS-nldbl-acospi.c = -fno-builtin-acospil CFLAGS-nldbl-asin.c = -fno-builtin-asinl CFLAGS-nldbl-asinh.c = -fno-builtin-asinhl CFLAGS-nldbl-asinpi.c = -fno-builtin-asinpil @@ -289,11 +292,12 @@ CFLAGS-nldbl-cexp.c = -fno-builtin-cexpl CFLAGS-nldbl-cimag.c = -fno-builtin-cimagl CFLAGS-nldbl-clog.c = -fno-builtin-clogl CFLAGS-nldbl-clog10.c = -fno-builtin-clog10l +CFLAGS-nldbl-compoundn.c = -fno-builtin-compoundnl CFLAGS-nldbl-conj.c = -fno-builtin-conjl CFLAGS-nldbl-copysign.c = -fno-builtin-copysignl CFLAGS-nldbl-cos.c = -fno-builtin-cosl CFLAGS-nldbl-cosh.c = -fno-builtin-coshl -CFLAGS-nldbl-cospi.c = -fno-builtin-cospi +CFLAGS-nldbl-cospi.c = -fno-builtin-cospil CFLAGS-nldbl-cpow.c = -fno-builtin-cpowl CFLAGS-nldbl-cproj.c = -fno-builtin-cprojl CFLAGS-nldbl-creal.c = -fno-builtin-creall @@ -376,10 +380,12 @@ CFLAGS-nldbl-nexttoward.c = -fno-builtin-nexttoward -fno-builtin-nexttowardl CFLAGS-nldbl-nexttowardf.c = -fno-builtin-nexttowardf CFLAGS-nldbl-nextup.c = -fno-builtin-nextupl CFLAGS-nldbl-pow.c = -fno-builtin-powl +CFLAGS-nldbl-pown.c = -fno-builtin-pownl CFLAGS-nldbl-powr.c = -fno-builtin-powrl CFLAGS-nldbl-remainder.c = -fno-builtin-remainderl -fno-builtin-dreml CFLAGS-nldbl-remquo.c = -fno-builtin-remquol CFLAGS-nldbl-rint.c = -fno-builtin-rintl +CFLAGS-nldbl-rootn.c = -fno-builtin-rootnl CFLAGS-nldbl-round.c = -fno-builtin-roundl CFLAGS-nldbl-roundeven.c = -fno-builtin-roundevenl CFLAGS-nldbl-rsqrt.c = -fno-builtin-rsqrtl @@ -392,11 +398,11 @@ CFLAGS-nldbl-significand.c = -fno-builtin-significandl CFLAGS-nldbl-sin.c = -fno-builtin-sinl CFLAGS-nldbl-sincos.c = -fno-builtin-sincosl CFLAGS-nldbl-sinh.c = -fno-builtin-sinhl -CFLAGS-nldbl-sinpi.c = -fno-builtin-sinpi +CFLAGS-nldbl-sinpi.c = -fno-builtin-sinpil CFLAGS-nldbl-sqrt.c = -fno-builtin-sqrtl CFLAGS-nldbl-tan.c = -fno-builtin-tanl CFLAGS-nldbl-tanh.c = -fno-builtin-tanhl -CFLAGS-nldbl-tanpi.c = -fno-builtin-tanpi +CFLAGS-nldbl-tanpi.c = -fno-builtin-tanpil CFLAGS-nldbl-tgamma.c = -fno-builtin-tgammal CFLAGS-nldbl-totalorder.c = -fno-builtin-totalorderl CFLAGS-nldbl-totalordermag.c = -fno-builtin-totalordermagl @@ -451,6 +457,59 @@ CFLAGS-tst-nldbl-errorfptr.c += -mlong-double-64 endif ifeq ($(subdir), stdio-common) +# We already have the long double conversion defined with our common rules +# for the IEEE binary128 format, so define these special rules to build +# and run extra executables for the IEEE binary64 format, reusing the same +# sources. +define tst-scanf-format-64-tests +test-srcs += \ + tst-scanf-format-$(1)-ldouble-64 \ + # test-srcs + +$$(objpfx)tst-scanf-format-$(1)-ldouble-64.o: \ + tst-scanf-format-$(1)-ldouble.c $$(before-compile) + $$(compile-command.c) +$$(objpfx)tst-scanf-format-$(1)-ldouble-64: $$(libm) +endef +$(foreach p,$(xscanf-funcs), \ + $(eval $(call tst-scanf-format-64-tests,$(p)))) + +# Use the IEEE binary64 format for long double scanf format tests. +$(foreach suf,$(all-object-suffixes), \ + $(foreach p,$(xscanf-funcs), \ + $(objpfx)tst-scanf-format-$(p)-ldouble-64$(suf))): \ + sysdep-CFLAGS += -mlong-double-64 + +ifeq ($(run-built-tests),yes) +define tst-scanf-format-64-rule +tests-special += \ + $$(objpfx)tst-scanf-format-$(1)-ldouble-64-$(2).out \ + # tests-special + +$$(objpfx)tst-scanf-format-$(1)-ldouble-64-$(2).out: \ + ../sysdeps/ieee754/ldbl-opt/tst-scanf-format-ldouble-$(2).input \ + $$(objpfx)tst-scanf-format-$(1)-ldouble-64 + $$(make-tst-scanf-format-out) > $$@ < $$<; \ + $$(evaluate-test) + +ifeq (yes,$(build-shared)) +ifneq ($(PERL),no) +tests-special += \ + $$(objpfx)tst-scanf-format-$(1)-ldouble-64-$(2)-mem.out \ + # tests-special + +generated += \ + $$(objpfx)tst-scanf-format-$(1)-ldouble-64-$(2)-mem.out \ + $$(objpfx)tst-scanf-format-$(1)-ldouble-64-$(2).mtrace \ + # generated +endif +endif +endef +$(foreach f,$(fmts-xscanf-real), \ + $(foreach p,$(xscanf-funcs), \ + $(eval $(call tst-scanf-format-64-rule,$(p),$(f))))) +endif # $(run-built-tests) == yes + tests += \ tst-nldbl-scanf-binary-c11 \ tst-nldbl-scanf-binary-c23 \ @@ -471,7 +530,7 @@ CFLAGS-tst-nldbl-scanf-binary-gnu11.c += -mlong-double-64 -std=gnu11 \ CFLAGS-tst-nldbl-scanf-binary-gnu89.c += -mlong-double-64 -std=gnu89 \ -DOBJPFX=\"$(objpfx)\" -endif +endif # $(subdir) == stdio-common ifeq ($(subdir), wcsmbs) tests += \ |