xref: /nrf52832-nimble/rt-thread/components/libc/pthreads/pthread_barrier.c (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero /*
2*10465441SEvalZero  * Copyright (c) 2006-2018, RT-Thread Development Team
3*10465441SEvalZero  *
4*10465441SEvalZero  * SPDX-License-Identifier: Apache-2.0
5*10465441SEvalZero  *
6*10465441SEvalZero  * Change Logs:
7*10465441SEvalZero  * Date           Author       Notes
8*10465441SEvalZero  * 2010-10-26     Bernard      the first version
9*10465441SEvalZero  */
10*10465441SEvalZero 
11*10465441SEvalZero #include <pthread.h>
12*10465441SEvalZero 
pthread_barrierattr_destroy(pthread_barrierattr_t * attr)13*10465441SEvalZero int pthread_barrierattr_destroy(pthread_barrierattr_t *attr)
14*10465441SEvalZero {
15*10465441SEvalZero     if (!attr)
16*10465441SEvalZero         return EINVAL;
17*10465441SEvalZero 
18*10465441SEvalZero     return 0;
19*10465441SEvalZero }
20*10465441SEvalZero RTM_EXPORT(pthread_barrierattr_destroy);
21*10465441SEvalZero 
pthread_barrierattr_init(pthread_barrierattr_t * attr)22*10465441SEvalZero int pthread_barrierattr_init(pthread_barrierattr_t *attr)
23*10465441SEvalZero {
24*10465441SEvalZero     if (!attr)
25*10465441SEvalZero         return EINVAL;
26*10465441SEvalZero     *attr = PTHREAD_PROCESS_PRIVATE;
27*10465441SEvalZero 
28*10465441SEvalZero     return 0;
29*10465441SEvalZero }
30*10465441SEvalZero RTM_EXPORT(pthread_barrierattr_init);
31*10465441SEvalZero 
pthread_barrierattr_getpshared(const pthread_barrierattr_t * attr,int * pshared)32*10465441SEvalZero int pthread_barrierattr_getpshared(const pthread_barrierattr_t *attr,
33*10465441SEvalZero                                    int                         *pshared)
34*10465441SEvalZero {
35*10465441SEvalZero     if (!attr)
36*10465441SEvalZero         return EINVAL;
37*10465441SEvalZero     *pshared = (int)*attr;
38*10465441SEvalZero 
39*10465441SEvalZero     return 0;
40*10465441SEvalZero }
41*10465441SEvalZero RTM_EXPORT(pthread_barrierattr_getpshared);
42*10465441SEvalZero 
pthread_barrierattr_setpshared(pthread_barrierattr_t * attr,int pshared)43*10465441SEvalZero int pthread_barrierattr_setpshared(pthread_barrierattr_t *attr, int pshared)
44*10465441SEvalZero {
45*10465441SEvalZero     if (!attr)
46*10465441SEvalZero         return EINVAL;
47*10465441SEvalZero     if (pshared == PTHREAD_PROCESS_PRIVATE)
48*10465441SEvalZero         attr = PTHREAD_PROCESS_PRIVATE;
49*10465441SEvalZero 
50*10465441SEvalZero     return EINVAL;
51*10465441SEvalZero }
52*10465441SEvalZero RTM_EXPORT(pthread_barrierattr_setpshared);
53*10465441SEvalZero 
pthread_barrier_destroy(pthread_barrier_t * barrier)54*10465441SEvalZero int pthread_barrier_destroy(pthread_barrier_t *barrier)
55*10465441SEvalZero {
56*10465441SEvalZero     rt_err_t result;
57*10465441SEvalZero 
58*10465441SEvalZero     if (!barrier)
59*10465441SEvalZero         return EINVAL;
60*10465441SEvalZero 
61*10465441SEvalZero     result = pthread_cond_destroy(&(barrier->cond));
62*10465441SEvalZero 
63*10465441SEvalZero     return result;
64*10465441SEvalZero }
65*10465441SEvalZero RTM_EXPORT(pthread_barrier_destroy);
66*10465441SEvalZero 
pthread_barrier_init(pthread_barrier_t * barrier,const pthread_barrierattr_t * attr,unsigned count)67*10465441SEvalZero int pthread_barrier_init(pthread_barrier_t           *barrier,
68*10465441SEvalZero                          const pthread_barrierattr_t *attr,
69*10465441SEvalZero                          unsigned                     count)
70*10465441SEvalZero {
71*10465441SEvalZero     if (!barrier)
72*10465441SEvalZero         return EINVAL;
73*10465441SEvalZero     if (attr && (*attr != PTHREAD_PROCESS_PRIVATE))
74*10465441SEvalZero         return EINVAL;
75*10465441SEvalZero 
76*10465441SEvalZero     barrier->count = count;
77*10465441SEvalZero     pthread_cond_init(&(barrier->cond), NULL);
78*10465441SEvalZero     pthread_mutex_init(&(barrier->mutex), NULL);
79*10465441SEvalZero 
80*10465441SEvalZero     return 0;
81*10465441SEvalZero }
82*10465441SEvalZero RTM_EXPORT(pthread_barrier_init);
83*10465441SEvalZero 
pthread_barrier_wait(pthread_barrier_t * barrier)84*10465441SEvalZero int pthread_barrier_wait(pthread_barrier_t *barrier)
85*10465441SEvalZero {
86*10465441SEvalZero     rt_err_t result;
87*10465441SEvalZero     if (!barrier)
88*10465441SEvalZero         return EINVAL;
89*10465441SEvalZero 
90*10465441SEvalZero     result = pthread_mutex_lock(&(barrier->mutex));
91*10465441SEvalZero     if (result != 0)
92*10465441SEvalZero         return EINVAL;
93*10465441SEvalZero 
94*10465441SEvalZero     if (barrier->count == 0)
95*10465441SEvalZero         result = EINVAL;
96*10465441SEvalZero     else
97*10465441SEvalZero     {
98*10465441SEvalZero         barrier->count -= 1;
99*10465441SEvalZero         if (barrier->count == 0) /* broadcast condition */
100*10465441SEvalZero             pthread_cond_broadcast(&(barrier->cond));
101*10465441SEvalZero         else
102*10465441SEvalZero             pthread_cond_wait(&(barrier->cond), &(barrier->mutex));
103*10465441SEvalZero     }
104*10465441SEvalZero 
105*10465441SEvalZero     pthread_mutex_unlock(&(barrier->mutex));
106*10465441SEvalZero 
107*10465441SEvalZero     return result;
108*10465441SEvalZero }
109*10465441SEvalZero RTM_EXPORT(pthread_barrier_wait);
110*10465441SEvalZero 
111