diff options
| author | Tianon Gravi <admwiggin@gmail.com> | 2015-01-15 11:54:00 -0700 | 
|---|---|---|
| committer | Tianon Gravi <admwiggin@gmail.com> | 2015-01-15 11:54:00 -0700 | 
| commit | f154da9e12608589e8d5f0508f908a0c3e88a1bb (patch) | |
| tree | f8255d51e10c6f1e0ed69702200b966c9556a431 /src/runtime/mem_openbsd.c | |
| parent | 8d8329ed5dfb9622c82a9fbec6fd99a580f9c9f6 (diff) | |
| download | golang-f154da9e12608589e8d5f0508f908a0c3e88a1bb.tar.gz | |
Imported Upstream version 1.4upstream/1.4
Diffstat (limited to 'src/runtime/mem_openbsd.c')
| -rw-r--r-- | src/runtime/mem_openbsd.c | 100 | 
1 files changed, 100 insertions, 0 deletions
| diff --git a/src/runtime/mem_openbsd.c b/src/runtime/mem_openbsd.c new file mode 100644 index 000000000..31820e517 --- /dev/null +++ b/src/runtime/mem_openbsd.c @@ -0,0 +1,100 @@ +// Copyright 2010 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. + +#include "runtime.h" +#include "arch_GOARCH.h" +#include "defs_GOOS_GOARCH.h" +#include "os_GOOS.h" +#include "malloc.h" +#include "textflag.h" + +enum +{ +	ENOMEM = 12, +}; + +#pragma textflag NOSPLIT +void* +runtime·sysAlloc(uintptr n, uint64 *stat) +{ +	void *v; + +	v = runtime·mmap(nil, n, PROT_READ|PROT_WRITE, MAP_ANON|MAP_PRIVATE, -1, 0); +	if(v < (void*)4096) +		return nil; +	runtime·xadd64(stat, n); +	return v; +} + +void +runtime·SysUnused(void *v, uintptr n) +{ +	runtime·madvise(v, n, MADV_FREE); +} + +void +runtime·SysUsed(void *v, uintptr n) +{ +	USED(v); +	USED(n); +} + +void +runtime·SysFree(void *v, uintptr n, uint64 *stat) +{ +	runtime·xadd64(stat, -(uint64)n); +	runtime·munmap(v, n); +} + +void +runtime·SysFault(void *v, uintptr n) +{ +	runtime·mmap(v, n, PROT_NONE, MAP_ANON|MAP_PRIVATE|MAP_FIXED, -1, 0); +} + +void* +runtime·SysReserve(void *v, uintptr n, bool *reserved) +{ +	void *p; + +	// On 64-bit, people with ulimit -v set complain if we reserve too +	// much address space.  Instead, assume that the reservation is okay +	// and check the assumption in SysMap. +	if(sizeof(void*) == 8 && n > 1LL<<32) { +		*reserved = false; +		return v; +	} + +	p = runtime·mmap(v, n, PROT_NONE, MAP_ANON|MAP_PRIVATE, -1, 0); +	if(p < (void*)4096) +		return nil; +	*reserved = true; +	return p; +} + +void +runtime·SysMap(void *v, uintptr n, bool reserved, uint64 *stat) +{ +	void *p; +	 +	runtime·xadd64(stat, n); + +	// On 64-bit, we don't actually have v reserved, so tread carefully. +	if(!reserved) { +		p = runtime·mmap(v, n, PROT_READ|PROT_WRITE, MAP_ANON|MAP_PRIVATE, -1, 0); +		if(p == (void*)ENOMEM) +			runtime·throw("runtime: out of memory"); +		if(p != v) { +			runtime·printf("runtime: address space conflict: map(%p) = %p\n", v, p); +			runtime·throw("runtime: address space conflict"); +		} +		return; +	} + +	p = runtime·mmap(v, n, PROT_READ|PROT_WRITE, MAP_ANON|MAP_FIXED|MAP_PRIVATE, -1, 0); +	if(p == (void*)ENOMEM) +		runtime·throw("runtime: out of memory"); +	if(p != v) +		runtime·throw("runtime: cannot map pages in arena address space"); +} | 
