2016-09-30 13:45:08 +00:00
|
|
|
// Copyright 2009 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"
|
|
|
|
|
|
|
|
type mOS struct {
|
2018-09-24 21:46:21 +00:00
|
|
|
initialized bool
|
|
|
|
mutex pthreadmutex
|
|
|
|
cond pthreadcond
|
|
|
|
count int
|
2016-09-30 13:45:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func unimplemented(name string) {
|
|
|
|
println(name, "not implemented")
|
|
|
|
*(*int)(unsafe.Pointer(uintptr(1231))) = 1231
|
|
|
|
}
|
|
|
|
|
|
|
|
//go:nosplit
|
|
|
|
func semacreate(mp *m) {
|
2018-09-24 21:46:21 +00:00
|
|
|
if mp.initialized {
|
2016-09-30 13:45:08 +00:00
|
|
|
return
|
|
|
|
}
|
2018-09-24 21:46:21 +00:00
|
|
|
mp.initialized = true
|
|
|
|
if err := pthread_mutex_init(&mp.mutex, nil); err != 0 {
|
|
|
|
throw("pthread_mutex_init")
|
2016-09-30 13:45:08 +00:00
|
|
|
}
|
2018-09-24 21:46:21 +00:00
|
|
|
if err := pthread_cond_init(&mp.cond, nil); err != 0 {
|
|
|
|
throw("pthread_cond_init")
|
2016-09-30 13:45:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//go:nosplit
|
|
|
|
func semasleep(ns int64) int32 {
|
2018-10-08 14:21:30 +00:00
|
|
|
var start int64
|
|
|
|
if ns >= 0 {
|
|
|
|
start = nanotime()
|
|
|
|
}
|
2018-09-24 21:46:21 +00:00
|
|
|
mp := getg().m
|
|
|
|
pthread_mutex_lock(&mp.mutex)
|
2016-09-30 13:45:08 +00:00
|
|
|
for {
|
2018-09-24 21:46:21 +00:00
|
|
|
if mp.count > 0 {
|
|
|
|
mp.count--
|
|
|
|
pthread_mutex_unlock(&mp.mutex)
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
if ns >= 0 {
|
2018-10-08 14:21:30 +00:00
|
|
|
spent := nanotime() - start
|
|
|
|
if spent >= ns {
|
|
|
|
pthread_mutex_unlock(&mp.mutex)
|
|
|
|
return -1
|
|
|
|
}
|
2018-09-24 21:46:21 +00:00
|
|
|
var t timespec
|
2018-10-08 14:21:30 +00:00
|
|
|
t.set_nsec(ns - spent)
|
2018-09-24 21:46:21 +00:00
|
|
|
err := pthread_cond_timedwait_relative_np(&mp.cond, &mp.mutex, &t)
|
|
|
|
if err == _ETIMEDOUT {
|
|
|
|
pthread_mutex_unlock(&mp.mutex)
|
|
|
|
return -1
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
pthread_cond_wait(&mp.cond, &mp.mutex)
|
2016-09-30 13:45:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-24 21:46:21 +00:00
|
|
|
//go:nosplit
|
|
|
|
func semawakeup(mp *m) {
|
|
|
|
pthread_mutex_lock(&mp.mutex)
|
|
|
|
mp.count++
|
|
|
|
if mp.count > 0 {
|
|
|
|
pthread_cond_signal(&mp.cond)
|
|
|
|
}
|
|
|
|
pthread_mutex_unlock(&mp.mutex)
|
2016-09-30 13:45:08 +00:00
|
|
|
}
|