Commit 77e52829 authored by Austin Clements's avatar Austin Clements

runtime: check that stack barrier unwind is in sync

Currently the stack barrier stub blindly unwinds the next stack
barrier from the G's stack barrier array without checking that it's
the right stack barrier. If through some bug the stack barrier array
position gets out of sync with where we actually are on the stack,
this could return to the wrong PC, which would lead to difficult to
debug crashes. To address this, this commit adds a check to the amd64
stack barrier stub that it's unwinding the correct stack barrier.

Updates #12238.

Change-Id: If824d95191d07e2512dc5dba0d9978cfd9f54e02
Reviewed-on: https://go-review.googlesource.com/13948Reviewed-by: default avatarRuss Cox <rsc@golang.org>
parent 3bfc9df2
...@@ -346,7 +346,12 @@ TEXT runtime·stackBarrier(SB),NOSPLIT,$0 ...@@ -346,7 +346,12 @@ TEXT runtime·stackBarrier(SB),NOSPLIT,$0
MOVQ (g_stkbar+slice_array)(CX), DX MOVQ (g_stkbar+slice_array)(CX), DX
MOVQ g_stkbarPos(CX), BX MOVQ g_stkbarPos(CX), BX
IMULQ $stkbar__size, BX // Too big for SIB. IMULQ $stkbar__size, BX // Too big for SIB.
MOVQ stkbar_savedLRPtr(DX)(BX*1), R8
MOVQ stkbar_savedLRVal(DX)(BX*1), BX MOVQ stkbar_savedLRVal(DX)(BX*1), BX
// Assert that we're popping the right saved LR.
CMPQ R8, SP
JNE 2(PC)
MOVL $0, 0
// Record that this stack barrier was hit. // Record that this stack barrier was hit.
ADDQ $1, g_stkbarPos(CX) ADDQ $1, g_stkbarPos(CX)
// Jump to the original return PC. // Jump to the original return PC.
......
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