diff options
| author | Ondřej Surý <ondrej@sury.org> | 2011-02-14 13:23:51 +0100 | 
|---|---|---|
| committer | Ondřej Surý <ondrej@sury.org> | 2011-02-14 13:23:51 +0100 | 
| commit | 758ff64c69e34965f8af5b2d6ffd65e8d7ab2150 (patch) | |
| tree | 6d6b34f8c678862fe9b56c945a7b63f68502c245 /src/pkg/runtime/mheapmap32.c | |
| parent | 3e45412327a2654a77944249962b3652e6142299 (diff) | |
| download | golang-758ff64c69e34965f8af5b2d6ffd65e8d7ab2150.tar.gz | |
Imported Upstream version 2011-02-01.1upstream/2011-02-01.1
Diffstat (limited to 'src/pkg/runtime/mheapmap32.c')
| -rw-r--r-- | src/pkg/runtime/mheapmap32.c | 96 | 
1 files changed, 0 insertions, 96 deletions
| diff --git a/src/pkg/runtime/mheapmap32.c b/src/pkg/runtime/mheapmap32.c deleted file mode 100644 index 323f8b87a..000000000 --- a/src/pkg/runtime/mheapmap32.c +++ /dev/null @@ -1,96 +0,0 @@ -// 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. - -// Heap map, 32-bit version -// See malloc.h and mheap.c for overview. - -#include "runtime.h" -#include "malloc.h" - -// 3-level radix tree mapping page ids to Span*. -void -runtime·MHeapMap_Init(MHeapMap *m, void *(*allocator)(uintptr)) -{ -	m->allocator = allocator; -} - -MSpan* -runtime·MHeapMap_Get(MHeapMap *m, PageID k) -{ -	int32 i1, i2; - -	i2 = k & MHeapMap_Level2Mask; -	k >>= MHeapMap_Level2Bits; -	i1 = k & MHeapMap_Level1Mask; -	k >>= MHeapMap_Level1Bits; -	if(k != 0) -		runtime·throw("MHeapMap_Get"); - -	return m->p[i1]->s[i2]; -} - -MSpan* -runtime·MHeapMap_GetMaybe(MHeapMap *m, PageID k) -{ -	int32 i1, i2; -	MHeapMapNode2 *p2; - -	i2 = k & MHeapMap_Level2Mask; -	k >>= MHeapMap_Level2Bits; -	i1 = k & MHeapMap_Level1Mask; -	k >>= MHeapMap_Level1Bits; -	if(k != 0) -		runtime·throw("MHeapMap_Get"); - -	p2 = m->p[i1]; -	if(p2 == nil) -		return nil; -	return p2->s[i2]; -} - -void -runtime·MHeapMap_Set(MHeapMap *m, PageID k, MSpan *s) -{ -	int32 i1, i2; - -	i2 = k & MHeapMap_Level2Mask; -	k >>= MHeapMap_Level2Bits; -	i1 = k & MHeapMap_Level1Mask; -	k >>= MHeapMap_Level1Bits; -	if(k != 0) -		runtime·throw("MHeapMap_Set"); - -	m->p[i1]->s[i2] = s; -} - -// Allocate the storage required for entries [k, k+1, ..., k+len-1] -// so that Get and Set calls need not check for nil pointers. -bool -runtime·MHeapMap_Preallocate(MHeapMap *m, PageID k, uintptr len) -{ -	uintptr end; -	int32 i1; -	MHeapMapNode2 *p2; - -	end = k+len; -	while(k < end) { -		if((k >> MHeapMap_TotalBits) != 0) -			return false; -		i1 = (k >> MHeapMap_Level2Bits) & MHeapMap_Level1Mask; - -		// first-level pointer -		if(m->p[i1] == nil) { -			p2 = m->allocator(sizeof *p2); -			if(p2 == nil) -				return false; -			mstats.heapmap_sys += sizeof *p2; -			m->p[i1] = p2; -		} - -		// advance key past this leaf node -		k = ((k >> MHeapMap_Level2Bits) + 1) << MHeapMap_Level2Bits; -	} -	return true; -} - | 
