Commit 24f846e2 authored by Josh Bleecher Snyder's avatar Josh Bleecher Snyder

runtime: skip wb call in growslice when unnecessary

Instrumenting make.bash reveals that almost half (49.54%)
of the >16 million calls to growslice for
pointer-containing slices are
growing from an empty to a non-empty slice.

In that case, there is no need to call the write barrier,
which does some work before discovering that no pointers need shading.

Change-Id: Ide741468d8dee7ad43ea0bfbea6ccdf680030a0f
Reviewed-on: https://go-review.googlesource.com/c/go/+/168959
Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarKeith Randall <khr@golang.org>
parent 2034fbab
...@@ -179,7 +179,7 @@ func growslice(et *_type, old slice, cap int) slice { ...@@ -179,7 +179,7 @@ func growslice(et *_type, old slice, cap int) slice {
} else { } else {
// Note: can't use rawmem (which avoids zeroing of memory), because then GC can scan uninitialized memory. // Note: can't use rawmem (which avoids zeroing of memory), because then GC can scan uninitialized memory.
p = mallocgc(capmem, et, true) p = mallocgc(capmem, et, true)
if writeBarrier.enabled { if lenmem > 0 && writeBarrier.enabled {
// Only shade the pointers in old.array since we know the destination slice p // Only shade the pointers in old.array since we know the destination slice p
// only contains nil pointers because it has been cleared during alloc. // only contains nil pointers because it has been cleared during alloc.
bulkBarrierPreWriteSrcOnly(uintptr(p), uintptr(old.array), lenmem) bulkBarrierPreWriteSrcOnly(uintptr(p), uintptr(old.array), lenmem)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment