Commit 98130b39 authored by Austin Clements's avatar Austin Clements

runtime: remove noescape hacks from gcWork

When gcWork was first introduced, the compiler's escape analysis
wasn't good enough to detect that that method receiver didn't escape,
so we had to hack around this.

Now that the compiler can figure out this for itself, remove these
hacks.

Change-Id: I9f73fab721e272410b8b6905b564e7abc03c0dfe
Reviewed-on: https://go-review.googlesource.com/19634Reviewed-by: default avatarRick Hudson <rlh@golang.org>
Run-TryBot: Austin Clements <austin@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent 0d26efb1
...@@ -105,9 +105,7 @@ func (w *gcWork) init() { ...@@ -105,9 +105,7 @@ func (w *gcWork) init() {
// put enqueues a pointer for the garbage collector to trace. // put enqueues a pointer for the garbage collector to trace.
// obj must point to the beginning of a heap object. // obj must point to the beginning of a heap object.
//go:nowritebarrier //go:nowritebarrier
func (ww *gcWork) put(obj uintptr) { func (w *gcWork) put(obj uintptr) {
w := (*gcWork)(noescape(unsafe.Pointer(ww))) // TODO: remove when escape analysis is fixed
wbuf := w.wbuf1.ptr() wbuf := w.wbuf1.ptr()
if wbuf == nil { if wbuf == nil {
w.init() w.init()
...@@ -133,9 +131,7 @@ func (ww *gcWork) put(obj uintptr) { ...@@ -133,9 +131,7 @@ func (ww *gcWork) put(obj uintptr) {
// queue, tryGet returns 0. Note that there may still be pointers in // queue, tryGet returns 0. Note that there may still be pointers in
// other gcWork instances or other caches. // other gcWork instances or other caches.
//go:nowritebarrier //go:nowritebarrier
func (ww *gcWork) tryGet() uintptr { func (w *gcWork) tryGet() uintptr {
w := (*gcWork)(noescape(unsafe.Pointer(ww))) // TODO: remove when escape analysis is fixed
wbuf := w.wbuf1.ptr() wbuf := w.wbuf1.ptr()
if wbuf == nil { if wbuf == nil {
w.init() w.init()
...@@ -164,9 +160,7 @@ func (ww *gcWork) tryGet() uintptr { ...@@ -164,9 +160,7 @@ func (ww *gcWork) tryGet() uintptr {
// if necessary to ensure all pointers from all queues and caches have // if necessary to ensure all pointers from all queues and caches have
// been retrieved. get returns 0 if there are no pointers remaining. // been retrieved. get returns 0 if there are no pointers remaining.
//go:nowritebarrier //go:nowritebarrier
func (ww *gcWork) get() uintptr { func (w *gcWork) get() uintptr {
w := (*gcWork)(noescape(unsafe.Pointer(ww))) // TODO: remove when escape analysis is fixed
wbuf := w.wbuf1.ptr() wbuf := w.wbuf1.ptr()
if wbuf == nil { if wbuf == nil {
w.init() w.init()
......
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