Commit 7f574e47 authored by Michael Anthony Knyszek's avatar Michael Anthony Knyszek Committed by Michael Knyszek

runtime: remove unnecessary large parameter to mheap_.alloc

mheap_.alloc currently accepts both a spanClass and a "large" parameter
indicating whether the allocation is large. These are redundant, since
spanClass.sizeclass() == 0 is an equivalent way to determine this and is
already used in mheap_.alloc. There are no places in the runtime where
the size class could be non-zero and large == true.

Updates #35112.

Change-Id: Ie66facf8f0faca6f4cd3d20a8ac4bc259e11823d
Reviewed-on: https://go-review.googlesource.com/c/go/+/196639
Run-TryBot: Michael Knyszek <mknyszek@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarAustin Clements <austin@google.com>
parent ffb5646f
...@@ -1149,7 +1149,7 @@ func largeAlloc(size uintptr, needzero bool, noscan bool) *mspan { ...@@ -1149,7 +1149,7 @@ func largeAlloc(size uintptr, needzero bool, noscan bool) *mspan {
// pays the debt down to npage pages. // pays the debt down to npage pages.
deductSweepCredit(npages*_PageSize, npages) deductSweepCredit(npages*_PageSize, npages)
s := mheap_.alloc(npages, makeSpanClass(0, noscan), true, needzero) s := mheap_.alloc(npages, makeSpanClass(0, noscan), needzero)
if s == nil { if s == nil {
throw("out of memory") throw("out of memory")
} }
......
...@@ -252,7 +252,7 @@ func (c *mcentral) grow() *mspan { ...@@ -252,7 +252,7 @@ func (c *mcentral) grow() *mspan {
npages := uintptr(class_to_allocnpages[c.spanclass.sizeclass()]) npages := uintptr(class_to_allocnpages[c.spanclass.sizeclass()])
size := uintptr(class_to_size[c.spanclass.sizeclass()]) size := uintptr(class_to_size[c.spanclass.sizeclass()])
s := mheap_.alloc(npages, c.spanclass, false, true) s := mheap_.alloc(npages, c.spanclass, true)
if s == nil { if s == nil {
return nil return nil
} }
......
...@@ -854,7 +854,7 @@ func (h *mheap) reclaimChunk(arenas []arenaIdx, pageIdx, n uintptr) uintptr { ...@@ -854,7 +854,7 @@ func (h *mheap) reclaimChunk(arenas []arenaIdx, pageIdx, n uintptr) uintptr {
// any stack growth during alloc_m would self-deadlock. // any stack growth during alloc_m would self-deadlock.
// //
//go:systemstack //go:systemstack
func (h *mheap) alloc_m(npage uintptr, spanclass spanClass, large bool) *mspan { func (h *mheap) alloc_m(npage uintptr, spanclass spanClass) *mspan {
_g_ := getg() _g_ := getg()
// To prevent excessive heap growth, before allocating n pages // To prevent excessive heap growth, before allocating n pages
...@@ -901,6 +901,11 @@ func (h *mheap) alloc_m(npage uintptr, spanclass spanClass, large bool) *mspan { ...@@ -901,6 +901,11 @@ func (h *mheap) alloc_m(npage uintptr, spanclass spanClass, large bool) *mspan {
s.divMul = 0 s.divMul = 0
s.divShift2 = 0 s.divShift2 = 0
s.baseMask = 0 s.baseMask = 0
// Update additional stats.
mheap_.largealloc += uint64(s.elemsize)
mheap_.nlargealloc++
atomic.Xadd64(&memstats.heap_live, int64(npage<<_PageShift))
} else { } else {
m := &class_to_divmagic[sizeclass] m := &class_to_divmagic[sizeclass]
s.divShift = m.shift s.divShift = m.shift
...@@ -932,13 +937,8 @@ func (h *mheap) alloc_m(npage uintptr, spanclass spanClass, large bool) *mspan { ...@@ -932,13 +937,8 @@ func (h *mheap) alloc_m(npage uintptr, spanclass spanClass, large bool) *mspan {
arena, pageIdx, pageMask := pageIndexOf(s.base()) arena, pageIdx, pageMask := pageIndexOf(s.base())
arena.pageInUse[pageIdx] |= pageMask arena.pageInUse[pageIdx] |= pageMask
// update stats, sweep lists // Update related page sweeper stats.
h.pagesInUse += uint64(npage) h.pagesInUse += uint64(npage)
if large {
mheap_.largealloc += uint64(s.elemsize)
mheap_.nlargealloc++
atomic.Xadd64(&memstats.heap_live, int64(npage<<_PageShift))
}
} }
// heap_scan and heap_live were updated. // heap_scan and heap_live were updated.
if gcBlackenEnabled != 0 { if gcBlackenEnabled != 0 {
...@@ -964,17 +964,16 @@ func (h *mheap) alloc_m(npage uintptr, spanclass spanClass, large bool) *mspan { ...@@ -964,17 +964,16 @@ func (h *mheap) alloc_m(npage uintptr, spanclass spanClass, large bool) *mspan {
// alloc allocates a new span of npage pages from the GC'd heap. // alloc allocates a new span of npage pages from the GC'd heap.
// //
// Either large must be true or spanclass must indicates the span's // spanclass indicates the span's size class and scannability.
// size class and scannability.
// //
// If needzero is true, the memory for the returned span will be zeroed. // If needzero is true, the memory for the returned span will be zeroed.
func (h *mheap) alloc(npage uintptr, spanclass spanClass, large bool, needzero bool) *mspan { func (h *mheap) alloc(npage uintptr, spanclass spanClass, needzero bool) *mspan {
// Don't do any operations that lock the heap on the G stack. // Don't do any operations that lock the heap on the G stack.
// It might trigger stack growth, and the stack growth code needs // It might trigger stack growth, and the stack growth code needs
// to be able to allocate heap. // to be able to allocate heap.
var s *mspan var s *mspan
systemstack(func() { systemstack(func() {
s = h.alloc_m(npage, spanclass, large) s = h.alloc_m(npage, spanclass)
}) })
if s != nil { if s != nil {
......
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