// 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

// 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-mallocHeaderSize {
		// Small object.
		if ! &&  > minSizeForMallocHeader { // !noscan && !heapBitsInSpan(reqSize)
			 += 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  <= smallSizeMax-8 {
			return uintptr(class_to_size[size_to_class8[divRoundUp(, smallSizeDiv)]]) - ( - )
		}
		return uintptr(class_to_size[size_to_class128[divRoundUp(-smallSizeMax, largeSizeDiv)]]) - ( - )
	}
	// Large object. Align reqSize up to the next page. Check for overflow.
	 += pageSize - 1
	if  <  {
		return 
	}
	return  &^ (pageSize - 1)
}