2 * This module contains allocation functions for the garbage collector.
4 * Copyright: Copyright (C) 2005-2006 Digital Mars, www.digitalmars.com.
7 * This software is provided 'as-is', without any express or implied
8 * warranty. In no event will the authors be held liable for any damages
9 * arising from the use of this software.
11 * Permission is granted to anyone to use this software for any purpose,
12 * including commercial applications, and to alter it and redistribute it
13 * freely, in both source and binary form, subject to the following
16 * o The origin of this software must not be misrepresented; you must not
17 * claim that you wrote the original software. If you use this software
18 * in a product, an acknowledgment in the product documentation would be
19 * appreciated but is not required.
20 * o Altered source versions must be plainly marked as such, and must not
21 * be misrepresented as being the original software.
22 * o This notice may not be removed or altered from any source
24 * Authors: Walter Bright, David Friedman, Sean Kelly
32 private import core.sys.windows.windows;
36 pthread_t pthread_self()
38 return cast(pthread_t) GetCurrentThreadId();
41 //version = GC_Use_Alloc_Win32;
45 private import core.sys.posix.sys.mman;
46 private import core.stdc.stdlib;
48 //version = GC_Use_Alloc_MMap;
52 private import core.stdc.stdlib;
54 //version = GC_Use_Alloc_Malloc;
58 static if(is(typeof(VirtualAlloc)))
59 version = GC_Use_Alloc_Win32;
60 else static if (is(typeof(mmap)))
61 version = GC_Use_Alloc_MMap;
62 else static if (is(typeof(valloc)))
63 version = GC_Use_Alloc_Valloc;
64 else static if (is(typeof(malloc)))
65 version = GC_Use_Alloc_Malloc;
66 else static assert(false, "No supported allocation methods available.");
69 static if (is(typeof(VirtualAlloc))) // version (GC_Use_Alloc_Win32)
74 void *os_mem_map(size_t nbytes)
76 return VirtualAlloc(null, nbytes, MEM_RESERVE, PAGE_READWRITE);
86 int os_mem_commit(void *base, size_t offset, size_t nbytes)
89 p = VirtualAlloc(base + offset, nbytes, MEM_COMMIT, PAGE_READWRITE);
90 return cast(int)(p is null);
100 int os_mem_decommit(void *base, size_t offset, size_t nbytes)
102 return cast(int)(VirtualFree(base + offset, nbytes, MEM_DECOMMIT) == 0);
107 * Unmap memory allocated with os_mem_map().
108 * Memory must have already been decommitted.
113 int os_mem_unmap(void *base, size_t nbytes)
115 return cast(int)(VirtualFree(base, 0, MEM_RELEASE) == 0);
118 else static if (is(typeof(mmap))) // else version (GC_Use_Alloc_MMap)
120 void *os_mem_map(size_t nbytes)
123 p = mmap(null, nbytes, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANON, -1, 0);
124 return (p == MAP_FAILED) ? null : p;
128 int os_mem_commit(void *base, size_t offset, size_t nbytes)
134 int os_mem_decommit(void *base, size_t offset, size_t nbytes)
140 int os_mem_unmap(void *base, size_t nbytes)
142 return munmap(base, nbytes);
145 else static if (is(typeof(valloc))) // else version (GC_Use_Alloc_Valloc)
147 void *os_mem_map(size_t nbytes)
149 return valloc(nbytes);
153 int os_mem_commit(void *base, size_t offset, size_t nbytes)
159 int os_mem_decommit(void *base, size_t offset, size_t nbytes)
165 int os_mem_unmap(void *base, size_t nbytes)
171 else static if (is(typeof(malloc))) // else version (GC_Use_Alloc_Malloc)
173 // NOTE: This assumes malloc granularity is at least (void*).sizeof. If
174 // (req_size + PAGESIZE) is allocated, and the pointer is rounded up
175 // to PAGESIZE alignment, there will be space for a void* at the end
176 // after PAGESIZE bytes used by the GC.
179 private import gcx : PAGESIZE;
182 const size_t PAGE_MASK = PAGESIZE - 1;
185 void *os_mem_map(size_t nbytes)
187 p = cast(byte *) malloc(nbytes + PAGESIZE);
188 q = p + ((PAGESIZE - ((cast(size_t) p & PAGE_MASK))) & PAGE_MASK);
189 * cast(void**)(q + nbytes) = p;
194 int os_mem_commit(void *base, size_t offset, size_t nbytes)
200 int os_mem_decommit(void *base, size_t offset, size_t nbytes)
206 int os_mem_unmap(void *base, size_t nbytes)
208 free( *cast(void**)( cast(byte*) base + nbytes ) );
214 static assert(false, "No supported allocation methods available.");