1// Copyright 2012 The Go Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style
3// license that can be found in the LICENSE file.
4
5package sync
6
7import "unsafe"
8
9// defined in package runtime
10
11// Semacquire waits until *s > 0 and then atomically decrements it.
12// It is intended as a simple sleep primitive for use by the synchronization
13// library and should not be used directly.
14func runtime_Semacquire(s *uint32)
15
16// Semacquire(RW)Mutex(R) is like Semacquire, but for profiling contended
17// Mutexes and RWMutexes.
18// If lifo is true, queue waiter at the head of wait queue.
19// skipframes is the number of frames to omit during tracing, counting from
20// runtime_SemacquireMutex's caller.
21// The different forms of this function just tell the runtime how to present
22// the reason for waiting in a backtrace, and is used to compute some metrics.
23// Otherwise they're functionally identical.
24func runtime_SemacquireMutex(s *uint32, lifo bool, skipframes int)
25func runtime_SemacquireRWMutexR(s *uint32, lifo bool, skipframes int)
26func runtime_SemacquireRWMutex(s *uint32, lifo bool, skipframes int)
27
28// Semrelease atomically increments *s and notifies a waiting goroutine
29// if one is blocked in Semacquire.
30// It is intended as a simple wakeup primitive for use by the synchronization
31// library and should not be used directly.
32// If handoff is true, pass count directly to the first waiter.
33// skipframes is the number of frames to omit during tracing, counting from
34// runtime_Semrelease's caller.
35func runtime_Semrelease(s *uint32, handoff bool, skipframes int)
36
37// See runtime/sema.go for documentation.
38func runtime_notifyListAdd(l *notifyList) uint32
39
40// See runtime/sema.go for documentation.
41func runtime_notifyListWait(l *notifyList, t uint32)
42
43// See runtime/sema.go for documentation.
44func runtime_notifyListNotifyAll(l *notifyList)
45
46// See runtime/sema.go for documentation.
47func runtime_notifyListNotifyOne(l *notifyList)
48
49// Ensure that sync and runtime agree on size of notifyList.
50func runtime_notifyListCheck(size uintptr)
51func init() {
52	var n notifyList
53	runtime_notifyListCheck(unsafe.Sizeof(n))
54}
55
56// Active spinning runtime support.
57// runtime_canSpin reports whether spinning makes sense at the moment.
58func runtime_canSpin(i int) bool
59
60// runtime_doSpin does active spinning.
61func runtime_doSpin()
62
63func runtime_nanotime() int64
64