backport: [multiple changes]

2015-06-25  Andreas Tobler  <andreast@gcc.gnu.org>

    Backport from mainline
    2015-05-28  Andreas Tobler  <andreast@gcc.gnu.org>

    * configure.host: Add bits for FreeBSD amd64 and i386.
    * configure.ac: Add signal handler for FreeBSD (amd64/i386)
    * configure: Regenerate.
    * include/freebsd-signal.h: New file.

    2015-05-26  Andreas Tobler  <andreast@gcc.gnu.org>

    * testsuite/libjava.jni/jni.exp (gcj_jni_get_cxxflags_invocation): Add
    libiconv for FreeBSD to cxxflags.

From-SVN: r224984
This commit is contained in:
Andreas Tobler 2015-06-25 19:56:36 +02:00
parent 81079cc605
commit 4e9c497988
6 changed files with 76 additions and 0 deletions

View File

@ -1,3 +1,18 @@
2015-06-25 Andreas Tobler <andreast@gcc.gnu.org>
Backport from mainline
2015-05-28 Andreas Tobler <andreast@gcc.gnu.org>
* configure.host: Add bits for FreeBSD amd64 and i386.
* configure.ac: Add signal handler for FreeBSD (amd64/i386)
* configure: Regenerate.
* include/freebsd-signal.h: New file.
2015-05-26 Andreas Tobler <andreast@gcc.gnu.org>
* testsuite/libjava.jni/jni.exp (gcj_jni_get_cxxflags_invocation): Add
libiconv for FreeBSD to cxxflags.
2015-04-22 Release Manager 2015-04-22 Release Manager
* GCC 5.1.0 released. * GCC 5.1.0 released.

3
libjava/configure vendored
View File

@ -24442,6 +24442,9 @@ case "${host}" in
powerpc*-*-aix*) powerpc*-*-aix*)
SIGNAL_HANDLER=include/aix-signal.h SIGNAL_HANDLER=include/aix-signal.h
;; ;;
i?86-*-freebsd* | x86_64-*-freebsd*)
SIGNAL_HANDLER=include/freebsd-signal.h
;;
*) *)
SIGNAL_HANDLER=include/default-signal.h SIGNAL_HANDLER=include/default-signal.h
;; ;;

View File

@ -1755,6 +1755,9 @@ case "${host}" in
powerpc*-*-aix*) powerpc*-*-aix*)
SIGNAL_HANDLER=include/aix-signal.h SIGNAL_HANDLER=include/aix-signal.h
;; ;;
i?86-*-freebsd* | x86_64-*-freebsd*)
SIGNAL_HANDLER=include/freebsd-signal.h
;;
*) *)
SIGNAL_HANDLER=include/default-signal.h SIGNAL_HANDLER=include/default-signal.h
;; ;;

View File

@ -338,6 +338,8 @@ EOF
;; ;;
*-*-freebsd*) *-*-freebsd*)
slow_pthread_self= slow_pthread_self=
can_unwind_signal=yes
DIVIDESPEC=-fuse-divide-subroutine
;; ;;
*-mingw*) *-mingw*)
libgcj_flags="${libgcj_flags} -fno-omit-frame-pointer" libgcj_flags="${libgcj_flags} -fno-omit-frame-pointer"

View File

@ -0,0 +1,48 @@
/* freebsd-signal.h - Catch runtime signals and turn them into exceptions,
on a FreeBSD system. */
/* Copyright (C) 2015 Free Software Foundation
This file is part of libgcj.
This software is copyrighted work licensed under the terms of the
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
details. */
/* This file is really more of a specification. The rest of the system
should be arranged so that this Just Works. */
#ifndef JAVA_SIGNAL_H
# define JAVA_SIGNAL_H 1
#include <sys/types.h>
#include <sys/signal.h>
# define HANDLE_SEGV 1
# define HANDLE_FPE 1
# define SIGNAL_HANDLER(_name) \
static void _name (int _dummy __attribute__ ((unused)))
# define MAKE_THROW_FRAME(_exception)
# define INIT_SEGV \
do { \
struct sigaction sa; \
sa.sa_handler = catch_segv; \
sigemptyset (&sa.sa_mask); \
sa.sa_flags = SA_NODEFER; \
sigaction (SIGBUS, &sa, NULL); \
sigaction (SIGSEGV, &sa, NULL); \
} while (0)
# define INIT_FPE \
do { \
struct sigaction sa; \
sa.sa_handler = catch_fpe; \
sigemptyset (&sa.sa_mask); \
sa.sa_flags = SA_NODEFER; \
sigaction (SIGFPE, &sa, NULL); \
} while (0)
#endif /* JAVA_SIGNAL_H */

View File

@ -274,6 +274,11 @@ proc gcj_jni_get_cxxflags_invocation {} {
eval lappend cxxflags "-shared-libgcc -lgcj $libiconv" eval lappend cxxflags "-shared-libgcc -lgcj $libiconv"
} }
# FreeBSD needs -liconv linked, otherwise we get some unresolved.
if { [istarget "*-*-freebsd*"] } {
eval lappend cxxflags "$libiconv"
}
# Make sure libgcc unwinder is used on 64-bit Solaris 10+/x86 rather than # Make sure libgcc unwinder is used on 64-bit Solaris 10+/x86 rather than
# the libc one. # the libc one.
if { [istarget "*-*-solaris*"] } { if { [istarget "*-*-solaris*"] } {