mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-26 11:10:58 +00:00 
			
		
		
		
	Introduce cosmo_futex_wait and cosmo_futex_wake
Cosmopolitan Futexes are now exposed as a public API.
This commit is contained in:
		
							parent
							
								
									729f7045e3
								
							
						
					
					
						commit
						9ddbfd921e
					
				
					 66 changed files with 886 additions and 917 deletions
				
			
		|  | @ -17,11 +17,11 @@ | |||
| │ PERFORMANCE OF THIS SOFTWARE.                                                │ | ||||
| ╚─────────────────────────────────────────────────────────────────────────────*/ | ||||
| #include "libc/calls/blockcancel.internal.h" | ||||
| #include "libc/cosmo.h" | ||||
| #include "libc/errno.h" | ||||
| #include "libc/intrin/atomic.h" | ||||
| #include "libc/limits.h" | ||||
| #include "libc/thread/thread.h" | ||||
| #include "third_party/nsync/futex.internal.h" | ||||
| 
 | ||||
| /**
 | ||||
|  * Waits for all threads to arrive at barrier. | ||||
|  | @ -54,14 +54,14 @@ errno_t pthread_barrier_wait(pthread_barrier_t *barrier) { | |||
|     atomic_store_explicit(&barrier->_counter, barrier->_count, | ||||
|                           memory_order_release); | ||||
|     atomic_store_explicit(&barrier->_waiters, 0, memory_order_release); | ||||
|     nsync_futex_wake_(&barrier->_waiters, INT_MAX, barrier->_pshared); | ||||
|     cosmo_futex_wake(&barrier->_waiters, INT_MAX, barrier->_pshared); | ||||
|     return PTHREAD_BARRIER_SERIAL_THREAD; | ||||
|   } | ||||
| 
 | ||||
|   // wait for everyone else to arrive at barrier
 | ||||
|   BLOCK_CANCELATION; | ||||
|   while ((n = atomic_load_explicit(&barrier->_waiters, memory_order_acquire))) | ||||
|     nsync_futex_wait_(&barrier->_waiters, n, barrier->_pshared, 0, 0); | ||||
|     cosmo_futex_wait(&barrier->_waiters, n, barrier->_pshared, 0, 0); | ||||
|   ALLOW_CANCELATION; | ||||
| 
 | ||||
|   return 0; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue