primitives_windows.odin 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. //+build windows
  2. //+private
  3. package sync
  4. import "core:time"
  5. import win32 "core:sys/windows"
  6. _current_thread_id :: proc "contextless" () -> int {
  7. return int(win32.GetCurrentThreadId())
  8. }
  9. _Mutex :: struct {
  10. srwlock: win32.SRWLOCK,
  11. }
  12. _mutex_lock :: proc "contextless" (m: ^Mutex) {
  13. win32.AcquireSRWLockExclusive(&m.impl.srwlock)
  14. }
  15. _mutex_unlock :: proc "contextless" (m: ^Mutex) {
  16. win32.ReleaseSRWLockExclusive(&m.impl.srwlock)
  17. }
  18. _mutex_try_lock :: proc "contextless" (m: ^Mutex) -> bool {
  19. return bool(win32.TryAcquireSRWLockExclusive(&m.impl.srwlock))
  20. }
  21. _RW_Mutex :: struct {
  22. srwlock: win32.SRWLOCK,
  23. }
  24. _rw_mutex_lock :: proc "contextless" (rw: ^RW_Mutex) {
  25. win32.AcquireSRWLockExclusive(&rw.impl.srwlock)
  26. }
  27. _rw_mutex_unlock :: proc "contextless" (rw: ^RW_Mutex) {
  28. win32.ReleaseSRWLockExclusive(&rw.impl.srwlock)
  29. }
  30. _rw_mutex_try_lock :: proc "contextless" (rw: ^RW_Mutex) -> bool {
  31. return bool(win32.TryAcquireSRWLockExclusive(&rw.impl.srwlock))
  32. }
  33. _rw_mutex_shared_lock :: proc "contextless" (rw: ^RW_Mutex) {
  34. win32.AcquireSRWLockShared(&rw.impl.srwlock)
  35. }
  36. _rw_mutex_shared_unlock :: proc "contextless" (rw: ^RW_Mutex) {
  37. win32.ReleaseSRWLockShared(&rw.impl.srwlock)
  38. }
  39. _rw_mutex_try_shared_lock :: proc "contextless" (rw: ^RW_Mutex) -> bool {
  40. return bool(win32.TryAcquireSRWLockShared(&rw.impl.srwlock))
  41. }
  42. _Cond :: struct {
  43. cond: win32.CONDITION_VARIABLE,
  44. }
  45. _cond_wait :: proc "contextless" (c: ^Cond, m: ^Mutex) {
  46. _ = win32.SleepConditionVariableSRW(&c.impl.cond, &m.impl.srwlock, win32.INFINITE, 0)
  47. }
  48. _cond_wait_with_timeout :: proc "contextless" (c: ^Cond, m: ^Mutex, duration: time.Duration) -> bool {
  49. duration := u32(duration / time.Millisecond)
  50. ok := win32.SleepConditionVariableSRW(&c.impl.cond, &m.impl.srwlock, duration, 0)
  51. return bool(ok)
  52. }
  53. _cond_signal :: proc "contextless" (c: ^Cond) {
  54. win32.WakeConditionVariable(&c.impl.cond)
  55. }
  56. _cond_broadcast :: proc "contextless" (c: ^Cond) {
  57. win32.WakeAllConditionVariable(&c.impl.cond)
  58. }