Commit b0d5e5c5 authored by Austin Clements's avatar Austin Clements

runtime: consolidate gcResetGState calls

Currently gcResetGState is called by func gcscan_m for concurrent GC
and directly by func gc for STW GC. Simplify this by consolidating
these two calls in to one call by func gc above where it splits for
concurrent and STW GC.

As a consequence, gcResetGState and gcResetMarkState are always called
together, so the next commit will consolidate these.

Change-Id: Ib62d404c7b32b28f7d3080d26ecf3966cbc4aca0
Reviewed-on: https://go-review.googlesource.com/16040Reviewed-by: default avatarRick Hudson <rlh@golang.org>
parent feb92a8e
...@@ -987,6 +987,7 @@ func gc(mode gcMode) { ...@@ -987,6 +987,7 @@ func gc(mode gcMode) {
// reclaimed until the next GC cycle. // reclaimed until the next GC cycle.
clearpools() clearpools()
gcResetGState()
gcResetMarkState() gcResetMarkState()
work.finalizersDone = false work.finalizersDone = false
...@@ -1105,11 +1106,6 @@ func gc(mode gcMode) { ...@@ -1105,11 +1106,6 @@ func gc(mode gcMode) {
gcController.endCycle() gcController.endCycle()
} else { } else {
// For non-concurrent GC (mode != gcBackgroundMode)
// The g stacks have not been scanned so clear g state
// such that mark termination scans all stacks.
gcResetGState()
t := nanotime() t := nanotime()
tScan, tInstallWB, tMark, tMarkTerm = t, t, t, t tScan, tInstallWB, tMark, tMarkTerm = t, t, t, t
heapGoal = heap0 heapGoal = heap0
...@@ -1653,9 +1649,9 @@ func gcCopySpans() { ...@@ -1653,9 +1649,9 @@ func gcCopySpans() {
unlock(&mheap_.lock) unlock(&mheap_.lock)
} }
// gcResetGState resets the GC state of all G's and returns the length // gcResetGState resets the GC state of all G's. Any Gs created after
// of allgs. // this will also be in this reset state.
func gcResetGState() (numgs int) { func gcResetGState() {
// This may be called during a concurrent phase, so make sure // This may be called during a concurrent phase, so make sure
// allgs doesn't change. // allgs doesn't change.
lock(&allglock) lock(&allglock)
...@@ -1664,9 +1660,7 @@ func gcResetGState() (numgs int) { ...@@ -1664,9 +1660,7 @@ func gcResetGState() (numgs int) {
gp.gcscanvalid = false // stack has not been scanned gp.gcscanvalid = false // stack has not been scanned
gp.gcAssistBytes = 0 gp.gcAssistBytes = 0
} }
numgs = len(allgs)
unlock(&allglock) unlock(&allglock)
return
} }
// gcResetMarkState resets state prior to marking (concurrent or STW). // gcResetMarkState resets state prior to marking (concurrent or STW).
......
...@@ -26,8 +26,12 @@ func gcscan_m() { ...@@ -26,8 +26,12 @@ func gcscan_m() {
// runtime·restartg(mastergp) to make it Grunnable. // runtime·restartg(mastergp) to make it Grunnable.
// At the bottom we will want to return this p back to the scheduler. // At the bottom we will want to return this p back to the scheduler.
// Prepare flag indicating that the scan has not been completed. // Snapshot of allglen. During concurrent scan, we just need
local_allglen := gcResetGState() // to be consistent about how many markroot jobs we create and
// how many Gs we check. Gs may be created after this and
// they'll be scanned during mark termination. During mark
// termination, allglen isn't changing.
local_allglen := int(atomicloaduintptr(&allglen))
work.ndone = 0 work.ndone = 0
useOneP := uint32(1) // For now do not do this in parallel. useOneP := uint32(1) // For now do not do this in parallel.
......
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