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