]> Cypherpunks repositories - gostls13.git/commitdiff
runtime: only trace mark assists that do work
authorAustin Clements <austin@google.com>
Wed, 19 Jul 2017 18:18:08 +0000 (14:18 -0400)
committerAustin Clements <austin@google.com>
Wed, 19 Jul 2017 20:56:20 +0000 (20:56 +0000)
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: Rick Hudson <rlh@golang.org>
src/runtime/mgcmark.go

index dbca5cd1c760099c734a54dfeceff759f52f6277..9029d19d4347ae7c213d16ff584dadbd09ea443b 100644 (file)
@@ -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()
        }
 }