gcc/libgo
Ian Lance Taylor 053a1f2320 runtime: use the call instruction's PC for panic-in-runtime detection
If a panic happens in the runtime we turn that into a fatal error.
    We use the caller's PC to determine if the panic call is inside
    the runtime. getcallerpc returns the PC immediately after the
    call instruction. If the call is the very last instruction of a
    function, it may not find this PC belong to a runtime function,
    giving false result. We need to back off the PC by 1 to the call
    instruction.
    
    The gc runtime doesn't do this because the gc compiler always
    emit an instruction following a panic call, presumably an UNDEF
    instruction which turns into an architecture-specific illegal
    instruction. Our compiler doesn't do this.
    
    Reviewed-on: https://go-review.googlesource.com/c/159437

From-SVN: r268358
2019-01-29 00:49:23 +00:00
..
config re PR bootstrap/82856 (--enable-maintainter-mode broken by incompatiblity of gcc's required automake and modern Perl) 2018-10-31 20:46:17 +00:00
go runtime: use the call instruction's PC for panic-in-runtime detection 2019-01-29 00:49:23 +00:00
misc/cgo libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
runtime runtime: use the call instruction's PC for panic-in-runtime detection 2019-01-29 00:49:23 +00:00
testsuite libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
aclocal.m4 re PR bootstrap/82856 (--enable-maintainter-mode broken by incompatiblity of gcc's required automake and modern Perl) 2018-10-31 20:46:17 +00:00
check-packages.txt libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
config.h.in internal/bytealg: support systems that don't have memmem 2018-10-02 16:45:51 +00:00
configure libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
configure.ac libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
goarch.sh libgo: support x32 as GOARCH=amd64p32 GOOS=linux 2018-10-01 20:17:11 +00:00
godeps.sh
gotool-packages.txt libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
libgo-packages.txt libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
libgo.imp
LICENSE
Makefile.am libgo: fix building, and some testing, on Solaris 2019-01-21 23:05:52 +00:00
Makefile.in libgo: fix building, and some testing, on Solaris 2019-01-21 23:05:52 +00:00
match.sh libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
MERGE libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
merge.sh libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
mkrsysinfo.sh
mkruntimeinc.sh
mksigtab.sh
mksysinfo.sh syscall: always define WEXITED and WNOWAIT on GNU/Linux 2018-11-26 23:58:34 +00:00
mvifdiff.sh
PATENTS
README
README.gcc
sysinfo.c
VERSION libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00

See ../README.

This is the runtime support library for the Go programming language.
This library is intended for use with the Go frontend.

This library should not be stripped when it is installed.  Go code
relies on being able to look up file/line information, which comes
from the debugging info using the libbacktrace library.

The library has only been tested on GNU/Linux using glibc, and on
Solaris.  It should not be difficult to port to other operating
systems.

Directories:

go
  A copy of the Go library from http://golang.org/, with several
  changes for gccgo.

runtime
  Runtime functions, written in C, which are called directly by the
  compiler or by the library.

Contributing
============

To contribute patches to the files in this directory, please see
http://golang.org/doc/gccgo_contribute.html .

The master copy of these files is hosted at
http://code.google.com/p/gofrontend .  Changes to these files require
signing a Google contributor license agreement.  If you are the
copyright holder, you will need to agree to the individual contributor
license agreement at
http://code.google.com/legal/individual-cla-v1.0.html.  This agreement
can be completed online.

If your organization is the copyright holder, the organization will
need to agree to the corporate contributor license agreement at
http://code.google.com/legal/corporate-cla-v1.0.html.

If the copyright holder for your code has already completed the
agreement in connection with another Google open source project, it
does not need to be completed again.