Commit ffd5687a authored by Austin Clements's avatar Austin Clements

runtime: only trace mark assists that do work

Currently we trace mark assists even if they're satisfied entirely by
stealing. This means even if background marking is keeping up with
allocation, we'll still emit a trace event every N bytes of
allocation. The event will be a few microseconds, if that, but they're
frequent enough that, when zoomed out in the trace view, it looks like
all of the time is spent in mark assists even if almost none is.

Change this so we only emit a trace event if the assist actually has
to do assisting. This makes the traces of these events far more
useful.

Change-Id: If4aed1c413b814341ef2fba61d2f10751d00451b
Reviewed-on: https://go-review.googlesource.com/50030
Run-TryBot: Austin Clements <austin@google.com>
Reviewed-by: default avatarRick Hudson <rlh@golang.org>
parent 93b7eb97
......@@ -415,10 +415,7 @@ func gcAssistAlloc(gp *g) {
return
}
if trace.enabled {
traceGCMarkAssistStart()
}
traced := false
retry:
// Compute the amount of scan work we need to do to make the
// balance positive. When the required amount of work is low,
......@@ -454,13 +451,18 @@ retry:
if scanWork == 0 {
// We were able to steal all of the credit we
// needed.
if trace.enabled {
if traced {
traceGCMarkAssistDone()
}
return
}
}
if trace.enabled && !traced {
traced = true
traceGCMarkAssistStart()
}
// Perform assist work
systemstack(func() {
gcAssistAlloc1(gp, scanWork)
......@@ -503,7 +505,7 @@ retry:
// At this point either background GC has satisfied
// this G's assist debt, or the GC cycle is over.
}
if trace.enabled {
if traced {
traceGCMarkAssistDone()
}
}
......
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