165 lines
3.2 KiB
Go
165 lines
3.2 KiB
Go
// 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.
|
|
|
|
//go:build js && wasm
|
|
|
|
package runtime
|
|
|
|
import (
|
|
"unsafe"
|
|
)
|
|
|
|
func exit(code int32)
|
|
|
|
func write1(fd uintptr, p unsafe.Pointer, n int32) int32 {
|
|
if fd > 2 {
|
|
throw("runtime.write to fd > 2 is unsupported")
|
|
}
|
|
wasmWrite(fd, p, n)
|
|
return n
|
|
}
|
|
|
|
// Stubs so tests can link correctly. These should never be called.
|
|
func open(name *byte, mode, perm int32) int32 { panic("not implemented") }
|
|
func closefd(fd int32) int32 { panic("not implemented") }
|
|
func read(fd int32, p unsafe.Pointer, n int32) int32 { panic("not implemented") }
|
|
|
|
//go:noescape
|
|
func wasmWrite(fd uintptr, p unsafe.Pointer, n int32)
|
|
|
|
func usleep(usec uint32)
|
|
|
|
//go:nosplit
|
|
func usleep_no_g(usec uint32) {
|
|
usleep(usec)
|
|
}
|
|
|
|
func exitThread(wait *uint32)
|
|
|
|
type mOS struct{}
|
|
|
|
func osyield()
|
|
|
|
//go:nosplit
|
|
func osyield_no_g() {
|
|
osyield()
|
|
}
|
|
|
|
const _SIGSEGV = 0xb
|
|
|
|
func sigpanic() {
|
|
g := getg()
|
|
if !canpanic(g) {
|
|
throw("unexpected signal during runtime execution")
|
|
}
|
|
|
|
// js only invokes the exception handler for memory faults.
|
|
g.sig = _SIGSEGV
|
|
panicmem()
|
|
}
|
|
|
|
type sigset struct{}
|
|
|
|
// Called to initialize a new m (including the bootstrap m).
|
|
// Called on the parent thread (main thread in case of bootstrap), can allocate memory.
|
|
func mpreinit(mp *m) {
|
|
mp.gsignal = malg(32 * 1024)
|
|
mp.gsignal.m = mp
|
|
}
|
|
|
|
//go:nosplit
|
|
func sigsave(p *sigset) {
|
|
}
|
|
|
|
//go:nosplit
|
|
func msigrestore(sigmask sigset) {
|
|
}
|
|
|
|
//go:nosplit
|
|
//go:nowritebarrierrec
|
|
func clearSignalHandlers() {
|
|
}
|
|
|
|
//go:nosplit
|
|
func sigblock(exiting bool) {
|
|
}
|
|
|
|
// Called to initialize a new m (including the bootstrap m).
|
|
// Called on the new thread, cannot allocate memory.
|
|
func minit() {
|
|
}
|
|
|
|
// Called from dropm to undo the effect of an minit.
|
|
func unminit() {
|
|
}
|
|
|
|
// Called from exitm, but not from drop, to undo the effect of thread-owned
|
|
// resources in minit, semacreate, or elsewhere. Do not take locks after calling this.
|
|
func mdestroy(mp *m) {
|
|
}
|
|
|
|
func osinit() {
|
|
ncpu = 1
|
|
getg().m.procid = 2
|
|
physPageSize = 64 * 1024
|
|
}
|
|
|
|
// wasm has no signals
|
|
const _NSIG = 0
|
|
|
|
func signame(sig uint32) string {
|
|
return ""
|
|
}
|
|
|
|
func crash() {
|
|
*(*int32)(nil) = 0
|
|
}
|
|
|
|
func getRandomData(r []byte)
|
|
|
|
func goenvs() {
|
|
goenvs_unix()
|
|
}
|
|
|
|
func initsig(preinit bool) {
|
|
}
|
|
|
|
// May run with m.p==nil, so write barriers are not allowed.
|
|
//go:nowritebarrier
|
|
func newosproc(mp *m) {
|
|
panic("newosproc: not implemented")
|
|
}
|
|
|
|
func setProcessCPUProfiler(hz int32) {}
|
|
func setThreadCPUProfiler(hz int32) {}
|
|
func sigdisable(uint32) {}
|
|
func sigenable(uint32) {}
|
|
func sigignore(uint32) {}
|
|
|
|
//go:linkname os_sigpipe os.sigpipe
|
|
func os_sigpipe() {
|
|
throw("too many writes on closed pipe")
|
|
}
|
|
|
|
//go:nosplit
|
|
func cputicks() int64 {
|
|
// Currently cputicks() is used in blocking profiler and to seed runtime·fastrand().
|
|
// runtime·nanotime() is a poor approximation of CPU ticks that is enough for the profiler.
|
|
return nanotime()
|
|
}
|
|
|
|
//go:linkname syscall_now syscall.now
|
|
func syscall_now() (sec int64, nsec int32) {
|
|
sec, nsec, _ = time_now()
|
|
return
|
|
}
|
|
|
|
// gsignalStack is unused on js.
|
|
type gsignalStack struct{}
|
|
|
|
const preemptMSupported = false
|
|
|
|
func preemptM(mp *m) {
|
|
// No threads, so nothing to do.
|
|
}
|