]> Cypherpunks repositories - gostls13.git/commitdiff
runtime: take stack barrier lock during copystack
authorAustin Clements <austin@google.com>
Mon, 23 Nov 2015 20:03:38 +0000 (15:03 -0500)
committerRuss Cox <rsc@golang.org>
Tue, 24 Nov 2015 01:50:52 +0000 (01:50 +0000)
Commit bbd1a1c prevented SIGPROF from scanning stacks that were being
copied, but it didn't prevent a stack copy (specifically a stack
shrink) from happening while SIGPROF is scanning the stack. As a
result, a stack copy may adjust stack barriers while SIGPROF is in the
middle of scanning a stack, causing SIGPROF to panic when it detects
an inconsistent stack barrier.

Fix this by taking the stack barrier lock while adjusting the stack.
In addition to preventing SIGPROF from scanning this stack, this will
block until any in-progress SIGPROF is done scanning the stack.

For 1.5.2.

Fixes #13362.
Updates #12932.

Change-Id: I422219c363054410dfa56381f7b917e04690e5dd
Reviewed-on: https://go-review.googlesource.com/17191
Run-TryBot: Austin Clements <austin@google.com>
Reviewed-by: Russ Cox <rsc@golang.org>
Run-TryBot: Russ Cox <rsc@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>

src/runtime/stack.go

index 00cd6aeb1dcc8625b6ccd5f5e0bc96cc71f35ff0..8f31c936be17573d7dabf59ccad43b9d212e084f 100644 (file)
@@ -719,6 +719,10 @@ func copystack(gp *g, newsize uintptr) {
                print("copystack gp=", gp, " [", hex(old.lo), " ", hex(old.hi-used), " ", hex(old.hi), "]/", gp.stackAlloc, " -> [", hex(new.lo), " ", hex(new.hi-used), " ", hex(new.hi), "]/", newsize, "\n")
        }
 
+       // Disallow sigprof scans of this stack and block if there's
+       // one in progress.
+       gcLockStackBarriers(gp)
+
        // adjust pointers in the to-be-copied frames
        var adjinfo adjustinfo
        adjinfo.old = old
@@ -751,6 +755,8 @@ func copystack(gp *g, newsize uintptr) {
        gp.stkbar = newstkbar
        gp.stktopsp += adjinfo.delta
 
+       gcUnlockStackBarriers(gp)
+
        // free old stack
        if stackPoisonCopy != 0 {
                fillstack(old, 0xfc)