mirror of
https://github.com/golang/go
synced 2024-11-19 12:14:42 -07:00
71 lines
1.4 KiB
Go
71 lines
1.4 KiB
Go
|
// 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.
|
||
|
|
||
|
package runtime
|
||
|
|
||
|
import "unsafe"
|
||
|
|
||
|
var bloc uintptr
|
||
|
var memlock mutex
|
||
|
|
||
|
const memRound = _PAGESIZE - 1
|
||
|
|
||
|
func initBloc() {
|
||
|
bloc = uintptr(unsafe.Pointer(&end))
|
||
|
}
|
||
|
|
||
|
func sbrk(n uintptr) unsafe.Pointer {
|
||
|
lock(&memlock)
|
||
|
// Plan 9 sbrk from /sys/src/libc/9sys/sbrk.c
|
||
|
bl := (bloc + memRound) &^ memRound
|
||
|
if brk_(unsafe.Pointer(bl+n)) < 0 {
|
||
|
unlock(&memlock)
|
||
|
return nil
|
||
|
}
|
||
|
bloc = bl + n
|
||
|
unlock(&memlock)
|
||
|
return unsafe.Pointer(bl)
|
||
|
}
|
||
|
|
||
|
func sysAlloc(n uintptr, stat *uint64) unsafe.Pointer {
|
||
|
p := sbrk(n)
|
||
|
if p != nil {
|
||
|
xadd64(stat, int64(n))
|
||
|
}
|
||
|
return p
|
||
|
}
|
||
|
|
||
|
func sysFree(v unsafe.Pointer, n uintptr, stat *uint64) {
|
||
|
xadd64(stat, -int64(n))
|
||
|
lock(&memlock)
|
||
|
// from tiny/mem.c
|
||
|
// Push pointer back if this is a free
|
||
|
// of the most recent sysAlloc.
|
||
|
n += (n + memRound) &^ memRound
|
||
|
if bloc == uintptr(v)+n {
|
||
|
bloc -= n
|
||
|
}
|
||
|
unlock(&memlock)
|
||
|
}
|
||
|
|
||
|
func sysUnused(v unsafe.Pointer, n uintptr) {
|
||
|
}
|
||
|
|
||
|
func sysUsed(v unsafe.Pointer, n uintptr) {
|
||
|
}
|
||
|
|
||
|
func sysMap(v unsafe.Pointer, n uintptr, reserved bool, stat *uint64) {
|
||
|
// sysReserve has already allocated all heap memory,
|
||
|
// but has not adjusted stats.
|
||
|
xadd64(stat, int64(n))
|
||
|
}
|
||
|
|
||
|
func sysFault(v unsafe.Pointer, n uintptr) {
|
||
|
}
|
||
|
|
||
|
func sysReserve(v unsafe.Pointer, n uintptr, reserved *bool) unsafe.Pointer {
|
||
|
*reserved = true
|
||
|
return sbrk(n)
|
||
|
}
|