-
Notifications
You must be signed in to change notification settings - Fork 17.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
runtime: g0 stack.lo is sometimes too low #26061
Comments
Change https://golang.org/cl/120858 mentions this issue: |
Change https://golang.org/cl/122577 mentions this issue: |
Hello Austin, you submitted CL https://go-review.googlesource.com/c/go/+/120858/ please rebase from master and remove the unused variables. Thank you! |
Change https://go.dev/cl/487355 mentions this issue: |
This test fails when run on ios. (Although ios does not normally support "exec", in the corellium environment it does.) For #26061. Change-Id: Idfdc53758aaabf0cb87ae50f9a4666deebf57fd6 Reviewed-on: https://go-review.googlesource.com/c/go/+/487355 TryBot-Result: Gopher Robot <gobot@golang.org> Auto-Submit: Bryan Mills <bcmills@google.com> Reviewed-by: Ian Lance Taylor <iant@google.com> Run-TryBot: Bryan Mills <bcmills@google.com>
In cgo mode for UNIX platforms, we compute the g0 stack bounds by querying the stack size from
pthread_get_stacksize
, subtracting that from the current SP inmstart
, and adding a 1k buffer. However, on my Linux laptop, over 4k of the stack has already been consumed by the time we reachmstart
, so the runtime sets the bottom of the g0 stack to be below the mapped memory. As a result, if we actually overflow the g0 stack, we get a segfault instead of a useful message with a traceback.We should use
pthread_get_stack
instead to get both stack bounds.Discovered when writing a test of overflowing the g0 stack for #21382, which I had assumed would pass on linux/amd64 but didn't.
The text was updated successfully, but these errors were encountered: