|
@@ -2,6 +2,7 @@
|
|
|
package thread;
|
|
|
|
|
|
import "core:runtime"
|
|
|
+import "core:intrinsics"
|
|
|
import "core:sync"
|
|
|
import "core:sys/unix"
|
|
|
|
|
@@ -40,15 +41,6 @@ Thread_Priority :: enum {
|
|
|
// Creates a thread which will run the given procedure.
|
|
|
// It then waits for `start` to be called.
|
|
|
//
|
|
|
-// You may provide a slice of bytes to use as the stack for the new thread,
|
|
|
-// but if you do, you are expected to set up the guard pages yourself.
|
|
|
-//
|
|
|
-// The stack must also be aligned appropriately for the platform.
|
|
|
-// We require it's at least 16 bytes aligned to help robustness; other
|
|
|
-// platforms may require page-size alignment.
|
|
|
-// Note also that pthreads requires the stack is at least 6 OS pages in size:
|
|
|
-// 4 are required by pthreads, and two extra for guards pages that will be applied.
|
|
|
-//
|
|
|
create :: proc(procedure: Thread_Proc, priority := Thread_Priority.Normal) -> ^Thread {
|
|
|
__linux_thread_entry_proc :: proc "c" (t: rawptr) -> rawptr {
|
|
|
t := (^Thread)(t);
|
|
@@ -134,7 +126,7 @@ join :: proc(t: ^Thread) {
|
|
|
if sync.atomic_swap(&t.already_joined, true, .Sequentially_Consistent) {
|
|
|
for {
|
|
|
if sync.atomic_load(&t.done, .Sequentially_Consistent) do return;
|
|
|
- sync.yield_processor();
|
|
|
+ intrinsics.cpu_relax();
|
|
|
}
|
|
|
}
|
|
|
|