summaryrefslogtreecommitdiff
path: root/lang
diff options
context:
space:
mode:
authormarino <marino@pkgsrc.org>2012-07-14 21:53:05 +0000
committermarino <marino@pkgsrc.org>2012-07-14 21:53:05 +0000
commit585e77178dc419e6fcdef45fa43a9b8acead0267 (patch)
tree8f7ff53d213ee982aad3c8ea44d4185de8af5489 /lang
parent2cd7318dbf2054c2f5b5935e1451891bad24f8e1 (diff)
downloadpkgsrc-585e77178dc419e6fcdef45fa43a9b8acead0267.tar.gz
lang/gcc-aux: Fix c/c++ precision on FreeBSD/DragonFly
Until now, GCC builders had to choose between Ada and C/C++ on the following platforms: i386-FreeBSD i386-DragonFly On these platforms, depending on the value of the configuration macro TARGET_96_ROUND_53_LONG_DOUBLE, either Ada precision or C/C++ long double precision was broken. The reason is that the floating point unit of these platforms round off real-time calculations to 53-bit mantissas. GCC will adjust accordingly to compensate. Since a common backend is used for all languages, one had to choice which language they wanted correct. The solution is to break out the object file responsible for this from the common backend library. Ada now receives an altered version of insn-modes.o, one that instructs the FPU not to round off the results. This is all handled by patched Makefiles. Other changes: - Configure DragonFly to add ".note.GNU-stack" section to assembly files to determine if program needs executable stacks - Skip 2 subtests of Wconversion-real on i386 FreeBSD and DragonFly. Due to the rounding behavior mentioned above, they fail to produce error messages as expected. It's not possible to set target with xfail, and every target && target seems not work work. So we will assume all gcc-aux platform targets are long-double capabile and just set xfail for x86 FreeBSD and DragonFly. - Rework Fortran large real test 2 to skip on x86_64 *BSD. This test should pass on x86 machines. - Rework Fortran large real test 3 to be skipped when compiles with -O0 only x86_64 machines. All other combinations will pass. - Rename C format test typedef from quad_t to quad2_t. DragonFly has a standard type called quad_t and the type conflict causes a large number of gcc tests to fail. - Add dummy dg-error line to avoid an assembly comparison tests on large files not built (test was marked as UNSUPPORTED but dejagnu is too dumb to know not to check for the tests' products.) - Reorder path passed during build when using an already-built gcc-aux compiler to build new compiler. If gnat-aux is also installed, it would use the gnat* tools from that compiler rather than gcc-aux which results in build failure (different versions of tools are getting used together resulting in build failure).
Diffstat (limited to 'lang')
-rw-r--r--lang/gcc-aux/Makefile5
-rw-r--r--lang/gcc-aux/files/diff-ada11
-rw-r--r--lang/gcc-aux/files/diff-core98
-rw-r--r--lang/gcc-aux/files/diff-cxx-testsuite26
-rw-r--r--lang/gcc-aux/files/diff-fortran-testsuite4
-rw-r--r--lang/gcc-aux/files/diff-gcc-testsuite38
6 files changed, 152 insertions, 30 deletions
diff --git a/lang/gcc-aux/Makefile b/lang/gcc-aux/Makefile
index c06d744abed..ae494ff31c8 100644
--- a/lang/gcc-aux/Makefile
+++ b/lang/gcc-aux/Makefile
@@ -1,8 +1,9 @@
-# $NetBSD: Makefile,v 1.1 2012/07/08 19:30:38 marino Exp $
+# $NetBSD: Makefile,v 1.2 2012/07/14 21:53:05 marino Exp $
#
PKGNAME= gcc-aux-${SNAPSHOT}
DISTNAME= gcc-${GCC_VERSION}
+PKGREVISION= 1
CATEGORIES= lang
MASTER_SITES= ${MASTER_SITE_GNU:=gcc/gcc-${GCC_VERSION}/}
DISTFILES= ${DISTNAME}.tar.bz2
@@ -44,7 +45,7 @@ BOOTSTRAP_COMPILER= NOT_REQUIRED
INTENDED_COMPILER= NATIVE
BOOTSTRAP_TRIPLET= NOT SET
FULL_GNATGCC= NOT SET
-FULL_PATH= /sbin:/bin:/usr/sbin:/usr/bin:${PREFIX}/sbin:${PREFIX}/bin:${PREFIX}/gcc-aux/bin
+FULL_PATH= /sbin:/bin:/usr/sbin:/usr/bin:${PREFIX}/gcc-aux/bin:${PREFIX}/sbin:${PREFIX}/bin
OLD_EH= register_frame
REBUILD_LIB= Rebuild the following library first:
STICONV= ${PREFIX}/lib/libiconv.a
diff --git a/lang/gcc-aux/files/diff-ada b/lang/gcc-aux/files/diff-ada
index c17a55e7cdf..cc2bdea0ca8 100644
--- a/lang/gcc-aux/files/diff-ada
+++ b/lang/gcc-aux/files/diff-ada
@@ -9355,3 +9355,14 @@
mips-sgi-irix*)
TOOLS_TARGET_PAIRS="mlib-tgt-specific.adb<mlib-tgt-specific-irix.adb"
;;
+--- gcc/ada/gcc-interface/Make-lang.in.orig
++++ gcc/ada/gcc-interface/Make-lang.in
+@@ -541,7 +541,7 @@
+ ada/widechar.o
+
+ # Language-independent object files.
+-ADA_BACKEND = $(BACKEND) attribs.o
++ADA_BACKEND = $(BACKEND2) attribs.o
+
+ # List of target dependent sources, overridden below as necessary
+ TARGET_ADA_SRCS =
diff --git a/lang/gcc-aux/files/diff-core b/lang/gcc-aux/files/diff-core
index b9a97a809e1..6040d6cb1a0 100644
--- a/lang/gcc-aux/files/diff-core
+++ b/lang/gcc-aux/files/diff-core
@@ -462,9 +462,10 @@
+#define UINTPTR_TYPE (LONG_TYPE_SIZE == 64 ? "long unsigned int" : "unsigned int")
--- /dev/null
+++ gcc/config/i386/dragonfly.h
-@@ -0,0 +1,101 @@
+@@ -0,0 +1,105 @@
+/* Definitions for Intel 386 running DragonFly with ELF format
-+ Copyright (C) 1996, 2000, 2002, 2004, 2007 Free Software Foundation, Inc.
++ Copyright (C) 1996, 2000, 2002, 2004, 2007, 2010, 2011
++ Free Software Foundation, Inc.
+ Contributed by Eric Youngdale.
+ Modified for stabs-in-ELF by H.J. Lu.
+ Adapted from GNU/Linux version by John Polstra.
@@ -548,10 +549,10 @@
+#undef DEFAULT_PCC_STRUCT_RETURN
+#define DEFAULT_PCC_STRUCT_RETURN 0
+
-+/* DragonFly sets the rounding precision of the FPU to 53 bits, but GNAT
-+ resets it to full precision. */
++/* DragonFly sets the rounding precision of the FPU to 53 bits. Let the
++ compiler get the contents of <float.h> and std::numeric_limits correct. */
+#undef TARGET_96_ROUND_53_LONG_DOUBLE
-+#define TARGET_96_ROUND_53_LONG_DOUBLE 0
++#define TARGET_96_ROUND_53_LONG_DOUBLE (!TARGET_64BIT)
+
+/* Put all *tf routines in libgcc. */
+#undef LIBGCC2_HAS_TF_MODE
@@ -564,23 +565,12 @@
+
+/* Support for i386 has been removed from DragonFly for several releases */
+#define SUBTARGET32_DEFAULT_CPU "i486"
++
++#define TARGET_ASM_FILE_END file_end_indicate_exec_stack
++
--- gcc/config/i386/freebsd.h.orig
+++ gcc/config/i386/freebsd.h
-@@ -127,10 +127,10 @@
- #undef DEFAULT_PCC_STRUCT_RETURN
- #define DEFAULT_PCC_STRUCT_RETURN 0
-
--/* FreeBSD sets the rounding precision of the FPU to 53 bits. Let the
-- compiler get the contents of <float.h> and std::numeric_limits correct. */
-+/* FreeBSD sets the rounding precision of the FPU to 53 bits, but GNAT
-+ resets it to full precision. */
- #undef TARGET_96_ROUND_53_LONG_DOUBLE
--#define TARGET_96_ROUND_53_LONG_DOUBLE (!TARGET_64BIT)
-+#define TARGET_96_ROUND_53_LONG_DOUBLE 0
-
- /* Put all *tf routines in libgcc. */
- #undef LIBGCC2_HAS_TF_MODE
-@@ -148,3 +148,35 @@
+@@ -148,3 +148,34 @@
#define TARGET_ASM_FILE_END file_end_indicate_exec_stack
@@ -615,7 +605,6 @@
+ (void) mprotect (page, ends - page, perms); \
+}
+
-+
--- gcc/config/i386/netbsd-elf.h.orig
+++ gcc/config/i386/netbsd-elf.h
@@ -119,3 +119,9 @@
@@ -1433,7 +1422,66 @@
if test x$gcc_cv_target_dl_iterate_phdr = xyes; then
--- gcc/Makefile.in.orig
+++ gcc/Makefile.in
-@@ -4378,7 +4378,7 @@
+@@ -1150,7 +1150,6 @@
+ insn-automata.o \
+ insn-emit.o \
+ insn-extract.o \
+- insn-modes.o \
+ insn-opinit.o \
+ insn-output.o \
+ insn-peep.o \
+@@ -1469,13 +1468,18 @@
+ ALL_HOST_BACKEND_OBJS = $(GCC_OBJS) $(OBJS) $(OBJS-libcommon) \
+ $(OBJS-libcommon-target) @TREEBROWSER@ main.o gccspec.o cppspec.o \
+ $(COLLECT2_OBJS) $(EXTRA_GCC_OBJS) mips-tfile.o mips-tdump.o \
+- $(GCOV_OBJS) $(GCOV_DUMP_OBJS)
++ $(GCOV_OBJS) $(GCOV_DUMP_OBJS) insn-modes.o insn-modes-ada.o
+
+ # This lists all host object files, whether they are included in this
+ # compilation or not.
+ ALL_HOST_OBJS = $(ALL_HOST_FRONTEND_OBJS) $(ALL_HOST_BACKEND_OBJS)
+
+-BACKEND = main.o @TREEBROWSER@ libbackend.a libcommon-target.a libcommon.a \
++BACKEND = main.o @TREEBROWSER@ insn-modes.o libbackend.a \
++ libcommon-target.a libcommon.a \
++ $(CPPLIB) $(LIBDECNUMBER)
++
++BACKEND2 = main.o @TREEBROWSER@ insn-modes-ada.o libbackend.a \
++ libcommon-target.a libcommon.a \
+ $(CPPLIB) $(LIBDECNUMBER)
+
+ MOSTLYCLEANFILES = insn-flags.h insn-config.h insn-codes.h \
+@@ -3506,6 +3510,8 @@
+ $(TM_H) $(RTL_H) $(DIAGNOSTIC_CORE_H) insn-config.h $(RECOG_H)
+ insn-modes.o : insn-modes.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
+ $(MACHMODE_H)
++insn-modes-ada.o : insn-modes-ada.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
++ $(TM_H) $(MACHMODE_H)
+ insn-opinit.o : insn-opinit.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
+ $(TM_H) $(RTL_H) $(TM_P_H) insn-config.h $(FLAGS_H) $(RECOG_H) \
+ $(EXPR_H) $(OPTABS_H) reload.h
+@@ -3599,6 +3605,7 @@
+
+ insn-modes.c: s-modes; @true
+ insn-modes.h: s-modes-h; @true
++insn-modes-ada.c: s-modes-ada; @true
+ min-insn-modes.c: s-modes-m; @true
+
+ s-modes: build/genmodes$(build_exeext)
+@@ -3616,6 +3623,12 @@
+ $(SHELL) $(srcdir)/../move-if-change tmp-min-modes.c min-insn-modes.c
+ $(STAMP) s-modes-m
+
++s-modes-ada: s-modes
++ $(shell sed -e 's/: TARGET_96_ROUND_53_LONG_DOUBLE \? &ieee_extended_intel_96_round_53_format //' \
++ < insn-modes.c > tmp-modes-ada.c)
++ $(SHELL) $(srcdir)/../move-if-change tmp-modes-ada.c insn-modes-ada.c
++ $(STAMP) s-modes-ada
++
+ insn-preds.c: s-preds; @true
+ tm-preds.h: s-preds-h; @true
+ tm-constrs.h: s-constrs-h; @true
+@@ -4378,7 +4391,7 @@
DESTDIR=$(@D) \
$(SHELL) $(srcdir)/doc/install.texi2html
@@ -1442,7 +1490,7 @@
generated-manpages: man
-@@ -4530,7 +4530,7 @@
+@@ -4530,7 +4543,7 @@
# Install the driver last so that the window when things are
# broken is small.
install: install-common $(INSTALL_HEADERS) \
@@ -1451,7 +1499,7 @@
install-driver install-lto-wrapper install-gcc-ar
ifeq ($(enable_plugin),yes)
-@@ -4655,6 +4655,9 @@
+@@ -4655,6 +4668,9 @@
-rm -f $(DESTDIR)$(bindir)/$(target_noncanonical)-gcc-$(version)$(exeext)
-( cd $(DESTDIR)$(bindir) && \
$(LN) $(GCC_INSTALL_NAME)$(exeext) $(target_noncanonical)-gcc-$(version)$(exeext) )
@@ -1461,7 +1509,7 @@
-if [ -f gcc-cross$(exeext) ] ; then \
if [ -d $(DESTDIR)$(gcc_tooldir)/bin/. ] ; then \
rm -f $(DESTDIR)$(gcc_tooldir)/bin/gcc$(exeext); \
-@@ -4728,10 +4731,7 @@
+@@ -4728,10 +4744,7 @@
install-man: lang.install-man \
$(DESTDIR)$(man1dir)/$(GCC_INSTALL_NAME)$(man1ext) \
$(DESTDIR)$(man1dir)/$(CPP_INSTALL_NAME)$(man1ext) \
diff --git a/lang/gcc-aux/files/diff-cxx-testsuite b/lang/gcc-aux/files/diff-cxx-testsuite
index f1009504079..fb1ee2a247b 100644
--- a/lang/gcc-aux/files/diff-cxx-testsuite
+++ b/lang/gcc-aux/files/diff-cxx-testsuite
@@ -1,3 +1,29 @@
+--- gcc/testsuite/c-c++-common/Wconversion-real.c.orig
++++ gcc/testsuite/c-c++-common/Wconversion-real.c
+@@ -5,6 +5,12 @@
+ /* { dg-options "-std=c99 -Wconversion" { target c } } */
+ /* { dg-options "-Wconversion" { target c++ } } */
+ /* { dg-require-effective-target large_double } */
++/* Due to i386 rounding of long doubles on FreeBSD and DragonFly, the tests
++ should be set to "xfail" for those platforms, but it's not possible to
++ set both "target" and "xfail" together. An attempt to mark it
++ UNSUPPORTED for large_long_double and not (i386 FreeBSD i386 DragonFly)
++ failed. All the supported platforms of gcc-aux have large long double
++ so we'll just assume it for these two tests and use xfail instead. */
+
+ float vfloat;
+ double vdouble;
+@@ -24,8 +30,8 @@
+ vfloat = 3.1; /* { dg-warning "conversion" } */
+ ffloat (3.1L); /* { dg-warning "conversion" } */
+ vfloat = 3.1L; /* { dg-warning "conversion" } */
+- fdouble (3.1L); /* { dg-warning "conversion" "" { target large_long_double } } */
+- vdouble = 3.1L; /* { dg-warning "conversion" "" { target large_long_double } } */
++ fdouble (3.1L); /* { dg-warning "conversion" "" { xfail { i?86-*-freebsd* i?86-*-dragonfly* } } } */
++ vdouble = 3.1L; /* { dg-warning "conversion" "" { xfail { i?86-*-freebsd* i?86-*-dragonfly* } } } */
+ ffloat (vdouble); /* { dg-warning "conversion" } */
+ vfloat = vdouble; /* { dg-warning "conversion" } */
+ ffloat (vlongdouble); /* { dg-warning "conversion" } */
--- gcc/testsuite/g++.dg/cdce3.C.orig
+++ gcc/testsuite/g++.dg/cdce3.C
@@ -1,4 +1,4 @@
diff --git a/lang/gcc-aux/files/diff-fortran-testsuite b/lang/gcc-aux/files/diff-fortran-testsuite
index af58f3abe20..789a9a2d468 100644
--- a/lang/gcc-aux/files/diff-fortran-testsuite
+++ b/lang/gcc-aux/files/diff-fortran-testsuite
@@ -4,7 +4,7 @@
! { dg-do run }
! { dg-require-effective-target fortran_large_real }
-! { dg-xfail-if "" { "*-*-freebsd*" } { "*" } { "" } }
-+! { dg-xfail-if "" { "*-*-freebsd*" *-*-dragonfly* *-*-netbsd* } { "*" } { "" } }
++! { dg-skip-if "Requires cpowl,coshl,sinhl,tanhl,acoshl,asinhl,atanhl,expl,logl,ccosl,csinl,cexpl,clogl" { "x86_64-*-freebsd* x86_64-*-dragonfly* x86_64-*-netbsd*" } { "*" } { "" } }
! Testing library calls on large real kinds (larger than kind=8)
implicit none
@@ -14,7 +14,7 @@
! { dg-do run }
! { dg-require-effective-target fortran_large_real }
-! { dg-xfail-if "" { "*-*-freebsd*" } { "*" } { "" } }
-+! { dg-xfail-if "" { "*-*-freebsd*" *-*-dragonfly* *-*-netbsd* } { "*" } { "" } }
++! { dg-skip-if "Requires erfl,erfcl with -O0" { "x86_64-*-freebsd* x86_64-*-dragonfly* x86_64-*-netbsd*" } { "-O0" } { "" } }
! Testing erf and erfc library calls on large real kinds (larger than kind=8)
implicit none
diff --git a/lang/gcc-aux/files/diff-gcc-testsuite b/lang/gcc-aux/files/diff-gcc-testsuite
index f371a02cd1c..f313ca030d1 100644
--- a/lang/gcc-aux/files/diff-gcc-testsuite
+++ b/lang/gcc-aux/files/diff-gcc-testsuite
@@ -1,10 +1,46 @@
--- gcc/testsuite/gcc.dg/pch/pch.exp.orig
+++ gcc/testsuite/gcc.dg/pch/pch.exp
-@@ -44,6 +44,7 @@
+@@ -44,6 +44,8 @@
set test "largefile.c"
set testh "largefile.hs"
set f [open $test w]
+puts $f "/* { dg-do run { target *-*-solaris* } } */"
++puts $f "/* { dg-error \"dummy\" \"fool dejagnu\" { target { ! *-*-solaris* } 20 } } */"
puts $f "/* { dg-timeout-factor 4.0 } */"
set v 0
for { set v 0 } { $v < 10000 } { incr v } {
+--- gcc/testsuite/gcc.dg/format/ext-1.c.orig
++++ gcc/testsuite/gcc.dg/format/ext-1.c
+@@ -8,7 +8,7 @@
+ #include "format.h"
+
+ void
+-foo (quad_t q, u_quad_t uq, quad_t *qn, size_t z, size_t *zn, long long int ll,
++foo (quad2_t q, u_quad2_t uq, quad2_t *qn, size_t z, size_t *zn, long long int ll,
+ unsigned long long int ull, int i, unsigned int u, double d,
+ char *s, void *p, wchar_t *ls, wint_t lc, int *n, long int l)
+ {
+--- gcc/testsuite/gcc.dg/format/ext-2.c.orig
++++ gcc/testsuite/gcc.dg/format/ext-2.c
+@@ -8,7 +8,7 @@
+ #include "format.h"
+
+ void
+-foo (quad_t *qp, u_quad_t *uqp, quad_t *qn, long long int *llp,
++foo (quad2_t *qp, u_quad2_t *uqp, quad2_t *qn, long long int *llp,
+ unsigned long long int *ullp, float *fp, char *s, void **pp, wchar_t *ls,
+ int *ip, unsigned int *up)
+ {
+--- gcc/testsuite/gcc.dg/format/format.h.orig
++++ gcc/testsuite/gcc.dg/format/format.h
+@@ -71,8 +71,8 @@
+ #endif
+
+ /* %q formats want a "quad"; GCC considers this to be a long long. */
+-typedef llong quad_t;
+-typedef ullong u_quad_t;
++typedef llong quad2_t;
++typedef ullong u_quad2_t;
+
+ __extension__ typedef __INTMAX_TYPE__ intmax_t;
+ __extension__ typedef __UINTMAX_TYPE__ uintmax_t;