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
..
2019-03-19 14:00:59 +00:00
2019-04-08 18:36:25 +00:00
2019-02-26 15:38:12 +00:00
2019-02-26 01:00:39 +00:00
2019-02-26 01:00:39 +00:00
2019-01-18 19:04:36 +00:00
2019-04-08 18:36:25 +00:00
2019-02-26 01:00:39 +00:00
2019-02-01 21:57:36 +00:00
2019-04-08 18:36:25 +00:00
2019-04-08 18:36:25 +00:00
2019-03-18 20:27:59 +00:00
2019-02-01 21:57:36 +00:00
2019-02-26 01:00:39 +00:00
2019-02-26 01:00:39 +00:00
2019-02-26 01:00:39 +00:00
2019-03-18 20:27:59 +00:00
2019-02-01 21:57:36 +00:00