Commit 1ab9176e authored by Rick Hudson's avatar Rick Hudson

runtime: remove race and increase precision in pointer validation.

This CL removes the single and racy use of mheap.arena_end outside
of the bookkeeping done in mHeap_init and mHeap_Alloc.
There should be no way for heapBitsForSpan to see a pointer to
an invalid span. This CL makes the check for this more precise by
checking that the pointer is between mheap_.arena_start and
mheap_.arena_used instead of mheap_.arena_end.

Change-Id: I1200b54353ee1eda002d92645fd8d26048600ceb
Reviewed-on: https://go-review.googlesource.com/11342Reviewed-by: default avatarAustin Clements <austin@google.com>
parent ffbed5c2
...@@ -164,7 +164,7 @@ func heapBitsForAddr(addr uintptr) heapBits { ...@@ -164,7 +164,7 @@ func heapBitsForAddr(addr uintptr) heapBits {
// heapBitsForSpan returns the heapBits for the span base address base. // heapBitsForSpan returns the heapBits for the span base address base.
func heapBitsForSpan(base uintptr) (hbits heapBits) { func heapBitsForSpan(base uintptr) (hbits heapBits) {
if base < mheap_.arena_start || base >= mheap_.arena_end { if base < mheap_.arena_start || base >= mheap_.arena_used {
throw("heapBitsForSpan: base out of range") throw("heapBitsForSpan: base out of range")
} }
hbits = heapBitsForAddr(base) hbits = heapBitsForAddr(base)
......
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