Commit 1ac65f82 authored by Austin Clements's avatar Austin Clements

runtime: eliminate b == 0 special case from scanblock

We no longer ever call scanblock with b == 0.

Change-Id: I9b01da39595e0cc251668c24d58748d88f5f0792
Reviewed-on: https://go-review.googlesource.com/4782Reviewed-by: default avatarRuss Cox <rsc@golang.org>
Reviewed-by: default avatarRick Hudson <rlh@golang.org>
parent cf964e16
...@@ -422,8 +422,6 @@ func scanobject(b, n uintptr, ptrmask *uint8, wbuf *workbuf) *workbuf { ...@@ -422,8 +422,6 @@ func scanobject(b, n uintptr, ptrmask *uint8, wbuf *workbuf) *workbuf {
// scanblock starts by scanning b as scanobject would. // scanblock starts by scanning b as scanobject would.
// If the gcphase is GCscan, that's all scanblock does. // If the gcphase is GCscan, that's all scanblock does.
// Otherwise it traverses some fraction of the pointers it found in b, recursively. // Otherwise it traverses some fraction of the pointers it found in b, recursively.
// As a special case, scanblock(nil, 0, nil) means to scan previously queued work,
// stopping only when no work is left in the system.
//go:nowritebarrier //go:nowritebarrier
func scanblock(b0, n0 uintptr, ptrmask *uint8, wbuf *workbuf) *workbuf { func scanblock(b0, n0 uintptr, ptrmask *uint8, wbuf *workbuf) *workbuf {
// Use local copies of original parameters, so that a stack trace // Use local copies of original parameters, so that a stack trace
...@@ -439,19 +437,16 @@ func scanblock(b0, n0 uintptr, ptrmask *uint8, wbuf *workbuf) *workbuf { ...@@ -439,19 +437,16 @@ func scanblock(b0, n0 uintptr, ptrmask *uint8, wbuf *workbuf) *workbuf {
if wbuf == nil { if wbuf == nil {
wbuf = getpartialorempty(460) // no wbuf passed in. wbuf = getpartialorempty(460) // no wbuf passed in.
} }
if b != 0 { wbuf = scanobject(b, n, ptrmask, wbuf)
wbuf = scanobject(b, n, ptrmask, wbuf) if gcphase == _GCscan {
if gcphase == _GCscan { if inheap(b) && ptrmask == nil {
if inheap(b) && ptrmask == nil { // b is in heap, we are in GCscan so there should be a ptrmask.
// b is in heap, we are in GCscan so there should be a ptrmask. throw("scanblock: In GCscan phase and inheap is true.")
throw("scanblock: In GCscan phase and inheap is true.")
}
return wbuf
} }
return wbuf
} }
drainallwbufs := b == 0 drainworkbuf(wbuf, false)
drainworkbuf(wbuf, drainallwbufs)
return nil return nil
} }
......
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