Source File
msize.go
Belonging Package
runtime
// Copyright 2009 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Malloc small size classes.
//
// See malloc.go for overview.
// See also mksizeclasses.go for how we decide what size classes to use.
package runtime
import
// Returns size of the memory block that mallocgc will allocate if you ask for the size,
// minus any inline space for metadata.
func roundupsize( uintptr, bool) ( uintptr) {
=
if <= maxSmallSize-gc.MallocHeaderSize {
// Small object.
if ! && > gc.MinSizeForMallocHeader { // !noscan && !heapBitsInSpan(reqSize)
+= gc.MallocHeaderSize
}
// (reqSize - size) is either mallocHeaderSize or 0. We need to subtract mallocHeaderSize
// from the result if we have one, since mallocgc will add it back in.
if <= gc.SmallSizeMax-8 {
return uintptr(gc.SizeClassToSize[gc.SizeToSizeClass8[divRoundUp(, gc.SmallSizeDiv)]]) - ( - )
}
return uintptr(gc.SizeClassToSize[gc.SizeToSizeClass128[divRoundUp(-gc.SmallSizeMax, gc.LargeSizeDiv)]]) - ( - )
}
// Large object. Align reqSize up to the next page. Check for overflow.
+= pageSize - 1
if < {
return
}
return &^ (pageSize - 1)
}
![]() |
The pages are generated with Golds v0.7.7-preview. (GOOS=linux GOARCH=amd64) Golds is a Go 101 project developed by Tapir Liu. PR and bug reports are welcome and can be submitted to the issue list. Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds. |