jack2 codebase
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

209 lines
6.3KB

  1. /*
  2. Copyright (C) 2004-2008 Grame
  3. This program is free software; you can redistribute it and/or modify
  4. it under the terms of the GNU Lesser General Public License as published by
  5. the Free Software Foundation; either version 2.1 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU Lesser General Public License for more details.
  11. You should have received a copy of the GNU Lesser General Public License
  12. along with this program; if not, write to the Free Software
  13. Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  14. */
  15. #include "JackWinProcessSync.h"
  16. #include "JackError.h"
  17. namespace Jack
  18. {
  19. void JackWinProcessSync::Signal()
  20. {
  21. if (!SetEvent(fEvent)) {
  22. jack_error("JackWinProcessSync::Signal SetEvent err = %d", GetLastError());
  23. }
  24. }
  25. void JackWinProcessSync::LockedSignal()
  26. {
  27. DWORD res = WaitForSingleObject(fMutex, INFINITE);
  28. if (res != WAIT_OBJECT_0) {
  29. jack_error("JackWinProcessSync::LockedSignal WaitForSingleObject err = %d", GetLastError());
  30. }
  31. if (!SetEvent(fEvent)) {
  32. jack_error("JackWinProcessSync::LockedSignal SetEvent err = %d", GetLastError());
  33. }
  34. if (!ReleaseMutex(fMutex)) {
  35. jack_error("JackWinProcessSync::LockedSignal ReleaseMutex err = %d", GetLastError());
  36. }
  37. }
  38. void JackWinProcessSync::SignalAll()
  39. {
  40. Signal();
  41. }
  42. void JackWinProcessSync::LockedSignalAll()
  43. {
  44. LockedSignal();
  45. }
  46. void JackWinProcessSync::Wait()
  47. {
  48. if (!ReleaseMutex(fMutex)) {
  49. jack_error("JackWinProcessSync::Wait ReleaseMutex err = %d", GetLastError());
  50. }
  51. DWORD res = WaitForSingleObject(fEvent, INFINITE);
  52. if (res != WAIT_OBJECT_0) {
  53. jack_error("JackWinProcessSync::Wait WaitForSingleObject err = %d", GetLastError());
  54. }
  55. }
  56. void JackWinProcessSync::LockedWait()
  57. {
  58. // Does it make sense on Windows, use non-locked version for now...
  59. Wait();
  60. }
  61. bool JackWinProcessSync::TimedWait(long usec)
  62. {
  63. if (!ReleaseMutex(fMutex)) {
  64. jack_error("JackWinProcessSync::TimedWait ReleaseMutex err = %d", GetLastError());
  65. }
  66. DWORD res = WaitForSingleObject(fEvent, usec / 1000);
  67. if (res != WAIT_OBJECT_0) {
  68. jack_error("JackWinProcessSync::TimedWait WaitForSingleObject err = %d", GetLastError());
  69. }
  70. return (res == WAIT_OBJECT_0);
  71. }
  72. bool JackWinProcessSync::LockedTimedWait(long usec)
  73. {
  74. // Does it make sense on Windows, use non-locked version for now...
  75. return TimedWait(usec);
  76. }
  77. /*
  78. // Code from APPLE CAGuard.cpp : does not seem to work as expected...
  79. void JackWinProcessSync::Wait()
  80. {
  81. if (!ReleaseMutex(fMutex)) {
  82. jack_error("JackWinProcessSync::Wait ReleaseMutex err = %d", GetLastError());
  83. }
  84. DWORD res = WaitForSingleObject(fEvent, INFINITE);
  85. if (res != WAIT_OBJECT_0) {
  86. jack_error("JackWinProcessSync::Wait WaitForSingleObject err = %d", GetLastError());
  87. }
  88. }
  89. // Variant that behaves differently depending of the mutex state
  90. void JackWinProcessSync::Wait()
  91. {
  92. if (ReleaseMutex(fMutex)) {
  93. HANDLE handles[] = { fMutex, fEvent };
  94. DWORD res = WaitForMultipleObjects(2, handles, true, INFINITE);
  95. if (res != WAIT_OBJECT_0) {
  96. jack_error("JackWinProcessSync::LockedWait WaitForMultipleObjects err = %d", GetLastError());
  97. }
  98. } else {
  99. jack_error("JackWinProcessSync::Wait ReleaseMutex err = %d", GetLastError());
  100. DWORD res = WaitForSingleObject(fEvent, INFINITE);
  101. if (res != WAIT_OBJECT_0) {
  102. jack_error("JackWinProcessSync::Wait WaitForSingleObject err = %d", GetLastError());
  103. }
  104. }
  105. if (!ResetEvent(fEvent)) {
  106. jack_error("JackWinProcessSync::LockedWait ResetEvent err = %d", GetLastError());
  107. }
  108. }
  109. void JackWinProcessSync::LockedWait()
  110. {
  111. if (!ReleaseMutex(fMutex)) {
  112. jack_error("JackWinProcessSync::LockedWait ReleaseMutex err = %d", GetLastError());
  113. }
  114. HANDLE handles[] = { fMutex, fEvent };
  115. DWORD res = WaitForMultipleObjects(2, handles, true, INFINITE);
  116. if (res != WAIT_OBJECT_0) {
  117. jack_error("JackWinProcessSync::LockedWait WaitForMultipleObjects err = %d", GetLastError());
  118. }
  119. if (!ResetEvent(fEvent)) {
  120. jack_error("JackWinProcessSync::LockedWait ResetEvent err = %d", GetLastError());
  121. }
  122. }
  123. bool JackWinProcessSync::TimedWait(long usec)
  124. {
  125. if (!ReleaseMutex(fMutex)) {
  126. jack_error("JackWinProcessSync::TimedWait ReleaseMutex err = %d", GetLastError());
  127. }
  128. DWORD res = WaitForSingleObject(fEvent, usec / 1000);
  129. if (res != WAIT_OBJECT_0) {
  130. jack_error("JackWinProcessSync::TimedWait WaitForSingleObject err = %d", GetLastError());
  131. }
  132. return (res == WAIT_OBJECT_0);
  133. }
  134. // Variant that behaves differently depending of the mutex state
  135. bool JackWinProcessSync::TimedWait(long usec)
  136. {
  137. if (ReleaseMutex(fMutex)) {
  138. HANDLE handles[] = { fMutex, fEvent };
  139. DWORD res = WaitForMultipleObjects(2, handles, true, usec / 1000);
  140. if ((res != WAIT_OBJECT_0) && (res != WAIT_TIMEOUT)) {
  141. jack_error("JackWinProcessSync::LockedTimedWait WaitForMultipleObjects err = %d", GetLastError());
  142. }
  143. } else {
  144. jack_error("JackWinProcessSync::TimedWait ReleaseMutex err = %d", GetLastError());
  145. DWORD res = WaitForSingleObject(fEvent, usec / 1000);
  146. if (res != WAIT_OBJECT_0) {
  147. jack_error("JackWinProcessSync::TimedWait WaitForSingleObject err = %d", GetLastError());
  148. }
  149. }
  150. if (!ResetEvent(fEvent)) {
  151. jack_error("JackWinProcessSync::LockedTimedWait ResetEvent err = %d", GetLastError());
  152. }
  153. return (res == WAIT_OBJECT_0);
  154. }
  155. bool JackWinProcessSync::LockedTimedWait(long usec)
  156. {
  157. if (!ReleaseMutex(fMutex)) {
  158. jack_error("JackWinProcessSync::LockedTimedWait ReleaseMutex err = %d", GetLastError());
  159. }
  160. HANDLE handles[] = { fMutex, fEvent };
  161. DWORD res = WaitForMultipleObjects(2, handles, true, usec / 1000);
  162. if ((res != WAIT_OBJECT_0) && (res != WAIT_TIMEOUT)) {
  163. jack_error("JackWinProcessSync::LockedTimedWait WaitForMultipleObjects err = %d", GetLastError());
  164. }
  165. if (!ResetEvent(fEvent)) {
  166. jack_error("JackWinProcessSync::LockedTimedWait ResetEvent err = %d", GetLastError());
  167. }
  168. return (res == WAIT_OBJECT_0);
  169. }
  170. */
  171. } // end of namespace