Commit 53f2d534 authored by Austin Clements's avatar Austin Clements

runtime: document concurrency of mheap.spans

We use lock-free reads from mheap.spans, but the safety of these is
somewhat subtle. Document this.

Change-Id: I928c893232176135308e38bed788d5f84ff11533
Reviewed-on: https://go-review.googlesource.com/54310Reviewed-by: default avatarRick Hudson <rlh@golang.org>
parent 6a7c4d69
...@@ -56,6 +56,12 @@ type mheap struct { ...@@ -56,6 +56,12 @@ type mheap struct {
// Internal pages map to an arbitrary span. // Internal pages map to an arbitrary span.
// For pages that have never been allocated, spans entries are nil. // For pages that have never been allocated, spans entries are nil.
// //
// Modifications are protected by mheap.lock. Reads can be
// performed without locking, but ONLY from indexes that are
// known to contain in-use or stack spans. This means there
// must not be a safe-point between establishing that an
// address is live and looking it up in the spans array.
//
// This is backed by a reserved region of the address space so // This is backed by a reserved region of the address space so
// it can grow without moving. The memory up to len(spans) is // it can grow without moving. The memory up to len(spans) is
// mapped. cap(spans) indicates the total reserved memory. // mapped. cap(spans) indicates the total reserved memory.
......
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