gcc/libgo
Ian Lance Taylor 1da37f43b2 runtime: persistentalloc and cache itabs
Previously, each time we do an interface conversion for which the
    method table is not known at compile time, we allocate a new
    method table.
    
    This CL ports the mechanism of itab caching from the gc runtime,
    adapted to our itab representation and method finding mechanism.
    With the cache, we reuse the same itab for the same (interface,
    concrete) type pair. This reduces allocations in interface
    conversions.
    
    Unlike the gc runtime, we don't prepopulate the cache with
    statically allocated itabs, as currently we don't have a way to
    find them. This means we don't deduplicate run-time allocated
    itabs with compile-time allocated ones. But that is not too bad
    -- it is just a cache anyway.
    
    As now itabs are never freed, it is also possible to drop the
    write barrier for writing the first word of an interface header.
    I'll leave this optimization for the future.
    
    Reviewed-on: https://go-review.googlesource.com/c/gofrontend/+/171617

From-SVN: r270778
2019-05-01 20:27:36 +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: persistentalloc and cache itabs 2019-05-01 20:27:36 +00:00
misc/cgo libgo: update to Go 1.12.1 2019-03-18 20:27:59 +00:00
runtime re PR target/89093 (C++ exception handling clobbers d8 VFP register) 2019-04-24 12:45:45 +00:00
testsuite commit 66ac9466852d11e968f8fd2ad6ffc7386cee49e1 2019-03-01 01:03:54 +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 runtime, sync: use __atomic intrinsics instead of __sync 2019-02-01 21:55:38 +00:00
configure re PR go/89172 (FAIL: runtime/pprof) 2019-02-27 22:35:10 +00:00
configure.ac re PR go/89172 (FAIL: runtime/pprof) 2019-02-27 22:35:10 +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 go_export extraction on Darwin 2019-02-28 01:01:46 +00:00
Makefile.in libgo: fix go_export extraction on Darwin 2019-02-28 01:01:46 +00:00
match.sh libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
MERGE libgo: update to Go 1.12.2 2019-04-08 18:36:25 +00:00
merge.sh libgo: update to Go1.12beta2 2019-01-18 19:04:36 +00:00
mkrsysinfo.sh
mkruntimeinc.sh libgo: refactor code to enumerate stdlib packages 2018-05-02 21:57:35 +00:00
mksigtab.sh libgo: add configury and sysinfo support for hurd 2019-02-01 22:46:39 +00:00
mksysinfo.sh libgo: fix build on AIX 2019-03-19 14:00:59 +00:00
mvifdiff.sh
PATENTS
README
README.gcc
sysinfo.c syscall: remove Ustat 2018-06-22 14:25:52 +00:00
VERSION libgo: update to Go 1.12.2 2019-04-08 18:36:25 +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.