// Copyright 2018 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 (
	
)

// Don't split the stack as this function may be invoked without a valid G,
// which prevents us from allocating more stack.
//go:nosplit
func ( uintptr,  *sysMemStat) unsafe.Pointer {
	,  := mmap(nil, , _PROT_READ|_PROT_WRITE, _MAP_ANON|_MAP_PRIVATE, -1, 0)
	if  != 0 {
		return nil
	}
	.add(int64())
	return 
}

func ( unsafe.Pointer,  uintptr) {
	// MADV_FREE_REUSABLE is like MADV_FREE except it also propagates
	// accounting information about the process to task_info.
	madvise(, , _MADV_FREE_REUSABLE)
}

func ( unsafe.Pointer,  uintptr) {
	// MADV_FREE_REUSE is necessary to keep the kernel's accounting
	// accurate. If called on any memory region that hasn't been
	// MADV_FREE_REUSABLE'd, it's a no-op.
	madvise(, , _MADV_FREE_REUSE)
}

func ( unsafe.Pointer,  uintptr) {
}

// Don't split the stack as this function may be invoked without a valid G,
// which prevents us from allocating more stack.
//go:nosplit
func ( unsafe.Pointer,  uintptr,  *sysMemStat) {
	.add(-int64())
	munmap(, )
}

func ( unsafe.Pointer,  uintptr) {
	mmap(, , _PROT_NONE, _MAP_ANON|_MAP_PRIVATE|_MAP_FIXED, -1, 0)
}

func ( unsafe.Pointer,  uintptr) unsafe.Pointer {
	,  := mmap(, , _PROT_NONE, _MAP_ANON|_MAP_PRIVATE, -1, 0)
	if  != 0 {
		return nil
	}
	return 
}

const _ENOMEM = 12

func ( unsafe.Pointer,  uintptr,  *sysMemStat) {
	.add(int64())

	,  := mmap(, , _PROT_READ|_PROT_WRITE, _MAP_ANON|_MAP_FIXED|_MAP_PRIVATE, -1, 0)
	if  == _ENOMEM {
		throw("runtime: out of memory")
	}
	if  !=  ||  != 0 {
		throw("runtime: cannot map pages in arena address space")
	}
}