mirror of git://gcc.gnu.org/git/gcc.git
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:
parent
81079cc605
commit
4e9c497988
|
|
@ -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.
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
;;
|
;;
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
;;
|
;;
|
||||||
|
|
|
||||||
|
|
@ -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"
|
||||||
|
|
|
||||||
|
|
@ -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 */
|
||||||
|
|
@ -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*"] } {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue