noderb 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (424) hide show
  1. data/LICENSE +19 -0
  2. data/README.md +25 -0
  3. data/ext/noderb_extension/extconf.rb +11 -0
  4. data/ext/noderb_extension/libuv/AUTHORS +11 -0
  5. data/ext/noderb_extension/libuv/LICENSE +48 -0
  6. data/ext/noderb_extension/libuv/Makefile +119 -0
  7. data/ext/noderb_extension/libuv/README +45 -0
  8. data/ext/noderb_extension/libuv/build/all.gyp +254 -0
  9. data/ext/noderb_extension/libuv/build/common.gypi +13 -0
  10. data/ext/noderb_extension/libuv/build/gyp_uv +43 -0
  11. data/ext/noderb_extension/libuv/config-mingw.mk +67 -0
  12. data/ext/noderb_extension/libuv/config-unix.mk +121 -0
  13. data/ext/noderb_extension/libuv/create-msvs-files.bat +14 -0
  14. data/ext/noderb_extension/libuv/deps/pthread-win32/ANNOUNCE +482 -0
  15. data/ext/noderb_extension/libuv/deps/pthread-win32/BUGS +141 -0
  16. data/ext/noderb_extension/libuv/deps/pthread-win32/Bmakefile +268 -0
  17. data/ext/noderb_extension/libuv/deps/pthread-win32/CONTRIBUTORS +140 -0
  18. data/ext/noderb_extension/libuv/deps/pthread-win32/COPYING +150 -0
  19. data/ext/noderb_extension/libuv/deps/pthread-win32/COPYING.LIB +504 -0
  20. data/ext/noderb_extension/libuv/deps/pthread-win32/ChangeLog +5194 -0
  21. data/ext/noderb_extension/libuv/deps/pthread-win32/FAQ +451 -0
  22. data/ext/noderb_extension/libuv/deps/pthread-win32/GNUmakefile +593 -0
  23. data/ext/noderb_extension/libuv/deps/pthread-win32/MAINTAINERS +4 -0
  24. data/ext/noderb_extension/libuv/deps/pthread-win32/Makefile +516 -0
  25. data/ext/noderb_extension/libuv/deps/pthread-win32/NEWS +1245 -0
  26. data/ext/noderb_extension/libuv/deps/pthread-win32/Nmakefile +24 -0
  27. data/ext/noderb_extension/libuv/deps/pthread-win32/Nmakefile.tests +260 -0
  28. data/ext/noderb_extension/libuv/deps/pthread-win32/PROGRESS +4 -0
  29. data/ext/noderb_extension/libuv/deps/pthread-win32/README +601 -0
  30. data/ext/noderb_extension/libuv/deps/pthread-win32/README.Borland +57 -0
  31. data/ext/noderb_extension/libuv/deps/pthread-win32/README.CV +3036 -0
  32. data/ext/noderb_extension/libuv/deps/pthread-win32/README.NONPORTABLE +783 -0
  33. data/ext/noderb_extension/libuv/deps/pthread-win32/README.Watcom +62 -0
  34. data/ext/noderb_extension/libuv/deps/pthread-win32/README.WinCE +6 -0
  35. data/ext/noderb_extension/libuv/deps/pthread-win32/TODO +7 -0
  36. data/ext/noderb_extension/libuv/deps/pthread-win32/WinCE-PORT +222 -0
  37. data/ext/noderb_extension/libuv/deps/pthread-win32/attr.c +53 -0
  38. data/ext/noderb_extension/libuv/deps/pthread-win32/autostatic.c +69 -0
  39. data/ext/noderb_extension/libuv/deps/pthread-win32/barrier.c +47 -0
  40. data/ext/noderb_extension/libuv/deps/pthread-win32/build/all.gyp +207 -0
  41. data/ext/noderb_extension/libuv/deps/pthread-win32/builddmc.bat +9 -0
  42. data/ext/noderb_extension/libuv/deps/pthread-win32/cancel.c +44 -0
  43. data/ext/noderb_extension/libuv/deps/pthread-win32/cleanup.c +148 -0
  44. data/ext/noderb_extension/libuv/deps/pthread-win32/condvar.c +50 -0
  45. data/ext/noderb_extension/libuv/deps/pthread-win32/config.h +153 -0
  46. data/ext/noderb_extension/libuv/deps/pthread-win32/context.h +74 -0
  47. data/ext/noderb_extension/libuv/deps/pthread-win32/create.c +308 -0
  48. data/ext/noderb_extension/libuv/deps/pthread-win32/dll.c +92 -0
  49. data/ext/noderb_extension/libuv/deps/pthread-win32/errno.c +94 -0
  50. data/ext/noderb_extension/libuv/deps/pthread-win32/exit.c +44 -0
  51. data/ext/noderb_extension/libuv/deps/pthread-win32/fork.c +39 -0
  52. data/ext/noderb_extension/libuv/deps/pthread-win32/global.c +107 -0
  53. data/ext/noderb_extension/libuv/deps/pthread-win32/implement.h +944 -0
  54. data/ext/noderb_extension/libuv/deps/pthread-win32/misc.c +50 -0
  55. data/ext/noderb_extension/libuv/deps/pthread-win32/mutex.c +62 -0
  56. data/ext/noderb_extension/libuv/deps/pthread-win32/need_errno.h +145 -0
  57. data/ext/noderb_extension/libuv/deps/pthread-win32/nonportable.c +47 -0
  58. data/ext/noderb_extension/libuv/deps/pthread-win32/private.c +54 -0
  59. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread.c +66 -0
  60. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread.dsp +142 -0
  61. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread.dsw +29 -0
  62. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread.h +1368 -0
  63. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_destroy.c +79 -0
  64. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getdetachstate.c +86 -0
  65. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getinheritsched.c +51 -0
  66. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getschedparam.c +52 -0
  67. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getschedpolicy.c +61 -0
  68. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getscope.c +54 -0
  69. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getstackaddr.c +97 -0
  70. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_getstacksize.c +100 -0
  71. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_init.c +117 -0
  72. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setdetachstate.c +91 -0
  73. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setinheritsched.c +57 -0
  74. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setschedparam.c +63 -0
  75. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setschedpolicy.c +55 -0
  76. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setscope.c +62 -0
  77. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setstackaddr.c +97 -0
  78. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_attr_setstacksize.c +110 -0
  79. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrier_destroy.c +103 -0
  80. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrier_init.c +69 -0
  81. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrier_wait.c +104 -0
  82. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrierattr_destroy.c +83 -0
  83. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrierattr_getpshared.c +95 -0
  84. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrierattr_init.c +85 -0
  85. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_barrierattr_setpshared.c +119 -0
  86. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cancel.c +189 -0
  87. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cond_destroy.c +253 -0
  88. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cond_init.c +167 -0
  89. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cond_signal.c +231 -0
  90. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_cond_wait.c +567 -0
  91. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_condattr_destroy.c +86 -0
  92. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_condattr_getpshared.c +97 -0
  93. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_condattr_init.c +87 -0
  94. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_condattr_setpshared.c +117 -0
  95. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_delay_np.c +172 -0
  96. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_detach.c +136 -0
  97. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_equal.c +76 -0
  98. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_exit.c +106 -0
  99. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getconcurrency.c +45 -0
  100. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getschedparam.c +75 -0
  101. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getspecific.c +87 -0
  102. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getunique_np.c +47 -0
  103. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_getw32threadhandle_np.c +65 -0
  104. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_join.c +157 -0
  105. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_key_create.c +108 -0
  106. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_key_delete.c +125 -0
  107. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_kill.c +105 -0
  108. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_consistent.c +187 -0
  109. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_destroy.c +148 -0
  110. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_init.c +130 -0
  111. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_lock.c +269 -0
  112. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_timedlock.c +324 -0
  113. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_trylock.c +154 -0
  114. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutex_unlock.c +175 -0
  115. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_destroy.c +83 -0
  116. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_getkind_np.c +44 -0
  117. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_getpshared.c +95 -0
  118. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_getrobust.c +113 -0
  119. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_gettype.c +56 -0
  120. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_init.c +86 -0
  121. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_setkind_np.c +44 -0
  122. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_setpshared.c +119 -0
  123. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_setrobust.c +119 -0
  124. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_mutexattr_settype.c +143 -0
  125. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_num_processors_np.c +56 -0
  126. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_once.c +79 -0
  127. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_destroy.c +143 -0
  128. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_init.c +109 -0
  129. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_rdlock.c +102 -0
  130. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_timedrdlock.c +109 -0
  131. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_timedwrlock.c +139 -0
  132. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_tryrdlock.c +102 -0
  133. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_trywrlock.c +122 -0
  134. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_unlock.c +93 -0
  135. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlock_wrlock.c +133 -0
  136. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlockattr_destroy.c +84 -0
  137. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlockattr_getpshared.c +97 -0
  138. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlockattr_init.c +83 -0
  139. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_rwlockattr_setpshared.c +120 -0
  140. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_self.c +141 -0
  141. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setcancelstate.c +125 -0
  142. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setcanceltype.c +126 -0
  143. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setconcurrency.c +53 -0
  144. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setschedparam.c +123 -0
  145. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_setspecific.c +167 -0
  146. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_destroy.c +111 -0
  147. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_init.c +123 -0
  148. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_lock.c +80 -0
  149. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_trylock.c +77 -0
  150. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_spin_unlock.c +71 -0
  151. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_testcancel.c +103 -0
  152. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_timechange_handler_np.c +108 -0
  153. data/ext/noderb_extension/libuv/deps/pthread-win32/pthread_win32_attach_detach_np.c +258 -0
  154. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_MCS_lock.c +278 -0
  155. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_callUserDestroyRoutines.c +232 -0
  156. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_calloc.c +56 -0
  157. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_cond_check_need_init.c +78 -0
  158. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_getprocessors.c +91 -0
  159. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_is_attr.c +47 -0
  160. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_mutex_check_need_init.c +92 -0
  161. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_new.c +94 -0
  162. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_processInitialize.c +92 -0
  163. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_processTerminate.c +105 -0
  164. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_relmillisecs.c +132 -0
  165. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_reuse.c +151 -0
  166. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_rwlock_cancelwrwait.c +50 -0
  167. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_rwlock_check_need_init.c +77 -0
  168. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_semwait.c +135 -0
  169. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_spinlock_check_need_init.c +78 -0
  170. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_threadDestroy.c +79 -0
  171. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_threadStart.c +357 -0
  172. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_throw.c +189 -0
  173. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_timespec.c +83 -0
  174. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_tkAssocCreate.c +118 -0
  175. data/ext/noderb_extension/libuv/deps/pthread-win32/ptw32_tkAssocDestroy.c +114 -0
  176. data/ext/noderb_extension/libuv/deps/pthread-win32/rwlock.c +51 -0
  177. data/ext/noderb_extension/libuv/deps/pthread-win32/sched.c +53 -0
  178. data/ext/noderb_extension/libuv/deps/pthread-win32/sched.h +183 -0
  179. data/ext/noderb_extension/libuv/deps/pthread-win32/sched_get_priority_max.c +134 -0
  180. data/ext/noderb_extension/libuv/deps/pthread-win32/sched_get_priority_min.c +135 -0
  181. data/ext/noderb_extension/libuv/deps/pthread-win32/sched_getscheduler.c +71 -0
  182. data/ext/noderb_extension/libuv/deps/pthread-win32/sched_setscheduler.c +83 -0
  183. data/ext/noderb_extension/libuv/deps/pthread-win32/sched_yield.c +71 -0
  184. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_close.c +58 -0
  185. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_destroy.c +144 -0
  186. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_getvalue.c +110 -0
  187. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_init.c +169 -0
  188. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_open.c +58 -0
  189. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_post.c +128 -0
  190. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_post_multiple.c +142 -0
  191. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_timedwait.c +238 -0
  192. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_trywait.c +117 -0
  193. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_unlink.c +58 -0
  194. data/ext/noderb_extension/libuv/deps/pthread-win32/sem_wait.c +187 -0
  195. data/ext/noderb_extension/libuv/deps/pthread-win32/semaphore.c +69 -0
  196. data/ext/noderb_extension/libuv/deps/pthread-win32/semaphore.h +169 -0
  197. data/ext/noderb_extension/libuv/deps/pthread-win32/signal.c +179 -0
  198. data/ext/noderb_extension/libuv/deps/pthread-win32/spin.c +46 -0
  199. data/ext/noderb_extension/libuv/deps/pthread-win32/sync.c +43 -0
  200. data/ext/noderb_extension/libuv/deps/pthread-win32/tsd.c +44 -0
  201. data/ext/noderb_extension/libuv/deps/pthread-win32/version.rc +388 -0
  202. data/ext/noderb_extension/libuv/deps/pthread-win32/w32_CancelableWait.c +161 -0
  203. data/ext/noderb_extension/libuv/doc/desired-api.md +159 -0
  204. data/ext/noderb_extension/libuv/doc/iocp-links.html +574 -0
  205. data/ext/noderb_extension/libuv/include/ares.h +582 -0
  206. data/ext/noderb_extension/libuv/include/ares_version.h +24 -0
  207. data/ext/noderb_extension/libuv/include/eio.h +376 -0
  208. data/ext/noderb_extension/libuv/include/ev.h +835 -0
  209. data/ext/noderb_extension/libuv/include/ngx-queue.h +102 -0
  210. data/ext/noderb_extension/libuv/include/tree.h +762 -0
  211. data/ext/noderb_extension/libuv/include/uv-unix.h +138 -0
  212. data/ext/noderb_extension/libuv/include/uv-win.h +187 -0
  213. data/ext/noderb_extension/libuv/include/uv.h +635 -0
  214. data/ext/noderb_extension/libuv/src/ares/AUTHORS +37 -0
  215. data/ext/noderb_extension/libuv/src/ares/CHANGES +1198 -0
  216. data/ext/noderb_extension/libuv/src/ares/CMakeLists.txt +22 -0
  217. data/ext/noderb_extension/libuv/src/ares/NEWS +21 -0
  218. data/ext/noderb_extension/libuv/src/ares/README +60 -0
  219. data/ext/noderb_extension/libuv/src/ares/README.cares +13 -0
  220. data/ext/noderb_extension/libuv/src/ares/README.msvc +118 -0
  221. data/ext/noderb_extension/libuv/src/ares/README.node +21 -0
  222. data/ext/noderb_extension/libuv/src/ares/RELEASE-NOTES +25 -0
  223. data/ext/noderb_extension/libuv/src/ares/TODO +23 -0
  224. data/ext/noderb_extension/libuv/src/ares/ares__close_sockets.c +66 -0
  225. data/ext/noderb_extension/libuv/src/ares/ares__get_hostent.c +263 -0
  226. data/ext/noderb_extension/libuv/src/ares/ares__read_line.c +71 -0
  227. data/ext/noderb_extension/libuv/src/ares/ares__timeval.c +111 -0
  228. data/ext/noderb_extension/libuv/src/ares/ares_cancel.c +63 -0
  229. data/ext/noderb_extension/libuv/src/ares/ares_data.c +190 -0
  230. data/ext/noderb_extension/libuv/src/ares/ares_data.h +65 -0
  231. data/ext/noderb_extension/libuv/src/ares/ares_destroy.c +105 -0
  232. data/ext/noderb_extension/libuv/src/ares/ares_dns.h +90 -0
  233. data/ext/noderb_extension/libuv/src/ares/ares_expand_name.c +193 -0
  234. data/ext/noderb_extension/libuv/src/ares/ares_expand_string.c +75 -0
  235. data/ext/noderb_extension/libuv/src/ares/ares_fds.c +62 -0
  236. data/ext/noderb_extension/libuv/src/ares/ares_free_hostent.c +39 -0
  237. data/ext/noderb_extension/libuv/src/ares/ares_free_string.c +25 -0
  238. data/ext/noderb_extension/libuv/src/ares/ares_gethostbyaddr.c +292 -0
  239. data/ext/noderb_extension/libuv/src/ares/ares_gethostbyname.c +515 -0
  240. data/ext/noderb_extension/libuv/src/ares/ares_getnameinfo.c +426 -0
  241. data/ext/noderb_extension/libuv/src/ares/ares_getopt.c +122 -0
  242. data/ext/noderb_extension/libuv/src/ares/ares_getopt.h +53 -0
  243. data/ext/noderb_extension/libuv/src/ares/ares_getsock.c +72 -0
  244. data/ext/noderb_extension/libuv/src/ares/ares_init.c +1665 -0
  245. data/ext/noderb_extension/libuv/src/ares/ares_ipv6.h +78 -0
  246. data/ext/noderb_extension/libuv/src/ares/ares_library_init.c +132 -0
  247. data/ext/noderb_extension/libuv/src/ares/ares_library_init.h +39 -0
  248. data/ext/noderb_extension/libuv/src/ares/ares_llist.c +86 -0
  249. data/ext/noderb_extension/libuv/src/ares/ares_llist.h +42 -0
  250. data/ext/noderb_extension/libuv/src/ares/ares_mkquery.c +195 -0
  251. data/ext/noderb_extension/libuv/src/ares/ares_nowarn.c +59 -0
  252. data/ext/noderb_extension/libuv/src/ares/ares_nowarn.h +24 -0
  253. data/ext/noderb_extension/libuv/src/ares/ares_options.c +253 -0
  254. data/ext/noderb_extension/libuv/src/ares/ares_parse_a_reply.c +260 -0
  255. data/ext/noderb_extension/libuv/src/ares/ares_parse_aaaa_reply.c +256 -0
  256. data/ext/noderb_extension/libuv/src/ares/ares_parse_mx_reply.c +170 -0
  257. data/ext/noderb_extension/libuv/src/ares/ares_parse_ns_reply.c +182 -0
  258. data/ext/noderb_extension/libuv/src/ares/ares_parse_ptr_reply.c +208 -0
  259. data/ext/noderb_extension/libuv/src/ares/ares_parse_srv_reply.c +179 -0
  260. data/ext/noderb_extension/libuv/src/ares/ares_parse_txt_reply.c +201 -0
  261. data/ext/noderb_extension/libuv/src/ares/ares_private.h +351 -0
  262. data/ext/noderb_extension/libuv/src/ares/ares_process.c +1296 -0
  263. data/ext/noderb_extension/libuv/src/ares/ares_query.c +183 -0
  264. data/ext/noderb_extension/libuv/src/ares/ares_rules.h +144 -0
  265. data/ext/noderb_extension/libuv/src/ares/ares_search.c +322 -0
  266. data/ext/noderb_extension/libuv/src/ares/ares_send.c +134 -0
  267. data/ext/noderb_extension/libuv/src/ares/ares_setup.h +191 -0
  268. data/ext/noderb_extension/libuv/src/ares/ares_strcasecmp.c +66 -0
  269. data/ext/noderb_extension/libuv/src/ares/ares_strcasecmp.h +30 -0
  270. data/ext/noderb_extension/libuv/src/ares/ares_strdup.c +42 -0
  271. data/ext/noderb_extension/libuv/src/ares/ares_strdup.h +26 -0
  272. data/ext/noderb_extension/libuv/src/ares/ares_strerror.c +56 -0
  273. data/ext/noderb_extension/libuv/src/ares/ares_timeout.c +80 -0
  274. data/ext/noderb_extension/libuv/src/ares/ares_version.c +11 -0
  275. data/ext/noderb_extension/libuv/src/ares/ares_writev.c +79 -0
  276. data/ext/noderb_extension/libuv/src/ares/ares_writev.h +36 -0
  277. data/ext/noderb_extension/libuv/src/ares/bitncmp.c +59 -0
  278. data/ext/noderb_extension/libuv/src/ares/bitncmp.h +26 -0
  279. data/ext/noderb_extension/libuv/src/ares/config_cygwin/ares_config.h +510 -0
  280. data/ext/noderb_extension/libuv/src/ares/config_darwin/ares_config.h +510 -0
  281. data/ext/noderb_extension/libuv/src/ares/config_freebsd/ares_config.h +510 -0
  282. data/ext/noderb_extension/libuv/src/ares/config_linux/ares_config.h +510 -0
  283. data/ext/noderb_extension/libuv/src/ares/config_openbsd/ares_config.h +510 -0
  284. data/ext/noderb_extension/libuv/src/ares/config_sunos/ares_config.h +510 -0
  285. data/ext/noderb_extension/libuv/src/ares/config_win32/ares_config.h +369 -0
  286. data/ext/noderb_extension/libuv/src/ares/get_ver.awk +35 -0
  287. data/ext/noderb_extension/libuv/src/ares/inet_net_pton.c +450 -0
  288. data/ext/noderb_extension/libuv/src/ares/inet_net_pton.h +31 -0
  289. data/ext/noderb_extension/libuv/src/ares/inet_ntop.c +232 -0
  290. data/ext/noderb_extension/libuv/src/ares/inet_ntop.h +27 -0
  291. data/ext/noderb_extension/libuv/src/ares/nameser.h +193 -0
  292. data/ext/noderb_extension/libuv/src/ares/setup_once.h +488 -0
  293. data/ext/noderb_extension/libuv/src/ares/windows_port.c +22 -0
  294. data/ext/noderb_extension/libuv/src/eio/Changes +63 -0
  295. data/ext/noderb_extension/libuv/src/eio/LICENSE +36 -0
  296. data/ext/noderb_extension/libuv/src/eio/Makefile.am +15 -0
  297. data/ext/noderb_extension/libuv/src/eio/aclocal.m4 +8957 -0
  298. data/ext/noderb_extension/libuv/src/eio/autogen.sh +3 -0
  299. data/ext/noderb_extension/libuv/src/eio/config.h.in +86 -0
  300. data/ext/noderb_extension/libuv/src/eio/config_cygwin.h +77 -0
  301. data/ext/noderb_extension/libuv/src/eio/config_darwin.h +137 -0
  302. data/ext/noderb_extension/libuv/src/eio/config_freebsd.h +78 -0
  303. data/ext/noderb_extension/libuv/src/eio/config_linux.h +101 -0
  304. data/ext/noderb_extension/libuv/src/eio/config_sunos.h +81 -0
  305. data/ext/noderb_extension/libuv/src/eio/configure.ac +22 -0
  306. data/ext/noderb_extension/libuv/src/eio/demo.c +194 -0
  307. data/ext/noderb_extension/libuv/src/eio/ecb.h +370 -0
  308. data/ext/noderb_extension/libuv/src/eio/eio.3 +3428 -0
  309. data/ext/noderb_extension/libuv/src/eio/eio.c +2562 -0
  310. data/ext/noderb_extension/libuv/src/eio/eio.pod +969 -0
  311. data/ext/noderb_extension/libuv/src/eio/libeio.m4 +195 -0
  312. data/ext/noderb_extension/libuv/src/eio/xthread.h +164 -0
  313. data/ext/noderb_extension/libuv/src/ev/Changes +388 -0
  314. data/ext/noderb_extension/libuv/src/ev/LICENSE +36 -0
  315. data/ext/noderb_extension/libuv/src/ev/Makefile.am +18 -0
  316. data/ext/noderb_extension/libuv/src/ev/Makefile.in +771 -0
  317. data/ext/noderb_extension/libuv/src/ev/README +58 -0
  318. data/ext/noderb_extension/libuv/src/ev/aclocal.m4 +8957 -0
  319. data/ext/noderb_extension/libuv/src/ev/autogen.sh +6 -0
  320. data/ext/noderb_extension/libuv/src/ev/config.guess +1526 -0
  321. data/ext/noderb_extension/libuv/src/ev/config.h.in +125 -0
  322. data/ext/noderb_extension/libuv/src/ev/config.sub +1658 -0
  323. data/ext/noderb_extension/libuv/src/ev/config_cygwin.h +123 -0
  324. data/ext/noderb_extension/libuv/src/ev/config_darwin.h +122 -0
  325. data/ext/noderb_extension/libuv/src/ev/config_freebsd.h +120 -0
  326. data/ext/noderb_extension/libuv/src/ev/config_linux.h +130 -0
  327. data/ext/noderb_extension/libuv/src/ev/config_sunos.h +122 -0
  328. data/ext/noderb_extension/libuv/src/ev/configure +13037 -0
  329. data/ext/noderb_extension/libuv/src/ev/configure.ac +18 -0
  330. data/ext/noderb_extension/libuv/src/ev/depcomp +630 -0
  331. data/ext/noderb_extension/libuv/src/ev/ev++.h +816 -0
  332. data/ext/noderb_extension/libuv/src/ev/ev.3 +5311 -0
  333. data/ext/noderb_extension/libuv/src/ev/ev.c +3913 -0
  334. data/ext/noderb_extension/libuv/src/ev/ev.pod +5243 -0
  335. data/ext/noderb_extension/libuv/src/ev/ev_epoll.c +266 -0
  336. data/ext/noderb_extension/libuv/src/ev/ev_kqueue.c +198 -0
  337. data/ext/noderb_extension/libuv/src/ev/ev_poll.c +148 -0
  338. data/ext/noderb_extension/libuv/src/ev/ev_port.c +179 -0
  339. data/ext/noderb_extension/libuv/src/ev/ev_select.c +310 -0
  340. data/ext/noderb_extension/libuv/src/ev/ev_vars.h +203 -0
  341. data/ext/noderb_extension/libuv/src/ev/ev_win32.c +153 -0
  342. data/ext/noderb_extension/libuv/src/ev/ev_wrap.h +196 -0
  343. data/ext/noderb_extension/libuv/src/ev/event.c +402 -0
  344. data/ext/noderb_extension/libuv/src/ev/event.h +170 -0
  345. data/ext/noderb_extension/libuv/src/ev/install-sh +294 -0
  346. data/ext/noderb_extension/libuv/src/ev/libev.m4 +39 -0
  347. data/ext/noderb_extension/libuv/src/ev/ltmain.sh +8413 -0
  348. data/ext/noderb_extension/libuv/src/ev/missing +336 -0
  349. data/ext/noderb_extension/libuv/src/ev/mkinstalldirs +111 -0
  350. data/ext/noderb_extension/libuv/src/uv-common.c +172 -0
  351. data/ext/noderb_extension/libuv/src/uv-common.h +53 -0
  352. data/ext/noderb_extension/libuv/src/uv-cygwin.c +52 -0
  353. data/ext/noderb_extension/libuv/src/uv-darwin.c +64 -0
  354. data/ext/noderb_extension/libuv/src/uv-eio.c +113 -0
  355. data/ext/noderb_extension/libuv/src/uv-eio.h +13 -0
  356. data/ext/noderb_extension/libuv/src/uv-freebsd.c +65 -0
  357. data/ext/noderb_extension/libuv/src/uv-linux.c +51 -0
  358. data/ext/noderb_extension/libuv/src/uv-sunos.c +60 -0
  359. data/ext/noderb_extension/libuv/src/uv-unix.c +2408 -0
  360. data/ext/noderb_extension/libuv/src/win/async.c +129 -0
  361. data/ext/noderb_extension/libuv/src/win/cares.c +304 -0
  362. data/ext/noderb_extension/libuv/src/win/core.c +155 -0
  363. data/ext/noderb_extension/libuv/src/win/error.c +140 -0
  364. data/ext/noderb_extension/libuv/src/win/getaddrinfo.c +341 -0
  365. data/ext/noderb_extension/libuv/src/win/handle.c +176 -0
  366. data/ext/noderb_extension/libuv/src/win/internal.h +237 -0
  367. data/ext/noderb_extension/libuv/src/win/loop-watcher.c +128 -0
  368. data/ext/noderb_extension/libuv/src/win/pipe.c +828 -0
  369. data/ext/noderb_extension/libuv/src/win/process.c +936 -0
  370. data/ext/noderb_extension/libuv/src/win/req.c +141 -0
  371. data/ext/noderb_extension/libuv/src/win/stdio.c +75 -0
  372. data/ext/noderb_extension/libuv/src/win/stream.c +149 -0
  373. data/ext/noderb_extension/libuv/src/win/tcp.c +895 -0
  374. data/ext/noderb_extension/libuv/src/win/timer.c +269 -0
  375. data/ext/noderb_extension/libuv/src/win/util.c +82 -0
  376. data/ext/noderb_extension/libuv/test/benchmark-ares.c +117 -0
  377. data/ext/noderb_extension/libuv/test/benchmark-getaddrinfo.c +90 -0
  378. data/ext/noderb_extension/libuv/test/benchmark-list.h +77 -0
  379. data/ext/noderb_extension/libuv/test/benchmark-ping-pongs.c +210 -0
  380. data/ext/noderb_extension/libuv/test/benchmark-pound.c +237 -0
  381. data/ext/noderb_extension/libuv/test/benchmark-pump.c +459 -0
  382. data/ext/noderb_extension/libuv/test/benchmark-sizes.c +39 -0
  383. data/ext/noderb_extension/libuv/test/benchmark-spawn.c +154 -0
  384. data/ext/noderb_extension/libuv/test/dns-server.c +323 -0
  385. data/ext/noderb_extension/libuv/test/echo-server.c +299 -0
  386. data/ext/noderb_extension/libuv/test/run-benchmarks.c +64 -0
  387. data/ext/noderb_extension/libuv/test/run-tests.c +82 -0
  388. data/ext/noderb_extension/libuv/test/runner-unix.c +335 -0
  389. data/ext/noderb_extension/libuv/test/runner-unix.h +36 -0
  390. data/ext/noderb_extension/libuv/test/runner-win.c +343 -0
  391. data/ext/noderb_extension/libuv/test/runner-win.h +42 -0
  392. data/ext/noderb_extension/libuv/test/runner.c +311 -0
  393. data/ext/noderb_extension/libuv/test/runner.h +155 -0
  394. data/ext/noderb_extension/libuv/test/task.h +111 -0
  395. data/ext/noderb_extension/libuv/test/test-async.c +218 -0
  396. data/ext/noderb_extension/libuv/test/test-callback-stack.c +205 -0
  397. data/ext/noderb_extension/libuv/test/test-connection-fail.c +149 -0
  398. data/ext/noderb_extension/libuv/test/test-delayed-accept.c +198 -0
  399. data/ext/noderb_extension/libuv/test/test-fail-always.c +29 -0
  400. data/ext/noderb_extension/libuv/test/test-get-currentexe.c +53 -0
  401. data/ext/noderb_extension/libuv/test/test-getaddrinfo.c +110 -0
  402. data/ext/noderb_extension/libuv/test/test-gethostbyname.c +192 -0
  403. data/ext/noderb_extension/libuv/test/test-getsockname.c +196 -0
  404. data/ext/noderb_extension/libuv/test/test-hrtime.c +51 -0
  405. data/ext/noderb_extension/libuv/test/test-idle.c +83 -0
  406. data/ext/noderb_extension/libuv/test/test-list.h +165 -0
  407. data/ext/noderb_extension/libuv/test/test-loop-handles.c +361 -0
  408. data/ext/noderb_extension/libuv/test/test-pass-always.c +28 -0
  409. data/ext/noderb_extension/libuv/test/test-ping-pong.c +256 -0
  410. data/ext/noderb_extension/libuv/test/test-pipe-bind-error.c +148 -0
  411. data/ext/noderb_extension/libuv/test/test-ref.c +91 -0
  412. data/ext/noderb_extension/libuv/test/test-shutdown-eof.c +183 -0
  413. data/ext/noderb_extension/libuv/test/test-spawn.c +345 -0
  414. data/ext/noderb_extension/libuv/test/test-tcp-bind-error.c +204 -0
  415. data/ext/noderb_extension/libuv/test/test-tcp-bind6-error.c +164 -0
  416. data/ext/noderb_extension/libuv/test/test-tcp-writealot.c +198 -0
  417. data/ext/noderb_extension/libuv/test/test-timer-again.c +141 -0
  418. data/ext/noderb_extension/libuv/test/test-timer.c +134 -0
  419. data/ext/noderb_extension/noderb.c +340 -0
  420. data/ext/noderb_extension/noderb.h +2 -0
  421. data/lib/noderb/connection.rb +21 -0
  422. data/lib/noderb/process.rb +17 -0
  423. data/lib/noderb.rb +25 -0
  424. metadata +470 -0
@@ -0,0 +1,278 @@
1
+ /*
2
+ * ptw32_MCS_lock.c
3
+ *
4
+ * Description:
5
+ * This translation unit implements queue-based locks.
6
+ *
7
+ * --------------------------------------------------------------------------
8
+ *
9
+ * Pthreads-win32 - POSIX Threads Library for Win32
10
+ * Copyright(C) 1998 John E. Bossom
11
+ * Copyright(C) 1999,2005 Pthreads-win32 contributors
12
+ *
13
+ * Contact Email: rpj@callisto.canberra.edu.au
14
+ *
15
+ * The current list of contributors is contained
16
+ * in the file CONTRIBUTORS included with the source
17
+ * code distribution. The list can also be seen at the
18
+ * following World Wide Web location:
19
+ * http://sources.redhat.com/pthreads-win32/contributors.html
20
+ *
21
+ * This library is free software; you can redistribute it and/or
22
+ * modify it under the terms of the GNU Lesser General Public
23
+ * License as published by the Free Software Foundation; either
24
+ * version 2 of the License, or (at your option) any later version.
25
+ *
26
+ * This library is distributed in the hope that it will be useful,
27
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
28
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
29
+ * Lesser General Public License for more details.
30
+ *
31
+ * You should have received a copy of the GNU Lesser General Public
32
+ * License along with this library in the file COPYING.LIB;
33
+ * if not, write to the Free Software Foundation, Inc.,
34
+ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
35
+ */
36
+
37
+ /*
38
+ * About MCS locks:
39
+ *
40
+ * MCS locks are queue-based locks, where the queue nodes are local to the
41
+ * thread. The 'lock' is nothing more than a global pointer that points to
42
+ * the last node in the queue, or is NULL if the queue is empty.
43
+ *
44
+ * Originally designed for use as spin locks requiring no kernel resources
45
+ * for synchronisation or blocking, the implementation below has adapted
46
+ * the MCS spin lock for use as a general mutex that will suspend threads
47
+ * when there is lock contention.
48
+ *
49
+ * Because the queue nodes are thread-local, most of the memory read/write
50
+ * operations required to add or remove nodes from the queue do not trigger
51
+ * cache-coherence updates.
52
+ *
53
+ * Like 'named' mutexes, MCS locks consume system resources transiently -
54
+ * they are able to acquire and free resources automatically - but MCS
55
+ * locks do not require any unique 'name' to identify the lock to all
56
+ * threads using it.
57
+ *
58
+ * Usage of MCS locks:
59
+ *
60
+ * - you need a global ptw32_mcs_lock_t instance initialised to 0 or NULL.
61
+ * - you need a local thread-scope ptw32_mcs_local_node_t instance, which
62
+ * may serve several different locks but you need at least one node for
63
+ * every lock held concurrently by a thread.
64
+ *
65
+ * E.g.:
66
+ *
67
+ * ptw32_mcs_lock_t lock1 = 0;
68
+ * ptw32_mcs_lock_t lock2 = 0;
69
+ *
70
+ * void *mythread(void *arg)
71
+ * {
72
+ * ptw32_mcs_local_node_t node;
73
+ *
74
+ * ptw32_mcs_acquire (&lock1, &node);
75
+ * ptw32_mcs_lock_release (&node);
76
+ *
77
+ * ptw32_mcs_lock_acquire (&lock2, &node);
78
+ * ptw32_mcs_lock_release (&node);
79
+ * {
80
+ * ptw32_mcs_local_node_t nodex;
81
+ *
82
+ * ptw32_mcs_lock_acquire (&lock1, &node);
83
+ * ptw32_mcs_lock_acquire (&lock2, &nodex);
84
+ *
85
+ * ptw32_mcs_lock_release (&nodex);
86
+ * ptw32_mcs_lock_release (&node);
87
+ * }
88
+ * return (void *)0;
89
+ * }
90
+ */
91
+
92
+ #include "pthread.h"
93
+ #include "sched.h"
94
+ #include "implement.h"
95
+
96
+ /*
97
+ * ptw32_mcs_flag_set -- notify another thread about an event.
98
+ *
99
+ * Set event if an event handle has been stored in the flag, and
100
+ * set flag to -1 otherwise. Note that -1 cannot be a valid handle value.
101
+ */
102
+ INLINE void
103
+ ptw32_mcs_flag_set (HANDLE * flag)
104
+ {
105
+ HANDLE e = (HANDLE)(PTW32_INTERLOCKED_SIZE)PTW32_INTERLOCKED_COMPARE_EXCHANGE_SIZE(
106
+ (PTW32_INTERLOCKED_SIZEPTR)flag,
107
+ (PTW32_INTERLOCKED_SIZE)-1,
108
+ (PTW32_INTERLOCKED_SIZE)0);
109
+ if ((HANDLE)0 != e)
110
+ {
111
+ /* another thread has already stored an event handle in the flag */
112
+ SetEvent(e);
113
+ }
114
+ }
115
+
116
+ /*
117
+ * ptw32_mcs_flag_set -- wait for notification from another.
118
+ *
119
+ * Store an event handle in the flag and wait on it if the flag has not been
120
+ * set, and proceed without creating an event otherwise.
121
+ */
122
+ INLINE void
123
+ ptw32_mcs_flag_wait (HANDLE * flag)
124
+ {
125
+ if ((PTW32_INTERLOCKED_LONG)0 ==
126
+ PTW32_INTERLOCKED_EXCHANGE_ADD_SIZE((PTW32_INTERLOCKED_SIZEPTR)flag,
127
+ (PTW32_INTERLOCKED_SIZE)0)) /* MBR fence */
128
+ {
129
+ /* the flag is not set. create event. */
130
+
131
+ HANDLE e = CreateEvent(NULL, PTW32_FALSE, PTW32_FALSE, NULL);
132
+
133
+ if ((PTW32_INTERLOCKED_SIZE)0 == PTW32_INTERLOCKED_COMPARE_EXCHANGE_SIZE(
134
+ (PTW32_INTERLOCKED_SIZEPTR)flag,
135
+ (PTW32_INTERLOCKED_SIZE)e,
136
+ (PTW32_INTERLOCKED_SIZE)0))
137
+ {
138
+ /* stored handle in the flag. wait on it now. */
139
+ WaitForSingleObject(e, INFINITE);
140
+ }
141
+
142
+ CloseHandle(e);
143
+ }
144
+ }
145
+
146
+ /*
147
+ * ptw32_mcs_lock_acquire -- acquire an MCS lock.
148
+ *
149
+ * See:
150
+ * J. M. Mellor-Crummey and M. L. Scott.
151
+ * Algorithms for Scalable Synchronization on Shared-Memory Multiprocessors.
152
+ * ACM Transactions on Computer Systems, 9(1):21-65, Feb. 1991.
153
+ */
154
+ #if defined(PTW32_BUILD_INLINED)
155
+ INLINE
156
+ #endif /* PTW32_BUILD_INLINED */
157
+ void
158
+ ptw32_mcs_lock_acquire (ptw32_mcs_lock_t * lock, ptw32_mcs_local_node_t * node)
159
+ {
160
+ ptw32_mcs_local_node_t *pred;
161
+
162
+ node->lock = lock;
163
+ node->nextFlag = 0;
164
+ node->readyFlag = 0;
165
+ node->next = 0; /* initially, no successor */
166
+
167
+ /* queue for the lock */
168
+ pred = (ptw32_mcs_local_node_t *)PTW32_INTERLOCKED_EXCHANGE_PTR((PTW32_INTERLOCKED_PVOID_PTR)lock,
169
+ (PTW32_INTERLOCKED_PVOID)node);
170
+
171
+ if (0 != pred)
172
+ {
173
+ /* the lock was not free. link behind predecessor. */
174
+ pred->next = node;
175
+ ptw32_mcs_flag_set(&pred->nextFlag);
176
+ ptw32_mcs_flag_wait(&node->readyFlag);
177
+ }
178
+ }
179
+
180
+ /*
181
+ * ptw32_mcs_lock_release -- release an MCS lock.
182
+ *
183
+ * See:
184
+ * J. M. Mellor-Crummey and M. L. Scott.
185
+ * Algorithms for Scalable Synchronization on Shared-Memory Multiprocessors.
186
+ * ACM Transactions on Computer Systems, 9(1):21-65, Feb. 1991.
187
+ */
188
+ #if defined(PTW32_BUILD_INLINED)
189
+ INLINE
190
+ #endif /* PTW32_BUILD_INLINED */
191
+ void
192
+ ptw32_mcs_lock_release (ptw32_mcs_local_node_t * node)
193
+ {
194
+ ptw32_mcs_lock_t *lock = node->lock;
195
+ ptw32_mcs_local_node_t *next =
196
+ (ptw32_mcs_local_node_t *)
197
+ PTW32_INTERLOCKED_EXCHANGE_ADD_SIZE((PTW32_INTERLOCKED_SIZEPTR)&node->next, (PTW32_INTERLOCKED_SIZE)0); /* MBR fence */
198
+
199
+ if (0 == next)
200
+ {
201
+ /* no known successor */
202
+
203
+ if (node == (ptw32_mcs_local_node_t *)
204
+ PTW32_INTERLOCKED_COMPARE_EXCHANGE_PTR((PTW32_INTERLOCKED_PVOID_PTR)lock,
205
+ (PTW32_INTERLOCKED_PVOID)0,
206
+ (PTW32_INTERLOCKED_PVOID)node))
207
+ {
208
+ /* no successor, lock is free now */
209
+ return;
210
+ }
211
+
212
+ /* wait for successor */
213
+ ptw32_mcs_flag_wait(&node->nextFlag);
214
+ next = (ptw32_mcs_local_node_t *)
215
+ PTW32_INTERLOCKED_EXCHANGE_ADD_SIZE((PTW32_INTERLOCKED_SIZEPTR)&node->next, (PTW32_INTERLOCKED_SIZE)0); /* MBR fence */
216
+ }
217
+
218
+ /* pass the lock */
219
+ ptw32_mcs_flag_set(&next->readyFlag);
220
+ }
221
+
222
+ /*
223
+ * ptw32_mcs_lock_try_acquire
224
+ */
225
+ #if defined(PTW32_BUILD_INLINED)
226
+ INLINE
227
+ #endif /* PTW32_BUILD_INLINED */
228
+ int
229
+ ptw32_mcs_lock_try_acquire (ptw32_mcs_lock_t * lock, ptw32_mcs_local_node_t * node)
230
+ {
231
+ node->lock = lock;
232
+ node->nextFlag = 0;
233
+ node->readyFlag = 0;
234
+ node->next = 0; /* initially, no successor */
235
+
236
+ return ((PTW32_INTERLOCKED_PVOID)PTW32_INTERLOCKED_COMPARE_EXCHANGE_PTR((PTW32_INTERLOCKED_PVOID_PTR)lock,
237
+ (PTW32_INTERLOCKED_PVOID)node,
238
+ (PTW32_INTERLOCKED_PVOID)0)
239
+ == (PTW32_INTERLOCKED_PVOID)0) ? 0 : EBUSY;
240
+ }
241
+
242
+ /*
243
+ * ptw32_mcs_node_transfer -- move an MCS lock local node, usually from thread
244
+ * space to, for example, global space so that another thread can release
245
+ * the lock on behalf of the current lock owner.
246
+ *
247
+ * Example: used in pthread_barrier_wait where we want the last thread out of
248
+ * the barrier to release the lock owned by the last thread to enter the barrier
249
+ * (the one that releases all threads but not necessarily the last to leave).
250
+ *
251
+ * Should only be called by the thread that has the lock.
252
+ */
253
+ #if defined(PTW32_BUILD_INLINED)
254
+ INLINE
255
+ #endif /* PTW32_BUILD_INLINED */
256
+ void
257
+ ptw32_mcs_node_transfer (ptw32_mcs_local_node_t * new_node, ptw32_mcs_local_node_t * old_node)
258
+ {
259
+ new_node->lock = old_node->lock;
260
+ new_node->nextFlag = 0; /* Not needed - used only in initial Acquire */
261
+ new_node->readyFlag = 0; /* Not needed - we were waiting on this */
262
+ new_node->next = 0;
263
+
264
+ if ((ptw32_mcs_local_node_t *)PTW32_INTERLOCKED_COMPARE_EXCHANGE_PTR((PTW32_INTERLOCKED_PVOID_PTR)new_node->lock,
265
+ (PTW32_INTERLOCKED_PVOID)new_node,
266
+ (PTW32_INTERLOCKED_PVOID)old_node)
267
+ != old_node)
268
+ {
269
+ /*
270
+ * A successor has queued after us, so wait for them to link to us
271
+ */
272
+ while (old_node->next == 0)
273
+ {
274
+ sched_yield();
275
+ }
276
+ new_node->next = old_node->next;
277
+ }
278
+ }
@@ -0,0 +1,232 @@
1
+ /*
2
+ * ptw32_callUserDestroyRoutines.c
3
+ *
4
+ * Description:
5
+ * This translation unit implements routines which are private to
6
+ * the implementation and may be used throughout it.
7
+ *
8
+ * --------------------------------------------------------------------------
9
+ *
10
+ * Pthreads-win32 - POSIX Threads Library for Win32
11
+ * Copyright(C) 1998 John E. Bossom
12
+ * Copyright(C) 1999,2005 Pthreads-win32 contributors
13
+ *
14
+ * Contact Email: rpj@callisto.canberra.edu.au
15
+ *
16
+ * The current list of contributors is contained
17
+ * in the file CONTRIBUTORS included with the source
18
+ * code distribution. The list can also be seen at the
19
+ * following World Wide Web location:
20
+ * http://sources.redhat.com/pthreads-win32/contributors.html
21
+ *
22
+ * This library is free software; you can redistribute it and/or
23
+ * modify it under the terms of the GNU Lesser General Public
24
+ * License as published by the Free Software Foundation; either
25
+ * version 2 of the License, or (at your option) any later version.
26
+ *
27
+ * This library is distributed in the hope that it will be useful,
28
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
29
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
30
+ * Lesser General Public License for more details.
31
+ *
32
+ * You should have received a copy of the GNU Lesser General Public
33
+ * License along with this library in the file COPYING.LIB;
34
+ * if not, write to the Free Software Foundation, Inc.,
35
+ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
36
+ */
37
+
38
+ #include "pthread.h"
39
+ #include "implement.h"
40
+
41
+ #if defined(__CLEANUP_CXX)
42
+ # if defined(_MSC_VER)
43
+ # include <eh.h>
44
+ # elif defined(__WATCOMC__)
45
+ # include <eh.h>
46
+ # include <exceptio.h>
47
+ # else
48
+ # if defined(__GNUC__) && __GNUC__ < 3
49
+ # include <new.h>
50
+ # else
51
+ # include <new>
52
+ using
53
+ std::terminate;
54
+ # endif
55
+ # endif
56
+ #endif
57
+
58
+ void
59
+ ptw32_callUserDestroyRoutines (pthread_t thread)
60
+ /*
61
+ * -------------------------------------------------------------------
62
+ * DOCPRIVATE
63
+ *
64
+ * This the routine runs through all thread keys and calls
65
+ * the destroy routines on the user's data for the current thread.
66
+ * It simulates the behaviour of POSIX Threads.
67
+ *
68
+ * PARAMETERS
69
+ * thread
70
+ * an instance of pthread_t
71
+ *
72
+ * RETURNS
73
+ * N/A
74
+ * -------------------------------------------------------------------
75
+ */
76
+ {
77
+ ThreadKeyAssoc * assoc;
78
+
79
+ if (thread.p != NULL)
80
+ {
81
+ ptw32_mcs_local_node_t threadLock;
82
+ ptw32_mcs_local_node_t keyLock;
83
+ int assocsRemaining;
84
+ int iterations = 0;
85
+ ptw32_thread_t * sp = (ptw32_thread_t *) thread.p;
86
+
87
+ /*
88
+ * Run through all Thread<-->Key associations
89
+ * for the current thread.
90
+ *
91
+ * Do this process at most PTHREAD_DESTRUCTOR_ITERATIONS times.
92
+ */
93
+ do
94
+ {
95
+ assocsRemaining = 0;
96
+ iterations++;
97
+
98
+ ptw32_mcs_lock_acquire(&(sp->threadLock), &threadLock);
99
+ /*
100
+ * The pointer to the next assoc is stored in the thread struct so that
101
+ * the assoc destructor in pthread_key_delete can adjust it
102
+ * if it deletes this assoc. This can happen if we fail to acquire
103
+ * both locks below, and are forced to release all of our locks,
104
+ * leaving open the opportunity for pthread_key_delete to get in
105
+ * before us.
106
+ */
107
+ sp->nextAssoc = sp->keys;
108
+ ptw32_mcs_lock_release(&threadLock);
109
+
110
+ for (;;)
111
+ {
112
+ void * value;
113
+ pthread_key_t k;
114
+ void (*destructor) (void *);
115
+
116
+ /*
117
+ * First we need to serialise with pthread_key_delete by locking
118
+ * both assoc guards, but in the reverse order to our convention,
119
+ * so we must be careful to avoid deadlock.
120
+ */
121
+ ptw32_mcs_lock_acquire(&(sp->threadLock), &threadLock);
122
+
123
+ if ((assoc = (ThreadKeyAssoc *)sp->nextAssoc) == NULL)
124
+ {
125
+ /* Finished */
126
+ ptw32_mcs_lock_release(&threadLock);
127
+ break;
128
+ }
129
+ else
130
+ {
131
+ /*
132
+ * assoc->key must be valid because assoc can't change or be
133
+ * removed from our chain while we hold at least one lock. If
134
+ * the assoc was on our key chain then the key has not been
135
+ * deleted yet.
136
+ *
137
+ * Now try to acquire the second lock without deadlocking.
138
+ * If we fail, we need to relinquish the first lock and the
139
+ * processor and then try to acquire them all again.
140
+ */
141
+ if (ptw32_mcs_lock_try_acquire(&(assoc->key->keyLock), &keyLock) == EBUSY)
142
+ {
143
+ ptw32_mcs_lock_release(&threadLock);
144
+ Sleep(0);
145
+ /*
146
+ * Go around again.
147
+ * If pthread_key_delete has removed this assoc in the meantime,
148
+ * sp->nextAssoc will point to a new assoc.
149
+ */
150
+ continue;
151
+ }
152
+ }
153
+
154
+ /* We now hold both locks */
155
+
156
+ sp->nextAssoc = assoc->nextKey;
157
+
158
+ /*
159
+ * Key still active; pthread_key_delete
160
+ * will block on these same mutexes before
161
+ * it can release actual key; therefore,
162
+ * key is valid and we can call the destroy
163
+ * routine;
164
+ */
165
+ k = assoc->key;
166
+ destructor = k->destructor;
167
+ value = TlsGetValue(k->key);
168
+ TlsSetValue (k->key, NULL);
169
+
170
+ // Every assoc->key exists and has a destructor
171
+ if (value != NULL && iterations <= PTHREAD_DESTRUCTOR_ITERATIONS)
172
+ {
173
+ /*
174
+ * Unlock both locks before the destructor runs.
175
+ * POSIX says pthread_key_delete can be run from destructors,
176
+ * and that probably includes with this key as target.
177
+ * pthread_setspecific can also be run from destructors and
178
+ * also needs to be able to access the assocs.
179
+ */
180
+ ptw32_mcs_lock_release(&threadLock);
181
+ ptw32_mcs_lock_release(&keyLock);
182
+
183
+ assocsRemaining++;
184
+
185
+ #if defined(__cplusplus)
186
+
187
+ try
188
+ {
189
+ /*
190
+ * Run the caller's cleanup routine.
191
+ */
192
+ destructor (value);
193
+ }
194
+ catch (...)
195
+ {
196
+ /*
197
+ * A system unexpected exception has occurred
198
+ * running the user's destructor.
199
+ * We get control back within this block in case
200
+ * the application has set up it's own terminate
201
+ * handler. Since we are leaving the thread we
202
+ * should not get any internal pthreads
203
+ * exceptions.
204
+ */
205
+ terminate ();
206
+ }
207
+
208
+ #else /* __cplusplus */
209
+
210
+ /*
211
+ * Run the caller's cleanup routine.
212
+ */
213
+ destructor (value);
214
+
215
+ #endif /* __cplusplus */
216
+
217
+ }
218
+ else
219
+ {
220
+ /*
221
+ * Remove association from both the key and thread chains
222
+ * and reclaim it's memory resources.
223
+ */
224
+ ptw32_tkAssocDestroy (assoc);
225
+ ptw32_mcs_lock_release(&threadLock);
226
+ ptw32_mcs_lock_release(&keyLock);
227
+ }
228
+ }
229
+ }
230
+ while (assocsRemaining);
231
+ }
232
+ } /* ptw32_callUserDestroyRoutines */
@@ -0,0 +1,56 @@
1
+ /*
2
+ * ptw32_calloc.c
3
+ *
4
+ * Description:
5
+ * This translation unit implements miscellaneous thread functions.
6
+ *
7
+ * --------------------------------------------------------------------------
8
+ *
9
+ * Pthreads-win32 - POSIX Threads Library for Win32
10
+ * Copyright(C) 1998 John E. Bossom
11
+ * Copyright(C) 1999,2005 Pthreads-win32 contributors
12
+ *
13
+ * Contact Email: rpj@callisto.canberra.edu.au
14
+ *
15
+ * The current list of contributors is contained
16
+ * in the file CONTRIBUTORS included with the source
17
+ * code distribution. The list can also be seen at the
18
+ * following World Wide Web location:
19
+ * http://sources.redhat.com/pthreads-win32/contributors.html
20
+ *
21
+ * This library is free software; you can redistribute it and/or
22
+ * modify it under the terms of the GNU Lesser General Public
23
+ * License as published by the Free Software Foundation; either
24
+ * version 2 of the License, or (at your option) any later version.
25
+ *
26
+ * This library is distributed in the hope that it will be useful,
27
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
28
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
29
+ * Lesser General Public License for more details.
30
+ *
31
+ * You should have received a copy of the GNU Lesser General Public
32
+ * License along with this library in the file COPYING.LIB;
33
+ * if not, write to the Free Software Foundation, Inc.,
34
+ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
35
+ */
36
+
37
+ #include "pthread.h"
38
+ #include "implement.h"
39
+
40
+
41
+ #if defined(NEED_CALLOC)
42
+ void *
43
+ ptw32_calloc (size_t n, size_t s)
44
+ {
45
+ unsigned int m = n * s;
46
+ void *p;
47
+
48
+ p = malloc (m);
49
+ if (p == NULL)
50
+ return NULL;
51
+
52
+ memset (p, 0, m);
53
+
54
+ return p;
55
+ }
56
+ #endif
@@ -0,0 +1,78 @@
1
+ /*
2
+ * ptw32_cond_check_need_init.c
3
+ *
4
+ * Description:
5
+ * This translation unit implements condition variables and their primitives.
6
+ *
7
+ *
8
+ * --------------------------------------------------------------------------
9
+ *
10
+ * Pthreads-win32 - POSIX Threads Library for Win32
11
+ * Copyright(C) 1998 John E. Bossom
12
+ * Copyright(C) 1999,2005 Pthreads-win32 contributors
13
+ *
14
+ * Contact Email: rpj@callisto.canberra.edu.au
15
+ *
16
+ * The current list of contributors is contained
17
+ * in the file CONTRIBUTORS included with the source
18
+ * code distribution. The list can also be seen at the
19
+ * following World Wide Web location:
20
+ * http://sources.redhat.com/pthreads-win32/contributors.html
21
+ *
22
+ * This library is free software; you can redistribute it and/or
23
+ * modify it under the terms of the GNU Lesser General Public
24
+ * License as published by the Free Software Foundation; either
25
+ * version 2 of the License, or (at your option) any later version.
26
+ *
27
+ * This library is distributed in the hope that it will be useful,
28
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
29
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
30
+ * Lesser General Public License for more details.
31
+ *
32
+ * You should have received a copy of the GNU Lesser General Public
33
+ * License along with this library in the file COPYING.LIB;
34
+ * if not, write to the Free Software Foundation, Inc.,
35
+ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
36
+ */
37
+
38
+ #include "pthread.h"
39
+ #include "implement.h"
40
+
41
+
42
+ int
43
+ ptw32_cond_check_need_init (pthread_cond_t * cond)
44
+ {
45
+ int result = 0;
46
+ ptw32_mcs_local_node_t node;
47
+
48
+ /*
49
+ * The following guarded test is specifically for statically
50
+ * initialised condition variables (via PTHREAD_OBJECT_INITIALIZER).
51
+ */
52
+ ptw32_mcs_lock_acquire(&ptw32_cond_test_init_lock, &node);
53
+
54
+ /*
55
+ * We got here possibly under race
56
+ * conditions. Check again inside the critical section.
57
+ * If a static cv has been destroyed, the application can
58
+ * re-initialise it only by calling pthread_cond_init()
59
+ * explicitly.
60
+ */
61
+ if (*cond == PTHREAD_COND_INITIALIZER)
62
+ {
63
+ result = pthread_cond_init (cond, NULL);
64
+ }
65
+ else if (*cond == NULL)
66
+ {
67
+ /*
68
+ * The cv has been destroyed while we were waiting to
69
+ * initialise it, so the operation that caused the
70
+ * auto-initialisation should fail.
71
+ */
72
+ result = EINVAL;
73
+ }
74
+
75
+ ptw32_mcs_lock_release(&node);
76
+
77
+ return result;
78
+ }