Commit 03227bb5 authored by Austin Clements's avatar Austin Clements

runtime: eliminate traceBuf write barriers

The tracing code is currently called from contexts such as sysmon and
the scheduler where write barriers are not allowed. Unfortunately,
while the common paths through the tracing code do not have write
barriers, many of the less common paths dealing with buffer overflow
and recycling do.

This change replaces all *traceBufs with traceBufPtrs. In the style of
guintptr, etc., the GC does not trace traceBufPtrs and write barriers
do not apply when these pointers are written. Since traceBufs are
allocated from non-GC'd memory and manually managed, this is always
safe.

Updates #10600.

Change-Id: I52b992d36d1b634ebd855c8cde27947ec14f59ba
Reviewed-on: https://go-review.googlesource.com/16812
Run-TryBot: Austin Clements <austin@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarDmitry Vyukov <dvyukov@google.com>
parent a9a7e406
...@@ -380,7 +380,7 @@ type p struct { ...@@ -380,7 +380,7 @@ type p struct {
sudogcache []*sudog sudogcache []*sudog
sudogbuf [128]*sudog sudogbuf [128]*sudog
tracebuf *traceBuf tracebuf traceBufPtr
palloc persistentAlloc // per-P to avoid mutex palloc persistentAlloc // per-P to avoid mutex
......
This diff is collapsed.
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