runtime: change some stack fields to uintptr
authorIan Lance Taylor <ian@gcc.gnu.org>
Thu, 22 Jun 2017 14:44:30 +0000 (14:44 +0000)
committerIan Lance Taylor <ian@gcc.gnu.org>
Thu, 22 Jun 2017 14:44:30 +0000 (14:44 +0000)
commit3b0ddadf74ec9c7aa404765ec50bb55d255dbec7
tree0c76bd6000837d9b83d3a57a300d41d87eaf3fb1
parenta055692a25c10bcd8fd90825cc39709f455335b2
runtime: change some stack fields to uintptr

    Because of how gccgo implements cgo calls, the code in dropm may not
    have any write barriers.  As a step toward implementing that, change
    the gcstack, gcnextsegment, and gcnextsp fields of the g struct to
    uintptr, so that assignments to them do not require write barriers.
    The gcinitialsp field remains unsafe.Pointer, as on 32-bit systems
    that do not support split stack it points to a heap allocated space
    used for the goroutine stack.

    The test for this is runtime tests like TestCgoCallbackGC, which are
    not run today but will be run with a future gotools patch.

    Reviewed-on: https://go-review.googlesource.com/46396

From-SVN: r249561
gcc/go/gofrontend/MERGE
libgo/go/runtime/proc.go
libgo/go/runtime/runtime2.go
libgo/runtime/proc.c
libgo/runtime/stack.c