mirror of
https://github.com/golang/go
synced 2024-10-04 20:21:22 -06:00
a33ef8d11b
Currently lots of sys allocations are not accounted in any of XxxSys, including GC bitmap, spans table, GC roots blocks, GC finalizer blocks, iface table, netpoll descriptors and more. Up to ~20% can unaccounted. This change introduces 2 new stats: GCSys and OtherSys for GC metadata and all other misc allocations, respectively. Also ensures that all XxxSys indeed sum up to Sys. All sys memory allocation functions require the stat for accounting, so that it's impossible to miss something. Also fix updating of mcache_sys/inuse, they were not updated after deallocation. test/bench/garbage/parser before: Sys 670064344 HeapSys 610271232 StackSys 65536 MSpanSys 14204928 MCacheSys 16384 BuckHashSys 1439992 after: Sys 670064344 HeapSys 610271232 StackSys 65536 MSpanSys 14188544 MCacheSys 16384 BuckHashSys 3194304 GCSys 39198688 OtherSys 3129656 Fixes #5799. R=rsc, dave, alex.brainman CC=golang-dev https://golang.org/cl/12946043
65 lines
1.3 KiB
C
65 lines
1.3 KiB
C
// 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.
|
|
|
|
// Fixed-size object allocator. Returned memory is not zeroed.
|
|
//
|
|
// See malloc.h for overview.
|
|
|
|
#include "runtime.h"
|
|
#include "arch_GOARCH.h"
|
|
#include "malloc.h"
|
|
|
|
// Initialize f to allocate objects of the given size,
|
|
// using the allocator to obtain chunks of memory.
|
|
void
|
|
runtime·FixAlloc_Init(FixAlloc *f, uintptr size, void (*first)(void*, byte*), void *arg, uint64 *stat)
|
|
{
|
|
f->size = size;
|
|
f->first = first;
|
|
f->arg = arg;
|
|
f->list = nil;
|
|
f->chunk = nil;
|
|
f->nchunk = 0;
|
|
f->inuse = 0;
|
|
f->stat = stat;
|
|
}
|
|
|
|
void*
|
|
runtime·FixAlloc_Alloc(FixAlloc *f)
|
|
{
|
|
void *v;
|
|
|
|
if(f->size == 0) {
|
|
runtime·printf("runtime: use of FixAlloc_Alloc before FixAlloc_Init\n");
|
|
runtime·throw("runtime: internal error");
|
|
}
|
|
|
|
if(f->list) {
|
|
v = f->list;
|
|
f->list = *(void**)f->list;
|
|
f->inuse += f->size;
|
|
return v;
|
|
}
|
|
if(f->nchunk < f->size) {
|
|
f->chunk = runtime·persistentalloc(FixAllocChunk, 0, f->stat);
|
|
f->nchunk = FixAllocChunk;
|
|
}
|
|
v = f->chunk;
|
|
if(f->first)
|
|
f->first(f->arg, v);
|
|
f->chunk += f->size;
|
|
f->nchunk -= f->size;
|
|
f->inuse += f->size;
|
|
return v;
|
|
}
|
|
|
|
void
|
|
runtime·FixAlloc_Free(FixAlloc *f, void *p)
|
|
{
|
|
f->inuse -= f->size;
|
|
*(void**)p = f->list;
|
|
f->list = p;
|
|
}
|
|
|