I just submitted CL 255297 which mostly fixed this problem, but totally
forgot to actually acquire/release the heap lock. Oops.
Updates #41391.
Change-Id: I45b42f20a9fc765c4de52476db3654d4bfe9feb3
Reviewed-on: https://go-review.googlesource.com/c/go/+/255298
Trust: Michael Knyszek <mknyszek@google.com>
Run-TryBot: Michael Knyszek <mknyszek@google.com>
Reviewed-by: Keith Randall <khr@golang.org>
TryBot-Result: Go Bot <gobot@golang.org>
func AllocMSpan() *MSpan {
var s *mspan
systemstack(func() {
+ lock(&mheap_.lock)
s = (*mspan)(mheap_.spanalloc.alloc())
+ unlock(&mheap_.lock)
})
return (*MSpan)(s)
}
// Free an allocated mspan.
func FreeMSpan(s *MSpan) {
systemstack(func() {
+ lock(&mheap_.lock)
mheap_.spanalloc.free(unsafe.Pointer(s))
+ unlock(&mheap_.lock)
})
}