mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 09:52:07 +00:00 
			
		
		
		
	 690141ff8b
			
		
	
	
		690141ff8b
		
	
	
	
	
		
			
			This implementation does not use locking or condition variables internally; it's purely based on atomics and futexes. Notably, concurrent sem_wait() and sem_post() calls can run *completely in parallel* without slowing each other down, as long as there are empty slots for them all to succeed without blocking. Additionally, sem_wait() never executes an atomic operation with release ordering, and sem_post() never executes an atomic operation with acquire ordering (unless you count the syscall). This means the compiler and the hardware are free to reorder code *into* the critical section.
		
			
				
	
	
		
			33 lines
		
	
	
	
		
			628 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
	
		
			628 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <limits.h>
 | |
| #include <pthread.h>
 | |
| #include <sys/cdefs.h>
 | |
| #include <sys/types.h>
 | |
| 
 | |
| __BEGIN_DECLS
 | |
| 
 | |
| typedef struct {
 | |
|     uint32_t value;
 | |
| } sem_t;
 | |
| 
 | |
| int sem_close(sem_t*);
 | |
| int sem_destroy(sem_t*);
 | |
| int sem_getvalue(sem_t*, int*);
 | |
| int sem_init(sem_t*, int, unsigned int);
 | |
| sem_t* sem_open(const char*, int, ...);
 | |
| int sem_post(sem_t*);
 | |
| int sem_trywait(sem_t*);
 | |
| int sem_unlink(const char*);
 | |
| int sem_wait(sem_t*);
 | |
| int sem_timedwait(sem_t*, const struct timespec* abstime);
 | |
| 
 | |
| #define SEM_VALUE_MAX INT_MAX
 | |
| 
 | |
| __END_DECLS
 |