summaryrefslogtreecommitdiff
path: root/libgo/runtime/runtime1.goc
blob: 6d8f09a6c5f4ccb968759d76c8b45066dc810012 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// 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
#include "runtime.h"
#include "arch.h"
#include "go-type.h"

func GOMAXPROCS(n int) (ret int) {
	ret = runtime_gomaxprocsfunc(n);
}

func NumCPU() (ret int) {
	ret = runtime_ncpu;
}

func NumCgoCall() (ret int64) {
	M *mp;

	ret = 0;
	for(mp=runtime_atomicloadp(&runtime_allm); mp; mp=mp->alllink)
		ret += mp->ncgocall;
}

func newParFor(nthrmax uint32) (desc *ParFor) {
	desc = runtime_parforalloc(nthrmax);
}

func parForSetup(desc *ParFor, nthr uint32, n uint32, ctx *byte, wait bool, body *byte) {
	runtime_parforsetup(desc, nthr, n, ctx, wait, *(void(**)(ParFor*, uint32))body);
}

func parForDo(desc *ParFor) {
	runtime_parfordo(desc);
}

func parForIters(desc *ParFor, tid uintptr) (start uintptr, end uintptr) {
	runtime_parforiters(desc, tid, &start, &end);
}

func typestring(e Eface) (s String) {
	s = *e.__type_descriptor->__reflection;
}

func golockedOSThread() (ret bool) {
	ret = runtime_lockedOSThread();
}

func NumGoroutine() (ret int) {
	ret = runtime_gcount();
}

func getgoroot() (out String) {
	const byte *p;

	p = runtime_getenv("GOROOT");
	out = runtime_gostringnocopy(p);
}

func runtime_pprof.runtime_cyclesPerSecond() (res int64) {
	res = runtime_tickspersecond();
}

func sync.runtime_procPin() (p int) {
	M *mp;

	mp = runtime_m();
	// Disable preemption.
	mp->locks++;
	p = mp->p->id;
}

func sync.runtime_procUnpin() {
	runtime_m()->locks--;
}

func sync_atomic.runtime_procPin() (p int) {
	M *mp;

	mp = runtime_m();
	// Disable preemption.
	mp->locks++;
	p = mp->p->id;
}

func sync_atomic.runtime_procUnpin() {
	runtime_m()->locks--;
}