Commit 4f514e86 authored by Dmitriy Vyukov's avatar Dmitriy Vyukov

runtime: use persistentalloc instead of SysAlloc in FixAlloc

Also reduce FixAlloc allocation granulatiry from 128k to 16k,
small programs do not need that much memory for MCache's and MSpan's.

R=golang-dev, khr
CC=golang-dev
https://golang.org/cl/10140044
parent 83445fdc
...@@ -407,7 +407,7 @@ runtime·mallocinit(void) ...@@ -407,7 +407,7 @@ runtime·mallocinit(void)
runtime·mheap.arena_end = runtime·mheap.arena_start + arena_size; runtime·mheap.arena_end = runtime·mheap.arena_start + arena_size;
// Initialize the rest of the allocator. // Initialize the rest of the allocator.
runtime·MHeap_Init(&runtime·mheap, runtime·SysAlloc); runtime·MHeap_Init(&runtime·mheap);
m->mcache = runtime·allocmcache(); m->mcache = runtime·allocmcache();
// See if it works. // See if it works.
......
...@@ -108,7 +108,7 @@ enum ...@@ -108,7 +108,7 @@ enum
// Tunable constants. // Tunable constants.
MaxSmallSize = 32<<10, MaxSmallSize = 32<<10,
FixAllocChunk = 128<<10, // Chunk size for FixAlloc FixAllocChunk = 16<<10, // Chunk size for FixAlloc
MaxMHeapList = 1<<(20 - PageShift), // Maximum page length for fixed-size list in MHeap. MaxMHeapList = 1<<(20 - PageShift), // Maximum page length for fixed-size list in MHeap.
HeapAllocChunk = 1<<20, // Chunk size for heap growth HeapAllocChunk = 1<<20, // Chunk size for heap growth
...@@ -188,7 +188,6 @@ void* runtime·SysReserve(void *v, uintptr nbytes); ...@@ -188,7 +188,6 @@ void* runtime·SysReserve(void *v, uintptr nbytes);
struct FixAlloc struct FixAlloc
{ {
uintptr size; uintptr size;
void *(*alloc)(uintptr);
void (*first)(void *arg, byte *p); // called first time p is returned void (*first)(void *arg, byte *p); // called first time p is returned
void *arg; void *arg;
MLink *list; MLink *list;
...@@ -198,7 +197,7 @@ struct FixAlloc ...@@ -198,7 +197,7 @@ struct FixAlloc
uintptr sys; // bytes obtained from system uintptr sys; // bytes obtained from system
}; };
void runtime·FixAlloc_Init(FixAlloc *f, uintptr size, void *(*alloc)(uintptr), void (*first)(void*, byte*), void *arg); void runtime·FixAlloc_Init(FixAlloc *f, uintptr size, void (*first)(void*, byte*), void *arg);
void* runtime·FixAlloc_Alloc(FixAlloc *f); void* runtime·FixAlloc_Alloc(FixAlloc *f);
void runtime·FixAlloc_Free(FixAlloc *f, void *p); void runtime·FixAlloc_Free(FixAlloc *f, void *p);
...@@ -432,7 +431,7 @@ struct MHeap ...@@ -432,7 +431,7 @@ struct MHeap
}; };
extern MHeap runtime·mheap; extern MHeap runtime·mheap;
void runtime·MHeap_Init(MHeap *h, void *(*allocator)(uintptr)); void runtime·MHeap_Init(MHeap *h);
MSpan* runtime·MHeap_Alloc(MHeap *h, uintptr npage, int32 sizeclass, int32 acct, int32 zeroed); MSpan* runtime·MHeap_Alloc(MHeap *h, uintptr npage, int32 sizeclass, int32 acct, int32 zeroed);
void runtime·MHeap_Free(MHeap *h, MSpan *s, int32 acct); void runtime·MHeap_Free(MHeap *h, MSpan *s, int32 acct);
MSpan* runtime·MHeap_Lookup(MHeap *h, void *v); MSpan* runtime·MHeap_Lookup(MHeap *h, void *v);
......
...@@ -13,10 +13,9 @@ ...@@ -13,10 +13,9 @@
// Initialize f to allocate objects of the given size, // Initialize f to allocate objects of the given size,
// using the allocator to obtain chunks of memory. // using the allocator to obtain chunks of memory.
void void
runtime·FixAlloc_Init(FixAlloc *f, uintptr size, void *(*alloc)(uintptr), void (*first)(void*, byte*), void *arg) runtime·FixAlloc_Init(FixAlloc *f, uintptr size, void (*first)(void*, byte*), void *arg)
{ {
f->size = size; f->size = size;
f->alloc = alloc;
f->first = first; f->first = first;
f->arg = arg; f->arg = arg;
f->list = nil; f->list = nil;
...@@ -44,9 +43,7 @@ runtime·FixAlloc_Alloc(FixAlloc *f) ...@@ -44,9 +43,7 @@ runtime·FixAlloc_Alloc(FixAlloc *f)
} }
if(f->nchunk < f->size) { if(f->nchunk < f->size) {
f->sys += FixAllocChunk; f->sys += FixAllocChunk;
f->chunk = f->alloc(FixAllocChunk); f->chunk = runtime·persistentalloc(FixAllocChunk, 0);
if(f->chunk == nil)
runtime·throw("out of memory (FixAlloc)");
f->nchunk = FixAllocChunk; f->nchunk = FixAllocChunk;
} }
v = f->chunk; v = f->chunk;
......
...@@ -51,12 +51,12 @@ RecordSpan(void *vh, byte *p) ...@@ -51,12 +51,12 @@ RecordSpan(void *vh, byte *p)
// Initialize the heap; fetch memory using alloc. // Initialize the heap; fetch memory using alloc.
void void
runtime·MHeap_Init(MHeap *h, void *(*alloc)(uintptr)) runtime·MHeap_Init(MHeap *h)
{ {
uint32 i; uint32 i;
runtime·FixAlloc_Init(&h->spanalloc, sizeof(MSpan), alloc, RecordSpan, h); runtime·FixAlloc_Init(&h->spanalloc, sizeof(MSpan), RecordSpan, h);
runtime·FixAlloc_Init(&h->cachealloc, sizeof(MCache), alloc, nil, nil); runtime·FixAlloc_Init(&h->cachealloc, sizeof(MCache), nil, nil);
// h->mapcache needs no init // h->mapcache needs no init
for(i=0; i<nelem(h->free); i++) for(i=0; i<nelem(h->free); i++)
runtime·MSpanList_Init(&h->free[i]); runtime·MSpanList_Init(&h->free[i]);
......
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