ref: d8bd5599e0e4b7919e3987ad80cb39f4a8aff63d
parent: 74389e559a91db698364664797e3819302a15836
author: Ori Bernstein <[email protected]>
date: Mon Jan 18 17:56:58 EST 2016
Add a broken spawn+osx.myr It works under dtruss...
--- a/lib/thread/bld.proj
+++ b/lib/thread/bld.proj
@@ -14,6 +14,12 @@
spawn+freebsd.myr
exit+freebsd-x64.s
+ # osx impl of thread primitives
+ #condvar+osx.myr
+ #mutex+osx.myr
+ spawn+osx.myr
+ #exit+osx-x64.s
+
# 9front impl of thread primitives
#condvar+plan9.myr
mutex+plan9.myr
--- /dev/null
+++ b/lib/thread/spawn+osx.myr
@@ -1,0 +1,40 @@
+use sys
+use std
+
+pkg thread =
+ type tid = uint64
+
+ const spawn : (fn : (-> void) -> std.result(tid, byte[:]))
+;;
+
+
+const Stacksz = 8*std.MiB
+extern const exit : (-> void)
+
+const spawn = {fn
+ -> spawnstk(fn, Stacksz)
+}
+
+const spawnstk = {fn, sz
+ var tid : tid, ret
+
+
+ ret = sys.bsdthread_create( \
+ startthread castto(void#), \
+ &fn castto(void#), \
+ sz castto(void#), \
+ &tid castto(void#), \
+ 0)
+
+ if ret == -1 castto(void#)
+ -> `std.Fail "couldn't spawn thread"
+ ;;
+ -> `std.Ok tid castto(tid)
+}
+
+const startthread = {fn : (-> void)# -> void
+ fn#()
+ std.write(1, "...bye mom\n")
+ sys.bsdthread_terminate(0 castto(void#), 0, 0, 0)
+}
+